diff options
| author | heathervm <heathervmurray@gmail.com> | 2017-03-31 07:10:08 -0700 |
|---|---|---|
| committer | Tim Graham <timograham@gmail.com> | 2017-03-31 10:10:30 -0400 |
| commit | ff0c6b83e590e36555639563c4bd1d808f416455 (patch) | |
| tree | da0ec13758cd5a98d460cace87cdb89a2e239a7c /tests/model_forms | |
| parent | 8484cf4cd0a6d3553f6fc1d62fa6dc04f04624f0 (diff) | |
[1.11.x] Fixed #27993 -- Fixed model form default fallback for SelectMultiple.
Backport of 7d1e23775344cc3dead03bd4af45f4fdf134b819 from master
Diffstat (limited to 'tests/model_forms')
| -rw-r--r-- | tests/model_forms/tests.py | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/tests/model_forms/tests.py b/tests/model_forms/tests.py index c8d22db6e8..159d0634ea 100644 --- a/tests/model_forms/tests.py +++ b/tests/model_forms/tests.py @@ -618,6 +618,22 @@ class ModelFormBaseTest(TestCase): self.assertEqual(m1.mode, '') self.assertEqual(m1._meta.get_field('mode').get_default(), 'di') + def test_default_not_populated_on_selectmultiple(self): + class PubForm(forms.ModelForm): + mode = forms.CharField(required=False, widget=forms.SelectMultiple) + + class Meta: + model = PublicationDefaults + fields = ('mode',) + + # Empty data doesn't use the model default because an unselected + # SelectMultiple doesn't have a value in HTML form submission. + mf1 = PubForm({}) + self.assertEqual(mf1.errors, {}) + m1 = mf1.save(commit=False) + self.assertEqual(m1.mode, '') + self.assertEqual(m1._meta.get_field('mode').get_default(), 'di') + def test_prefixed_form_with_default_field(self): class PubForm(forms.ModelForm): prefix = 'form-prefix' |
