tests.py 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. from django.contrib.auth.models import User
  2. from django.core.urlresolvers import reverse
  3. from django.test import TestCase
  4. from django.contrib.contenttypes.models import ContentType
  5. from django.utils import timezone
  6. from adhesions.models import Adhesion, Corporation
  7. from .models import Service, ServiceType, IPResource, ResourceAllocation
  8. class ServicesTests(TestCase):
  9. def setUp(self):
  10. user_ct = ContentType.objects.get_for_model(User)
  11. corp_ct = ContentType.objects.get_for_model(Corporation)
  12. user1 = User.objects.create_user('user1', email='user1@example.net', password='user1')
  13. adh_u1 = Adhesion.objects.create(adherent_type=user_ct, adherent_id=user1.pk)
  14. corp1 = Corporation.objects.create(social_reason='Corp 1')
  15. corp1.members.add(user1)
  16. adh_c1 = Adhesion.objects.create(adherent_type=corp_ct, adherent_id=corp1.pk)
  17. user2 = User.objects.create_user('user2', email='user2@example.net', password='user2', is_superuser=True)
  18. adh_u2 = Adhesion.objects.create(adherent_type=user_ct, adherent_id=user2.pk)
  19. corp2 = Corporation.objects.create(social_reason='Corp 2')
  20. corp2.members.add(user2)
  21. adh_c2 = Adhesion.objects.create(adherent_type=corp_ct, adherent_id=corp2.pk)
  22. stype = ServiceType.objects.create(name='VM')
  23. s1 = Service.objects.create(adhesion=adh_u1, service_type=stype, label='Service 1')
  24. s2 = Service.objects.create(adhesion=adh_u2, service_type=stype, label='Service 2')
  25. s3 = Service.objects.create(adhesion=adh_c1, service_type=stype, label='Service 3')
  26. s4 = Service.objects.create(adhesion=adh_c2, service_type=stype, label='Service 4')
  27. ip1 = IPResource.objects.create(ip='91.224.148.1')
  28. ResourceAllocation.objects.create(resource=ip1, service=s1, start=timezone.now())
  29. ip2 = IPResource.objects.create(ip='91.224.148.2')
  30. ip3 = IPResource.objects.create(ip='91.224.148.3', mask=32)
  31. def test_home_service_list(self):
  32. self.client.login(username='user1', password='user1')
  33. response = self.client.get(reverse('user'))
  34. self.assertContains(response, 'Service 1')
  35. self.assertNotContains(response, 'Service 2')
  36. self.assertNotContains(response, 'Service 3')
  37. self.assertNotContains(response, 'Service 4')
  38. def test_service_list(self):
  39. self.client.login(username='user1', password='user1')
  40. response = self.client.get(reverse('service-list'))
  41. self.assertRedirects(response, reverse('login') + '?next=' + reverse('service-list'))
  42. self.client.login(username='user2', password='user2')
  43. response = self.client.get(reverse('service-list'))
  44. self.assertEqual(response.status_code, 200)
  45. self.assertContains(response, 'Service 1')
  46. self.assertContains(response, 'Service 2')
  47. self.assertContains(response, 'Service 3')
  48. self.assertContains(response, 'Service 4')
  49. def test_service_detail(self):
  50. s1 = Service.objects.get(label='Service 1')
  51. s2 = Service.objects.get(label='Service 2')
  52. s3 = Service.objects.get(label='Service 3')
  53. s4 = Service.objects.get(label='Service 4')
  54. # L’utilisateur lambda n’a accès qu’aux services 1 et 3
  55. self.client.login(username='user1', password='user1')
  56. response = self.client.get(reverse('service-detail', kwargs={'pk': s1.pk}))
  57. self.assertEqual(response.status_code, 200)
  58. response = self.client.get(reverse('service-detail', kwargs={'pk': s2.pk}))
  59. self.assertEqual(response.status_code, 404)
  60. response = self.client.get(reverse('service-detail', kwargs={'pk': s3.pk}))
  61. self.assertEqual(response.status_code, 200)
  62. response = self.client.get(reverse('service-detail', kwargs={'pk': s4.pk}))
  63. self.assertEqual(response.status_code, 404)
  64. # L’admin a accès à tous les services
  65. self.client.login(username='user2', password='user2')
  66. response = self.client.get(reverse('service-detail', kwargs={'pk': s1.pk}))
  67. self.assertEqual(response.status_code, 200)
  68. response = self.client.get(reverse('service-detail', kwargs={'pk': s2.pk}))
  69. self.assertEqual(response.status_code, 200)
  70. response = self.client.get(reverse('service-detail', kwargs={'pk': s3.pk}))
  71. self.assertEqual(response.status_code, 200)
  72. response = self.client.get(reverse('service-detail', kwargs={'pk': s4.pk}))
  73. self.assertEqual(response.status_code, 200)
  74. def test_ipresource_allocate(self):
  75. ip1 = IPResource.objects.get(ip='91.224.148.1')
  76. url1 = reverse('ip-allocate', kwargs={'pk': ip1.pk})
  77. ip2 = IPResource.objects.get(ip='91.224.148.2')
  78. url2 = reverse('ip-allocate', kwargs={'pk': ip2.pk})
  79. self.client.login(username='user1', password='user1')
  80. response = self.client.get(url1)
  81. self.assertRedirects(response, reverse('login') + '?next=' + url1)
  82. self.client.login(username='user2', password='user2')
  83. response = self.client.get(url1)
  84. self.assertEqual(response.status_code, 410)
  85. response = self.client.get(url2)
  86. self.assertEqual(response.status_code, 200)
  87. def test_service_allocate(self):
  88. s1 = Service.objects.get(label='Service 1')
  89. url = reverse('service-allocate', kwargs={'pk': s1.pk})
  90. self.client.login(username='user1', password='user1')
  91. response = self.client.get(url)
  92. self.assertRedirects(response, reverse('login') + '?next=' + url)
  93. self.client.login(username='user2', password='user2')
  94. response = self.client.get(url)
  95. self.assertEqual(response.status_code, 200)
  96. self.assertNotContains(response, '91.224.148.1') # in use
  97. self.assertContains(response, '91.224.148.2')
  98. self.assertContains(response, '91.224.148.3')
  99. def test_deallocate(self):
  100. ip1 = IPResource.objects.get(ip='91.224.148.1')
  101. ip2 = IPResource.objects.get(ip='91.224.148.2')
  102. allocation = ResourceAllocation.objects.get(resource=ip1)
  103. self.assertTrue(ip1.in_use)
  104. self.assertFalse(ip2.in_use)
  105. self.assertTrue(allocation.active)
  106. url = reverse('deallocate', kwargs={'pk': allocation.pk})
  107. self.client.login(username='user1', password='user1')
  108. response = self.client.get(url)
  109. self.assertRedirects(response, reverse('login') + '?next=' + url)
  110. self.client.login(username='user2', password='user2')
  111. response = self.client.get(url)
  112. self.assertEqual(response.status_code, 405)
  113. response = self.client.post(url)
  114. self.assertRedirects(response, reverse('ip-detail', kwargs={'pk': ip1.pk}))
  115. self.assertFalse(ip1.in_use)
  116. self.assertFalse(allocation.active)
  117. response = self.client.post(url)
  118. self.assertEqual(response.status_code, 403)