123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- from django.urls import reverse
- from .. import ACL_CACHE
- from ...admin.test import AdminTestCase
- from ...cache.test import assert_invalidates_cache
- from ..models import Role
- from ..test import mock_role_form_data
- def create_data(data_dict):
- return mock_role_form_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:index"))
- self.assertContains(response, reverse("misago:admin:permissions:index"))
- def test_list_view(self):
- """roles list view returns 200"""
- response = self.client.get(reverse("misago:admin:permissions: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:new"))
- self.assertEqual(response.status_code, 200)
- response = self.client.post(
- reverse("misago:admin:permissions:new"),
- data=create_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: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:new"),
- data=create_data({"name": "Test Role"}),
- )
- test_role = Role.objects.get(name="Test Role")
- response = self.client.get(
- reverse("misago:admin:permissions: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:edit", kwargs={"pk": test_role.pk}),
- data=create_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: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:new"),
- data=create_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:edit", kwargs={"pk": test_role.pk}),
- data=create_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:new"),
- data=create_data({"name": "Test Role"}),
- )
- test_role = Role.objects.get(name="Test Role")
- response = self.client.get(
- reverse("misago:admin:permissions: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:new"),
- data=create_data({"name": "Test Role"}),
- )
- test_role = Role.objects.get(name="Test Role")
- response = self.client.post(
- reverse("misago:admin:permissions: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:index"))
- response = self.client.get(reverse("misago:admin:permissions:index"))
- self.assertNotContains(response, test_role.name)
- def test_deleting_role_invalidates_acl_cache(self):
- self.client.post(
- reverse("misago:admin:permissions:new"),
- data=create_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:delete", kwargs={"pk": test_role.pk})
- )
|