from django.contrib.auth import get_user_model from django.core.urlresolvers import reverse from django.test import TestCase from ..testutils import AdminTestCase from ..views import get_protected_namespace class FakeRequest(object): def __init__(self, path): self.path = path self.path_info = path class AdminProtectedNamespaceTests(TestCase): def test_valid_cases(self): """get_protected_namespace returns true for protected links""" links_prefix = reverse('misago:admin:index') TEST_CASES = ( '', 'somewhere/', 'ejksajdlksajldjskajdlksajlkdas', ) for case in TEST_CASES: request = FakeRequest(links_prefix + case) self.assertEqual(get_protected_namespace(request), 'misago:admin') def test_invalid_cases(self): """get_protected_namespace returns none for other links""" TEST_CASES = ( '/', '/somewhere/', '/ejksajdlksajldjskajdlksajlkdas', ) for case in TEST_CASES: request = FakeRequest(case) self.assertEqual(get_protected_namespace(request), None) class AdminLoginViewTests(TestCase): def test_login_returns_200_on_get(self): """unauthenticated request to admin index produces login form""" response = self.client.get(reverse('misago:admin:index')) self.assertEqual(response.status_code, 200) self.assertIn('Sign in', response.content) self.assertIn('Username or e-mail', response.content) self.assertIn('Password', response.content) def test_login_returns_200_on_invalid_post(self): """form handles invalid data gracefully""" response = self.client.post( reverse('misago:admin:index'), data={'username': 'Nope', 'password': 'Nope'}) self.assertEqual(response.status_code, 200) self.assertIn('Login or password is incorrect.', response.content) self.assertIn('Sign in', response.content) self.assertIn('Username or e-mail', response.content) self.assertIn('Password', response.content) def test_login_returns_200_on_valid_post(self): """form handles valid data correctly""" User = get_user_model() User.objects.create_superuser('Bob', 'bob@test.com', 'Pass.123') response = self.client.post( reverse('misago:admin:index'), data={'username': 'Bob', 'password': 'Pass.123'}) self.assertEqual(response.status_code, 302) class AdminLogoutTests(AdminTestCase): def test_admin_logout(self): """admin logout logged from admin only""" response = self.client.post(reverse('misago:admin:logout')) self.assertEqual(response.status_code, 302) response = self.client.get(reverse('misago:admin:index')) self.assertEqual(response.status_code, 200) self.assertIn("Your admin session has been closed.", response.content) response = self.client.get(reverse('misago:index')) self.assertEqual(response.status_code, 200) self.assertIn(self.user.username, response.content) def test_complete_logout(self): """complete logout logged from both admin and site""" response = self.client.post(reverse('misago:logout')) self.assertEqual(response.status_code, 302) response = self.client.get(reverse('misago:admin:index')) self.assertEqual(response.status_code, 200) self.assertIn("Sign in", response.content) response = self.client.get(reverse('misago:index')) self.assertEqual(response.status_code, 200) self.assertIn("Sign in", response.content) class AdminIndexViewTests(AdminTestCase): def test_view_returns_200(self): """admin index view returns 200""" response = self.client.get(reverse('misago:admin:index')) self.assertEqual(response.status_code, 200) self.assertIn(self.user.username, response.content)