mirror of
https://github.com/django/django.git
synced 2025-10-23 21:59:11 +00:00
Fixed #13776 -- Fixed ModelForm.is_valid() exception with non-nullable FK and blank=True.
Thanks peterbe for the report.
This commit is contained in:
committed by
Tim Graham
parent
7e2c87809c
commit
45e049937d
@@ -23,7 +23,7 @@ from .models import (Article, ArticleStatus, Author, Author1, BetterWriter, BigI
|
||||
ImprovedArticle, ImprovedArticleWithParentLink, Inventory, Person, Post, Price,
|
||||
Product, Publication, TextFile, Triple, Writer, WriterProfile,
|
||||
Colour, ColourfulItem, DateTimePost, CustomErrorMessage,
|
||||
test_images, StumpJoke, Character)
|
||||
test_images, StumpJoke, Character, Student)
|
||||
|
||||
if test_images:
|
||||
from .models import ImageFile, OptionalImageFile
|
||||
@@ -199,6 +199,34 @@ class ModelFormBaseTest(TestCase):
|
||||
instance = construct_instance(form, Person(), fields=())
|
||||
self.assertEqual(instance.name, '')
|
||||
|
||||
def test_blank_with_null_foreign_key_field(self):
|
||||
"""
|
||||
#13776 -- ModelForm's with models having a FK set to null=False and
|
||||
required=False should be valid.
|
||||
"""
|
||||
class FormForTestingIsValid(forms.ModelForm):
|
||||
class Meta:
|
||||
model = Student
|
||||
fields = '__all__'
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
super(FormForTestingIsValid, self).__init__(*args, **kwargs)
|
||||
self.fields['character'].required = False
|
||||
|
||||
char = Character.objects.create(username='user',
|
||||
last_action=datetime.datetime.today())
|
||||
data = {'study': 'Engineering'}
|
||||
data2 = {'study': 'Engineering', 'character': char.pk}
|
||||
|
||||
# form is valid because required=False for field 'character'
|
||||
f1 = FormForTestingIsValid(data)
|
||||
self.assertTrue(f1.is_valid())
|
||||
|
||||
f2 = FormForTestingIsValid(data2)
|
||||
self.assertTrue(f2.is_valid())
|
||||
obj = f2.save()
|
||||
self.assertEqual(obj.character, char)
|
||||
|
||||
def test_missing_fields_attribute(self):
|
||||
message = (
|
||||
"Creating a ModelForm without either the 'fields' attribute "
|
||||
|
Reference in New Issue
Block a user