mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #12481: Updated admin validation code to not reject non-editable fields in readonly_fields, since these are handled fine by the display code itself. Thanks lashni and Alex.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12730 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -245,6 +245,12 @@ def validate_base(cls, model):
|
|||||||
if type(fields) != tuple:
|
if type(fields) != tuple:
|
||||||
fields = (fields,)
|
fields = (fields,)
|
||||||
for field in fields:
|
for field in fields:
|
||||||
|
if field in cls.readonly_fields:
|
||||||
|
# Stuff can be put in fields that isn't actually a
|
||||||
|
# model field if it's in readonly_fields,
|
||||||
|
# readonly_fields will handle the validation of such
|
||||||
|
# things.
|
||||||
|
continue
|
||||||
check_formfield(cls, model, opts, "fieldsets[%d][1]['fields']" % idx, field)
|
check_formfield(cls, model, opts, "fieldsets[%d][1]['fields']" % idx, field)
|
||||||
try:
|
try:
|
||||||
f = opts.get_field(field)
|
f = opts.get_field(field)
|
||||||
|
@@ -12,6 +12,7 @@ class Album(models.Model):
|
|||||||
class Song(models.Model):
|
class Song(models.Model):
|
||||||
title = models.CharField(max_length=150)
|
title = models.CharField(max_length=150)
|
||||||
album = models.ForeignKey(Album)
|
album = models.ForeignKey(Album)
|
||||||
|
original_release = models.DateField(editable=False)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ('title',)
|
ordering = ('title',)
|
||||||
|
18
tests/regressiontests/admin_validation/tests.py
Normal file
18
tests/regressiontests/admin_validation/tests.py
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
from django.contrib import admin
|
||||||
|
from django.contrib.admin.validation import validate
|
||||||
|
from django.test import TestCase
|
||||||
|
|
||||||
|
from models import Song
|
||||||
|
|
||||||
|
|
||||||
|
class ValidationTestCase(TestCase):
|
||||||
|
def test_readonly_and_editable(self):
|
||||||
|
class SongAdmin(admin.ModelAdmin):
|
||||||
|
readonly_fields = ["original_release"]
|
||||||
|
fieldsets = [
|
||||||
|
(None, {
|
||||||
|
"fields": ["title", "original_release"],
|
||||||
|
}),
|
||||||
|
]
|
||||||
|
|
||||||
|
validate(SongAdmin, Song)
|
Reference in New Issue
Block a user