test_admin_views.py 4.3 KB

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