test_admin_views.py 7.4 KB

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