Fixed #27161 -- Fixed form validation when an ArrayField's base_field has choices.

This commit is contained in:
Romulo Furtado 2017-04-06 11:06:11 -03:00 committed by Tim Graham
parent de9294727c
commit 9dd2443942
2 changed files with 9 additions and 0 deletions

View File

@ -27,6 +27,10 @@ class SimpleArrayField(forms.CharField):
self.max_length = max_length self.max_length = max_length
self.validators.append(ArrayMaxLengthValidator(int(max_length))) self.validators.append(ArrayMaxLengthValidator(int(max_length)))
def clean(self, value):
value = super().clean(value)
return [self.base_field.clean(val) for val in value]
def prepare_value(self, value): def prepare_value(self, value):
if isinstance(value, list): if isinstance(value, list):
return self.delimiter.join(str(self.base_field.prepare_value(v)) for v in value) return self.delimiter.join(str(self.base_field.prepare_value(v)) for v in value)

View File

@ -686,6 +686,11 @@ class TestSimpleFormField(PostgreSQLTestCase):
self.assertIsInstance(form_field, SimpleArrayField) self.assertIsInstance(form_field, SimpleArrayField)
self.assertEqual(form_field.max_length, 4) self.assertEqual(form_field.max_length, 4)
def test_model_field_choices(self):
model_field = ArrayField(models.IntegerField(choices=((1, 'A'), (2, 'B'))))
form_field = model_field.formfield()
self.assertEqual(form_field.clean('1,2'), [1, 2])
def test_already_converted_value(self): def test_already_converted_value(self):
field = SimpleArrayField(forms.CharField()) field = SimpleArrayField(forms.CharField())
vals = ['a', 'b', 'c'] vals = ['a', 'b', 'c']