test_admin_views.py 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. from django.contrib.auth import get_user_model
  2. from django.core.urlresolvers import reverse
  3. from django.test import TestCase
  4. from ..testutils import AdminTestCase
  5. from ..views import get_protected_namespace
  6. class FakeRequest(object):
  7. def __init__(self, path):
  8. self.path = path
  9. self.path_info = path
  10. class AdminProtectedNamespaceTests(TestCase):
  11. def test_valid_cases(self):
  12. """get_protected_namespace returns true for protected links"""
  13. links_prefix = reverse('misago:admin:index')
  14. TEST_CASES = (
  15. '',
  16. 'somewhere/',
  17. 'ejksajdlksajldjskajdlksajlkdas',
  18. )
  19. for case in TEST_CASES:
  20. request = FakeRequest(links_prefix + case)
  21. self.assertEqual(get_protected_namespace(request), 'misago:admin')
  22. def test_invalid_cases(self):
  23. """get_protected_namespace returns none for other links"""
  24. TEST_CASES = (
  25. '/',
  26. '/somewhere/',
  27. '/ejksajdlksajldjskajdlksajlkdas',
  28. )
  29. for case in TEST_CASES:
  30. request = FakeRequest(case)
  31. self.assertEqual(get_protected_namespace(request), None)
  32. class AdminLoginViewTests(TestCase):
  33. def test_login_returns_200_on_get(self):
  34. """unauthenticated request to admin index produces login form"""
  35. response = self.client.get(reverse('misago:admin:index'))
  36. self.assertEqual(response.status_code, 200)
  37. self.assertIn('Sign in', response.content)
  38. self.assertIn('Username or e-mail', response.content)
  39. self.assertIn('Password', response.content)
  40. def test_login_returns_200_on_invalid_post(self):
  41. """form handles invalid data gracefully"""
  42. response = self.client.post(
  43. reverse('misago:admin:index'),
  44. data={'username': 'Nope', 'password': 'Nope'})
  45. self.assertEqual(response.status_code, 200)
  46. self.assertIn('Login or password is incorrect.', response.content)
  47. self.assertIn('Sign in', response.content)
  48. self.assertIn('Username or e-mail', response.content)
  49. self.assertIn('Password', response.content)
  50. def test_login_returns_200_on_valid_post(self):
  51. """form handles valid data correctly"""
  52. User = get_user_model()
  53. User.objects.create_superuser('Bob', 'bob@test.com', 'Pass.123')
  54. response = self.client.post(
  55. reverse('misago:admin:index'),
  56. data={'username': 'Bob', 'password': 'Pass.123'})
  57. self.assertEqual(response.status_code, 302)
  58. class AdminLogoutTests(AdminTestCase):
  59. def test_admin_logout(self):
  60. """admin logout logged from admin only"""
  61. response = self.client.post(reverse('misago:admin:logout'))
  62. self.assertEqual(response.status_code, 302)
  63. response = self.client.get(reverse('misago:admin:index'))
  64. self.assertEqual(response.status_code, 200)
  65. self.assertIn("Your admin session has been closed.", response.content)
  66. response = self.client.get(reverse('misago:index'))
  67. self.assertEqual(response.status_code, 200)
  68. self.assertIn(self.user.username, response.content)
  69. def test_complete_logout(self):
  70. """complete logout logged from both admin and site"""
  71. response = self.client.post(reverse('misago:logout'))
  72. self.assertEqual(response.status_code, 302)
  73. response = self.client.get(reverse('misago:admin:index'))
  74. self.assertEqual(response.status_code, 200)
  75. self.assertIn("Sign in", response.content)
  76. response = self.client.get(reverse('misago:index'))
  77. self.assertEqual(response.status_code, 200)
  78. self.assertIn("Sign in", response.content)
  79. class AdminIndexViewTests(AdminTestCase):
  80. def test_view_returns_200(self):
  81. """admin index view returns 200"""
  82. response = self.client.get(reverse('misago:admin:index'))
  83. self.assertEqual(response.status_code, 200)
  84. self.assertIn(self.user.username, response.content)