mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #8027: correctly validate fields/fieldsets in ModelAdmin
validation when using custom ModelForm
s.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@8662 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
43
tests/regressiontests/admin_validation/models.py
Normal file
43
tests/regressiontests/admin_validation/models.py
Normal file
@@ -0,0 +1,43 @@
|
||||
"""
|
||||
Tests of ModelAdmin validation logic.
|
||||
"""
|
||||
|
||||
from django.db import models
|
||||
|
||||
class Song(models.Model):
|
||||
title = models.CharField(max_length=150)
|
||||
|
||||
class Meta:
|
||||
ordering = ('title',)
|
||||
|
||||
def __unicode__(self):
|
||||
return self.title
|
||||
|
||||
__test__ = {'API_TESTS':"""
|
||||
|
||||
>>> from django import forms
|
||||
>>> from django.contrib import admin
|
||||
>>> from django.contrib.admin.validation import validate
|
||||
|
||||
#
|
||||
# Regression test for #8027: custom ModelForms with fields/fieldsets
|
||||
#
|
||||
|
||||
>>> class SongForm(forms.ModelForm):
|
||||
... pass
|
||||
|
||||
>>> class ValidFields(admin.ModelAdmin):
|
||||
... form = SongForm
|
||||
... fields = ['title']
|
||||
|
||||
>>> class InvalidFields(admin.ModelAdmin):
|
||||
... form = SongForm
|
||||
... fields = ['spam']
|
||||
|
||||
>>> validate(ValidFields, Song)
|
||||
>>> validate(InvalidFields, Song)
|
||||
Traceback (most recent call last):
|
||||
...
|
||||
ImproperlyConfigured: 'InvalidFields.fields' refers to field 'spam' that is missing from the form.
|
||||
|
||||
"""}
|
Reference in New Issue
Block a user