test_admin_views.py 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. # -*- coding: utf-8 -*-
  2. from __future__ import unicode_literals
  3. from django.contrib.auth import get_user_model
  4. from django.test import TestCase
  5. from django.urls import reverse
  6. from ..testutils import AdminTestCase
  7. from ..views import get_protected_namespace
  8. class FakeRequest(object):
  9. def __init__(self, path):
  10. self.path = path
  11. self.path_info = path
  12. class AdminProtectedNamespaceTests(TestCase):
  13. def test_valid_cases(self):
  14. """get_protected_namespace returns true for protected links"""
  15. links_prefix = reverse('misago:admin:index')
  16. TEST_CASES = (
  17. '',
  18. 'somewhere/',
  19. 'ejksajdlksajldjskajdlksajlkdas',
  20. )
  21. for case in TEST_CASES:
  22. request = FakeRequest(links_prefix + case)
  23. self.assertEqual(get_protected_namespace(request), 'misago:admin')
  24. def test_invalid_cases(self):
  25. """get_protected_namespace returns none for other links"""
  26. TEST_CASES = (
  27. '/',
  28. '/somewhere/',
  29. '/ejksajdlksajldjskajdlksajlkdas',
  30. )
  31. for case in TEST_CASES:
  32. request = FakeRequest(case)
  33. self.assertEqual(get_protected_namespace(request), None)
  34. class AdminLoginViewTests(TestCase):
  35. def test_login_returns_200_on_get(self):
  36. """unauthenticated request to admin index produces login form"""
  37. response = self.client.get(reverse('misago:admin:index'))
  38. self.assertContains(response, 'Sign in')
  39. self.assertContains(response, 'Username or e-mail')
  40. self.assertContains(response, 'Password')
  41. def test_login_returns_200_on_invalid_post(self):
  42. """form handles invalid data gracefully"""
  43. response = self.client.post(
  44. reverse('misago:admin:index'),
  45. data={'username': 'Nope', 'password': 'Nope'})
  46. self.assertContains(response, "Login or password is incorrect.")
  47. self.assertContains(response, "Sign in")
  48. self.assertContains(response, "Username or e-mail")
  49. self.assertContains(response, "Password")
  50. def test_login_denies_non_staff_non_superuser(self):
  51. """login rejects user thats non staff and non superuser"""
  52. User = get_user_model()
  53. user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  54. user.is_staff = False
  55. user.is_superuser = False
  56. user.save()
  57. response = self.client.post(
  58. reverse('misago:admin:index'),
  59. data={'username': 'Bob', 'password': 'Pass.123'})
  60. self.assertContains(response, "Your account does not have admin privileges.")
  61. def test_login_denies_non_staff_superuser(self):
  62. """login rejects user thats non staff and superuser"""
  63. User = get_user_model()
  64. user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  65. user.is_staff = False
  66. user.is_superuser = True
  67. user.save()
  68. response = self.client.post(
  69. reverse('misago:admin:index'),
  70. data={'username': 'Bob', 'password': 'Pass.123'})
  71. self.assertContains(response, "Your account does not have admin privileges.")
  72. def test_login_signs_in_staff_non_superuser(self):
  73. """login passess user thats staff and non superuser"""
  74. User = get_user_model()
  75. user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  76. user.is_staff = True
  77. user.is_superuser = False
  78. user.save()
  79. response = self.client.post(
  80. reverse('misago:admin:index'),
  81. data={'username': 'Bob', 'password': 'Pass.123'})
  82. self.assertEqual(response.status_code, 302)
  83. def test_login_signs_in_staff_superuser(self):
  84. """login passess user thats staff and superuser"""
  85. User = get_user_model()
  86. user = User.objects.create_user('Bob', 'bob@test.com', 'Pass.123')
  87. user.is_staff = True
  88. user.is_superuser = True
  89. user.save()
  90. response = self.client.post(
  91. reverse('misago:admin:index'),
  92. data={'username': 'Bob', 'password': 'Pass.123'})
  93. self.assertEqual(response.status_code, 302)
  94. class AdminLogoutTests(AdminTestCase):
  95. def test_admin_logout(self):
  96. """admin logout logged from admin only"""
  97. response = self.client.post(reverse('misago:admin:logout'))
  98. self.assertEqual(response.status_code, 302)
  99. response = self.client.get(reverse('misago:admin:index'))
  100. self.assertContains(response, "Your admin session has been closed.")
  101. response = self.client.get(reverse('misago:index'))
  102. self.assertContains(response, self.user.username)
  103. def test_complete_logout(self):
  104. """complete logout logged from both admin and site"""
  105. response = self.client.post(reverse('misago:logout'))
  106. self.assertEqual(response.status_code, 302)
  107. response = self.client.get(reverse('misago:admin:index'))
  108. self.assertContains(response, "Sign in")
  109. response = self.client.get(reverse('misago:index'))
  110. self.assertContains(response, "Sign in")
  111. class AdminViewAccessTests(AdminTestCase):
  112. def test_admin_denies_non_staff_non_superuser(self):
  113. """admin middleware rejects user thats non staff and non superuser"""
  114. self.user.is_staff = False
  115. self.user.is_superuser = False
  116. self.user.save()
  117. response = self.client.get(reverse('misago:admin:index'))
  118. self.assertContains(response, "Sign in")
  119. def test_admin_denies_non_staff_superuser(self):
  120. """admin middleware rejects user thats non staff and superuser"""
  121. self.user.is_staff = False
  122. self.user.is_superuser = True
  123. self.user.save()
  124. response = self.client.get(reverse('misago:admin:index'))
  125. self.assertContains(response, "Sign in")
  126. def test_admin_passess_in_staff_non_superuser(self):
  127. """admin middleware passess user thats staff and non superuser"""
  128. self.user.is_staff = True
  129. self.user.is_superuser = False
  130. self.user.save()
  131. response = self.client.get(reverse('misago:admin:index'))
  132. self.assertContains(response, self.user.username)
  133. def test_admin_passess_in_staff_superuser(self):
  134. """admin middleware passess user thats staff and superuser"""
  135. self.user.is_staff = True
  136. self.user.is_superuser = True
  137. self.user.save()
  138. response = self.client.get(reverse('misago:admin:index'))
  139. self.assertContains(response, self.user.username)
  140. class AdminIndexViewTests(AdminTestCase):
  141. def test_view_returns_200(self):
  142. """admin index view returns 200"""
  143. response = self.client.get(reverse('misago:admin:index'))
  144. self.assertContains(response, self.user.username)
  145. class AdminGenericViewsTests(AdminTestCase):
  146. def test_view_redirected_queryvar(self):
  147. """querystring redirected value is handled"""
  148. test_link = reverse('misago:admin:users:accounts:index')
  149. # request resulted in redirect with redirected=1 bit
  150. response = self.client.get('%s?username=lorem' % test_link)
  151. self.assertEqual(response.status_code, 302)
  152. self.assertIn('redirected=1', response['location'])
  153. # request with flag muted redirect
  154. response = self.client.get(
  155. '%s?redirected=1&username=lorem' % test_link)
  156. self.assertEqual(response.status_code, 200)
  157. def test_list_search_unicode_handling(self):
  158. """querystring creation handles unicode strings"""
  159. test_link = reverse('misago:admin:users:accounts:index')
  160. response = self.client.get(
  161. '%s?redirected=1&username=%s' % (test_link, 'łut'))
  162. self.assertEqual(response.status_code, 200)