test_admin_views.py 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. import pytest
  2. from django.urls import reverse
  3. from ....admin.test import AdminTestCase
  4. from ....cache.test import assert_invalidates_cache
  5. from ....test import assert_contains
  6. from ... import ACL_CACHE
  7. from ...models import Role
  8. from ..test import mock_role_form_data
  9. admin_link = reverse("misago:admin:permissions:index")
  10. def create_form_data(data_dict):
  11. return mock_role_form_data(Role(), data_dict)
  12. def test_link_is_registered_in_admin_nav(admin_client):
  13. response = admin_client.get(reverse("misago:admin:index"))
  14. assert_contains(response, admin_link)
  15. def test_list_renders(admin_client):
  16. response = admin_client.get(admin_link)
  17. assert response.status_code == 200
  18. def test_new_role_form_renders(admin_client):
  19. response = admin_client.get(reverse("misago:admin:permissions:new"))
  20. assert response.status_code == 200
  21. def test_new_role_can_be_created(admin_client):
  22. response = admin_client.post(
  23. reverse("misago:admin:permissions:new"),
  24. data=create_form_data({"name": "Test Role"}),
  25. )
  26. Role.objects.get(name="Test Role")
  27. @pytest.fixture
  28. def role(db):
  29. return Role.objects.create(name="Test Role")
  30. def test_edit_role_form_renders(admin_client, role):
  31. response = admin_client.get(
  32. reverse("misago:admin:permissions:edit", kwargs={"pk": role.pk})
  33. )
  34. assert response.status_code == 200
  35. def test_role_can_be_edited(admin_client, role):
  36. response = admin_client.post(
  37. reverse("misago:admin:permissions:edit", kwargs={"pk": role.pk}),
  38. data=create_form_data({"name": "Edited Role"}),
  39. )
  40. role.refresh_from_db()
  41. assert role.name == "Edited Role"
  42. def test_editing_role_invalidates_acl_cache(admin_client, role):
  43. with assert_invalidates_cache(ACL_CACHE):
  44. admin_client.post(
  45. reverse("misago:admin:permissions:edit", kwargs={"pk": role.pk}),
  46. data=create_form_data({"name": "Role"}),
  47. )
  48. def test_role_can_be_deleted(admin_client, role):
  49. admin_client.post(
  50. reverse("misago:admin:permissions:delete", kwargs={"pk": role.pk})
  51. )
  52. with pytest.raises(Role.DoesNotExist):
  53. role.refresh_from_db()
  54. def test_special_role_cant_be_deleted(admin_client, role):
  55. role.special_role = "Test"
  56. role.save()
  57. admin_client.post(
  58. reverse("misago:admin:permissions:delete", kwargs={"pk": role.pk})
  59. )
  60. role.refresh_from_db()
  61. def test_deleting_role_invalidates_acl_cache(admin_client, role):
  62. with assert_invalidates_cache(ACL_CACHE):
  63. admin_client.post(
  64. reverse("misago:admin:permissions:delete", kwargs={"pk": role.pk})
  65. )
  66. def test_users_with_role_view_redirects_to_admin_users_list(admin_client, role):
  67. response = admin_client.get(
  68. reverse("misago:admin:permissions:users", kwargs={"pk": role.pk})
  69. )
  70. assert response.status_code == 302
  71. assert reverse("misago:admin:users:index") in response["location"]