test_admin_views.py 7.8 KB

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