1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- from django.core.urlresolvers import reverse
- from misago.admin.testutils import AdminTestCase
- from misago.acl.models import ForumRole
- def fake_data(data_dict):
- data_dict.update({
- 'can_see_forum': 0,
- 'can_browse_forum': 0,
- })
- return data_dict
- class ForumRoleAdminViewsTests(AdminTestCase):
- def test_link_registered(self):
- """admin nav contains forum roles link"""
- response = self.client.get(
- reverse('misago:admin:permissions:forums:index'))
- self.assertIn(reverse('misago:admin:permissions:forums:index'),
- response.content)
- def test_list_view(self):
- """roles list view returns 200"""
- response = self.client.get(
- reverse('misago:admin:permissions:forums:index'))
- self.assertEqual(response.status_code, 200)
- def test_new_view(self):
- """new role view has no showstoppers"""
- response = self.client.get(
- reverse('misago:admin:permissions:forums:new'))
- self.assertEqual(response.status_code, 200)
- response = self.client.post(
- reverse('misago:admin:permissions:forums:new'),
- data=fake_data({'name': 'Test ForumRole'}))
- self.assertEqual(response.status_code, 302)
- test_role = ForumRole.objects.get(name='Test ForumRole')
- response = self.client.get(
- reverse('misago:admin:permissions:forums:index'))
- self.assertEqual(response.status_code, 200)
- self.assertIn(test_role.name, response.content)
- def test_edit_view(self):
- """edit role view has no showstoppers"""
- self.client.post(
- reverse('misago:admin:permissions:forums:new'),
- data=fake_data({'name': 'Test ForumRole'}))
- test_role = ForumRole.objects.get(name='Test ForumRole')
- response = self.client.get(
- reverse('misago:admin:permissions:forums:edit',
- kwargs={'role_id': test_role.pk}))
- self.assertEqual(response.status_code, 200)
- self.assertIn('Test ForumRole', response.content)
- response = self.client.post(
- reverse('misago:admin:permissions:forums:edit',
- kwargs={'role_id': test_role.pk}),
- data=fake_data({'name': 'Top Lel'}))
- self.assertEqual(response.status_code, 302)
- test_role = ForumRole.objects.get(name='Top Lel')
- response = self.client.get(
- reverse('misago:admin:permissions:forums:index'))
- self.assertEqual(response.status_code, 200)
- self.assertIn(test_role.name, response.content)
- def test_delete_view(self):
- """delete role view has no showstoppers"""
- self.client.post(
- reverse('misago:admin:permissions:forums:new'),
- data=fake_data({'name': 'Test ForumRole'}))
- test_role = ForumRole.objects.get(name='Test ForumRole')
- response = self.client.post(
- reverse('misago:admin:permissions:forums:delete',
- kwargs={'role_id': test_role.pk}))
- self.assertEqual(response.status_code, 302)
- self.client.get(reverse('misago:admin:permissions:forums:index'))
- response = self.client.get(
- reverse('misago:admin:permissions:forums:index'))
- self.assertEqual(response.status_code, 200)
- self.assertTrue(test_role.name not in response.content)
|