test_admin_views.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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 AdminIndexViewTests(TestCase):
  7. def test_view_returns_200(self):
  8. """admin index view returns 200"""
  9. User = get_user_model()
  10. User.objects.create_superuser('Bob', 'bob@test.com', 'Pass.123')
  11. admin_login(self.client, 'Bob', 'Pass.123')
  12. response = self.client.get(reverse('misago:admin:index'))
  13. self.assertEqual(response.status_code, 200)
  14. self.assertIn('Bob', response.content)
  15. class AdminLoginViewTests(TestCase):
  16. def test_login_returns_200_on_get(self):
  17. """unauthenticated request to admin index produces login form"""
  18. response = self.client.get(reverse('misago:admin:index'))
  19. self.assertEqual(response.status_code, 200)
  20. self.assertIn('Sign in', response.content)
  21. self.assertIn('Username or e-mail', response.content)
  22. self.assertIn('Password', response.content)
  23. def test_login_returns_200_on_invalid_post(self):
  24. """form handles invalid data gracefully"""
  25. response = self.client.post(
  26. reverse('misago:admin:index'),
  27. data={'username': 'Nope', 'password': 'Nope'})
  28. self.assertEqual(response.status_code, 200)
  29. self.assertIn('Your login or password is incorrect.', response.content)
  30. self.assertIn('Sign in', response.content)
  31. self.assertIn('Username or e-mail', response.content)
  32. self.assertIn('Password', response.content)
  33. def test_login_returns_200_on_valid_post(self):
  34. """form handles valid data correctly"""
  35. User = get_user_model()
  36. User.objects.create_superuser('Bob', 'bob@test.com', 'Pass.123')
  37. response = self.client.post(
  38. reverse('misago:admin:index'),
  39. data={'username': 'Bob', 'password': 'Pass.123'})
  40. self.assertEqual(response.status_code, 302)
  41. class FakeRequest(object):
  42. def __init__(self, path):
  43. self.path = path
  44. class AdminProtectedNamespaceTexts(TestCase):
  45. def test_valid_cases(self):
  46. """get_protected_namespace returns true for protected links"""
  47. links_prefix = reverse('misago:admin:index')
  48. TEST_CASES = (
  49. '',
  50. 'somewhere/',
  51. 'ejksajdlksajldjskajdlksajlkdas',
  52. )
  53. for case in TEST_CASES:
  54. request = FakeRequest(links_prefix + case)
  55. self.assertEqual(get_protected_namespace(request), 'misago:admin')
  56. def test_invalid_cases(self):
  57. """get_protected_namespace returns none for other links"""
  58. TEST_CASES = (
  59. '/',
  60. '/somewhere/',
  61. '/ejksajdlksajldjskajdlksajlkdas',
  62. )
  63. for case in TEST_CASES:
  64. request = FakeRequest(case)
  65. self.assertEqual(get_protected_namespace(request), None)