|
16 | 16 |
|
17 | 17 | class SnippetAdminTestCase(CMSTestCase):
|
18 | 18 | def setUp(self):
|
| 19 | + self.superuser = self.get_superuser() |
19 | 20 | self.snippet = Snippet.objects.create(
|
20 | 21 | name="Test Snippet",
|
21 | 22 | slug="test-snippet",
|
22 | 23 | html="<h1>This is a test</h1>",
|
23 | 24 | snippet_grouper=SnippetGrouper.objects.create(),
|
24 | 25 | )
|
| 26 | + self.snippet_version = Version.objects.create(content=self.snippet, created_by=self.superuser) |
25 | 27 | self.snippet_admin = snippet_admin.SnippetAdmin(Snippet, admin)
|
26 | 28 | self.snippet_admin_request = RequestFactory().get("/admin/djangocms_snippet")
|
| 29 | + self.edit_url = reverse("admin:djangocms_snippet_snippet_change", args=(self.snippet.id,),) |
| 30 | + self.delete_url = reverse("admin:djangocms_snippet_snippet_delete", args=(self.snippet.id,),) |
27 | 31 |
|
28 | 32 | @override_settings(DJANGOCMS_SNIPPET_VERSIONING_ENABLED=False)
|
29 | 33 | def test_admin_list_display_without_versioning(self):
|
@@ -67,6 +71,68 @@ def test_admin_uses_form(self):
|
67 | 71 | """
|
68 | 72 | self.assertEqual(self.snippet_admin.form, SnippetForm)
|
69 | 73 |
|
| 74 | + @override_settings(DJANGOCMS_SNIPPET_VERSIONING_ENABLED=True) |
| 75 | + def test_admin_delete_button_disabled_versioning_enabled(self): |
| 76 | + """ |
| 77 | + If versioning is enabled, the delete button should not be rendered on the change form |
| 78 | + """ |
| 79 | + admin.site.unregister(Snippet) |
| 80 | + reload(cms_config) |
| 81 | + reload(snippet_admin) |
| 82 | + |
| 83 | + with self.login_user_context(self.superuser): |
| 84 | + response = self.client.get(self.edit_url) |
| 85 | + |
| 86 | + self.assertNotContains( |
| 87 | + response, '<a href="/en/admin/djangocms_snippet/snippet/1/delete/" class="deletelink">Delete</a>' |
| 88 | + ) |
| 89 | + |
| 90 | + @override_settings(DJANGOCMS_SNIPPET_VERSIONING_ENABLED=False) |
| 91 | + def test_admin_delete_button_available_versioning_disabled(self): |
| 92 | + """ |
| 93 | + If versioning is disabled, the delete button should be rendered on the change form |
| 94 | + """ |
| 95 | + admin.site.unregister(Snippet) |
| 96 | + reload(cms_config) |
| 97 | + reload(snippet_admin) |
| 98 | + |
| 99 | + with self.login_user_context(self.superuser): |
| 100 | + response = self.client.get(self.edit_url) |
| 101 | + |
| 102 | + self.assertContains( |
| 103 | + response, '<a href="/en/admin/djangocms_snippet/snippet/1/delete/" class="deletelink">Delete</a>' |
| 104 | + ) |
| 105 | + |
| 106 | + @override_settings(DJANGOCMS_SNIPPET_VERSIONING_ENABLED=True) |
| 107 | + def test_admin_delete_endpoint_inaccessible_versioning_enabled(self): |
| 108 | + """ |
| 109 | + If versioning is enabled, the delete endpoint should not be accessible. |
| 110 | + """ |
| 111 | + admin.site.unregister(Snippet) |
| 112 | + reload(cms_config) |
| 113 | + reload(snippet_admin) |
| 114 | + |
| 115 | + with self.login_user_context(self.superuser): |
| 116 | + response = self.client.post(self.delete_url) |
| 117 | + |
| 118 | + # The delete endpoint should return a 403 forbidden if we try to access it with versioning enabled |
| 119 | + self.assertEqual(response.status_code, 403) |
| 120 | + |
| 121 | + @override_settings(DJANGOCMS_SNIPPET_VERSIONING_ENABLED=False) |
| 122 | + def test_admin_delete_endpoint_accessible_versioning_disabled(self): |
| 123 | + """ |
| 124 | + If versioning is disabled, the delete endpoint should be accessible. |
| 125 | + """ |
| 126 | + admin.site.unregister(Snippet) |
| 127 | + reload(cms_config) |
| 128 | + reload(snippet_admin) |
| 129 | + |
| 130 | + with self.login_user_context(self.superuser): |
| 131 | + response = self.client.post(self.delete_url) |
| 132 | + |
| 133 | + # The delete endpoint should return a 200 success if we try to access it with versioning disabled |
| 134 | + self.assertEqual(response.status_code, 200) |
| 135 | + |
70 | 136 |
|
71 | 137 | class SnippetAdminFormTestCase(CMSTestCase):
|
72 | 138 | def setUp(self):
|
|
0 commit comments