Fixed #28882 -- Fixed cleaning of disabled MultiValueFields.

Thanks avalanchy for the initial patch.
This commit is contained in:
Tim Graham 2018-01-05 15:49:54 -05:00
parent 3333d935d2
commit ec2ce4517a
2 changed files with 19 additions and 0 deletions

View File

@ -970,6 +970,8 @@ class MultiValueField(Field):
for f in fields: for f in fields:
f.error_messages.setdefault('incomplete', f.error_messages.setdefault('incomplete',
self.error_messages['incomplete']) self.error_messages['incomplete'])
if self.disabled:
f.disabled = True
if self.require_all_fields: if self.require_all_fields:
# Set 'required' to False on the individual fields, because the # Set 'required' to False on the individual fields, because the
# required validation will be handled by MultiValueField, not # required validation will be handled by MultiValueField, not
@ -996,6 +998,8 @@ class MultiValueField(Field):
""" """
clean_data = [] clean_data = []
errors = [] errors = []
if self.disabled and not isinstance(value, list):
value = self.widget.decompress(value)
if not value or isinstance(value, (list, tuple)): if not value or isinstance(value, (list, tuple)):
if not value or not [v for v in value if v not in self.empty_values]: if not value or not [v for v in value if v not in self.empty_values]:
if self.required: if self.required:

View File

@ -62,6 +62,21 @@ class MultiValueFieldTest(SimpleTestCase):
'some text,JP,2007-04-25 06:24:00', 'some text,JP,2007-04-25 06:24:00',
) )
def test_clean_disabled_multivalue(self):
class ComplexFieldForm(Form):
f = ComplexField(disabled=True, widget=ComplexMultiWidget)
inputs = (
'some text,JP,2007-04-25 06:24:00',
['some text', ['J', 'P'], ['2007-04-25', '6:24:00']],
)
for data in inputs:
with self.subTest(data=data):
form = ComplexFieldForm({}, initial={'f': data})
form.full_clean()
self.assertEqual(form.errors, {})
self.assertEqual(form.cleaned_data, {'f': inputs[0]})
def test_bad_choice(self): def test_bad_choice(self):
msg = "'Select a valid choice. X is not one of the available choices.'" msg = "'Select a valid choice. X is not one of the available choices.'"
with self.assertRaisesMessage(ValidationError, msg): with self.assertRaisesMessage(ValidationError, msg):