123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- from django.urls import reverse
- from misago.acl import ACL_CACHE
- from misago.acl.models import Role
- from misago.acl.testutils import fake_post_data
- from misago.cache.test import assert_invalidates_cache
- from misago.admin.testutils import AdminTestCase
- def fake_data(data_dict):
- return fake_post_data(Role(), data_dict)
- class RoleAdminViewsTests(AdminTestCase):
- def test_link_registered(self):
- """admin nav contains user roles link"""
- response = self.client.get(reverse('misago:admin:permissions:users:index'))
- self.assertContains(response, reverse('misago:admin:permissions:users:index'))
- def test_list_view(self):
- """roles list view returns 200"""
- response = self.client.get(reverse('misago:admin:permissions:users: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:users:new'))
- self.assertEqual(response.status_code, 200)
- response = self.client.post(
- reverse('misago:admin:permissions:users:new'), data=fake_data({
- 'name': 'Test Role',
- })
- )
- self.assertEqual(response.status_code, 302)
- test_role = Role.objects.get(name='Test Role')
- response = self.client.get(reverse('misago:admin:permissions:users:index'))
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, test_role.name)
- def test_edit_view(self):
- """edit role view has no showstoppers"""
- self.client.post(
- reverse('misago:admin:permissions:users:new'), data=fake_data({
- 'name': 'Test Role',
- })
- )
- test_role = Role.objects.get(name='Test Role')
- response = self.client.get(
- reverse('misago:admin:permissions:users:edit', kwargs={
- 'pk': test_role.pk,
- })
- )
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, 'Test Role')
- response = self.client.post(
- reverse('misago:admin:permissions:users:edit', kwargs={
- 'pk': test_role.pk,
- }),
- data=fake_data({
- 'name': 'Top Lel',
- })
- )
- self.assertEqual(response.status_code, 302)
- test_role = Role.objects.get(name='Top Lel')
- response = self.client.get(reverse('misago:admin:permissions:users:index'))
- self.assertEqual(response.status_code, 200)
- self.assertContains(response, test_role.name)
- def test_editing_role_invalidates_acl_cache(self):
- self.client.post(
- reverse('misago:admin:permissions:users:new'), data=fake_data({
- 'name': 'Test Role',
- })
- )
- test_role = Role.objects.get(name='Test Role')
- with assert_invalidates_cache(ACL_CACHE):
- self.client.post(
- reverse('misago:admin:permissions:users:edit', kwargs={
- 'pk': test_role.pk,
- }),
- data=fake_data({
- 'name': 'Top Lel',
- })
- )
- def test_users_view(self):
- """users with this role view has no showstoppers"""
- response = self.client.post(
- reverse('misago:admin:permissions:users:new'), data=fake_data({
- 'name': 'Test Role',
- })
- )
- test_role = Role.objects.get(name='Test Role')
- response = self.client.get(
- reverse('misago:admin:permissions:users:users', kwargs={
- 'pk': test_role.pk,
- })
- )
- self.assertEqual(response.status_code, 302)
- def test_delete_view(self):
- """delete role view has no showstoppers"""
- self.client.post(
- reverse('misago:admin:permissions:users:new'), data=fake_data({
- 'name': 'Test Role',
- })
- )
- test_role = Role.objects.get(name='Test Role')
- response = self.client.post(
- reverse('misago:admin:permissions:users:delete', kwargs={
- 'pk': test_role.pk,
- })
- )
- self.assertEqual(response.status_code, 302)
- # Get the page twice so no alert is renderered on second request
- self.client.get(reverse('misago:admin:permissions:users:index'))
- response = self.client.get(reverse('misago:admin:permissions:users:index'))
- self.assertNotContains(response, test_role.name)
- def test_deleting_role_invalidates_acl_cache(self):
- self.client.post(
- reverse('misago:admin:permissions:users:new'), data=fake_data({
- 'name': 'Test Role',
- })
- )
- test_role = Role.objects.get(name='Test Role')
- with assert_invalidates_cache(ACL_CACHE):
- self.client.post(
- reverse('misago:admin:permissions:users:delete', kwargs={
- 'pk': test_role.pk,
- })
- )
|