test_admin_views.py 8.1 KB

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