test_admin_views.py 7.8 KB

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