test_admin_views.py 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  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"), data={"username": "Nope", "password": "Nope"}
  35. )
  36. self.assertContains(response, "Login or password is incorrect.")
  37. self.assertContains(response, "Sign in")
  38. self.assertContains(response, "Username or e-mail")
  39. self.assertContains(response, "Password")
  40. def test_login_denies_non_staff_non_superuser(self):
  41. """login rejects user thats non staff and non superuser"""
  42. user = UserModel.objects.create_user("Bob", "bob@test.com", "Pass.123")
  43. user.is_staff = False
  44. user.is_superuser = False
  45. user.save()
  46. response = self.client.post(
  47. reverse("misago:admin:index"),
  48. data={"username": "Bob", "password": "Pass.123"},
  49. )
  50. self.assertContains(response, "Your account does not have admin privileges.")
  51. def test_login_denies_non_staff_superuser(self):
  52. """login rejects user thats non staff and superuser"""
  53. user = UserModel.objects.create_user("Bob", "bob@test.com", "Pass.123")
  54. user.is_staff = False
  55. user.is_superuser = True
  56. user.save()
  57. response = self.client.post(
  58. reverse("misago:admin:index"),
  59. data={"username": "Bob", "password": "Pass.123"},
  60. )
  61. self.assertContains(response, "Your account does not have admin privileges.")
  62. def test_login_signs_in_staff_non_superuser(self):
  63. """login passess user thats staff and non superuser"""
  64. user = UserModel.objects.create_user("Bob", "bob@test.com", "Pass.123")
  65. user.is_staff = True
  66. user.is_superuser = False
  67. user.save()
  68. response = self.client.post(
  69. reverse("misago:admin:index"),
  70. data={"username": "Bob", "password": "Pass.123"},
  71. )
  72. self.assertEqual(response.status_code, 302)
  73. def test_login_signs_in_staff_superuser(self):
  74. """login passess user thats staff and superuser"""
  75. user = UserModel.objects.create_user("Bob", "bob@test.com", "Pass.123")
  76. user.is_staff = True
  77. user.is_superuser = True
  78. user.save()
  79. response = self.client.post(
  80. reverse("misago:admin:index"),
  81. data={"username": "Bob", "password": "Pass.123"},
  82. )
  83. self.assertEqual(response.status_code, 302)
  84. class AdminLogoutTests(AdminTestCase):
  85. def test_admin_logout(self):
  86. """admin logout logged from admin only"""
  87. response = self.client.post(reverse("misago:admin:logout"))
  88. self.assertEqual(response.status_code, 302)
  89. response = self.client.get(reverse("misago:admin:index"))
  90. self.assertContains(response, "Your admin session has been closed.")
  91. response = self.client.get(reverse("misago:index"))
  92. self.assertContains(response, self.user.username)
  93. def test_complete_logout(self):
  94. """complete logout logged from both admin and site"""
  95. response = self.client.post(reverse("misago:logout"))
  96. self.assertEqual(response.status_code, 302)
  97. response = self.client.get(reverse("misago:admin:index"))
  98. self.assertContains(response, "Sign in")
  99. response = self.client.get(reverse("misago:index"))
  100. self.assertContains(response, "Sign in")
  101. class AdminViewAccessTests(AdminTestCase):
  102. def test_admin_denies_non_staff_non_superuser(self):
  103. """admin middleware rejects user thats non staff and non superuser"""
  104. self.user.is_staff = False
  105. self.user.is_superuser = False
  106. self.user.save()
  107. response = self.client.get(reverse("misago:admin:index"))
  108. self.assertContains(response, "Sign in")
  109. def test_admin_denies_non_staff_superuser(self):
  110. """admin middleware rejects user thats non staff and superuser"""
  111. self.user.is_staff = False
  112. self.user.is_superuser = True
  113. self.user.save()
  114. response = self.client.get(reverse("misago:admin:index"))
  115. self.assertContains(response, "Sign in")
  116. def test_admin_passess_in_staff_non_superuser(self):
  117. """admin middleware passess user thats staff and non superuser"""
  118. self.user.is_staff = True
  119. self.user.is_superuser = False
  120. self.user.save()
  121. response = self.client.get(reverse("misago:admin:index"))
  122. self.assertContains(response, self.user.username)
  123. def test_admin_passess_in_staff_superuser(self):
  124. """admin middleware passess user thats staff and superuser"""
  125. self.user.is_staff = True
  126. self.user.is_superuser = True
  127. self.user.save()
  128. response = self.client.get(reverse("misago:admin:index"))
  129. self.assertContains(response, self.user.username)
  130. class Admin404ErrorTests(AdminTestCase):
  131. def test_list_search_unicode_handling(self):
  132. """querystring creation handles unicode strings"""
  133. test_link = "%stotally-errored/" % reverse("misago:admin:index")
  134. response = self.client.get(test_link)
  135. self.assertContains(
  136. response, "Requested page could not be found.", status_code=404
  137. )
  138. class AdminGenericViewsTests(AdminTestCase):
  139. def test_view_redirected_queryvar(self):
  140. """querystring redirected value is handled"""
  141. test_link = reverse("misago:admin:users:accounts:index")
  142. # request resulted in redirect with redirected=1 bit
  143. response = self.client.get("%s?username=lorem" % test_link)
  144. self.assertEqual(response.status_code, 302)
  145. self.assertIn("redirected=1", response["location"])
  146. # request with flag muted redirect
  147. response = self.client.get("%s?redirected=1&username=lorem" % test_link)
  148. self.assertEqual(response.status_code, 200)
  149. def test_list_search_unicode_handling(self):
  150. """querystring creation handles unicode strings"""
  151. test_link = reverse("misago:admin:users:accounts:index")
  152. response = self.client.get("%s?redirected=1&username=%s" % (test_link, "łut"))
  153. self.assertEqual(response.status_code, 200)