summaryrefslogtreecommitdiff
path: root/tests/admin_views
diff options
context:
space:
mode:
Diffstat (limited to 'tests/admin_views')
-rw-r--r--tests/admin_views/admin.py8
-rw-r--r--tests/admin_views/tests.py19
2 files changed, 27 insertions, 0 deletions
diff --git a/tests/admin_views/admin.py b/tests/admin_views/admin.py
index 04cc6c79e7..5dc2a5811b 100644
--- a/tests/admin_views/admin.py
+++ b/tests/admin_views/admin.py
@@ -459,6 +459,13 @@ class PrePopulatedPostAdmin(admin.ModelAdmin):
return self.prepopulated_fields
+class PrePopulatedPostReadOnlyAdmin(admin.ModelAdmin):
+ prepopulated_fields = {'slug': ('title',)}
+
+ def has_change_permission(self, *args, **kwargs):
+ return False
+
+
class PostAdmin(admin.ModelAdmin):
list_display = ['title', 'public']
readonly_fields = (
@@ -1085,6 +1092,7 @@ site2.register(Person, save_as_continue=False)
site7 = admin.AdminSite(name="admin7")
site7.register(Article, ArticleAdmin2)
site7.register(Section)
+site7.register(PrePopulatedPost, PrePopulatedPostReadOnlyAdmin)
# Used to test ModelAdmin.sortable_by and get_sortable_by().
diff --git a/tests/admin_views/tests.py b/tests/admin_views/tests.py
index fb10f485cd..115291f902 100644
--- a/tests/admin_views/tests.py
+++ b/tests/admin_views/tests.py
@@ -4211,6 +4211,25 @@ class PrePopulatedTest(TestCase):
response = self.client.get(reverse('admin:admin_views_prepopulatedpostlargeslug_add'))
self.assertContains(response, ""maxLength": 1000") # instead of 1,000
+ def test_view_only_add_form(self):
+ """
+ PrePopulatedPostReadOnlyAdmin.prepopulated_fields includes 'slug'
+ which is present in the add view, even if the
+ ModelAdmin.has_change_permission() returns False.
+ """
+ response = self.client.get(reverse('admin7:admin_views_prepopulatedpost_add'))
+ self.assertContains(response, 'data-prepopulated-fields=')
+ self.assertContains(response, '"id": "#id_slug"')
+
+ def test_view_only_change_form(self):
+ """
+ PrePopulatedPostReadOnlyAdmin.prepopulated_fields includes 'slug'. That
+ doesn't break a view-only change view.
+ """
+ response = self.client.get(reverse('admin7:admin_views_prepopulatedpost_change', args=(self.p1.pk,)))
+ self.assertContains(response, 'data-prepopulated-fields="[]"')
+ self.assertContains(response, '<div class="readonly">%s</div>' % self.p1.slug)
+
@override_settings(ROOT_URLCONF='admin_views.urls')
class SeleniumTests(AdminSeleniumTestCase):