Fixed #27369 -- Prevented widgets from being shared between form field instances.
This commit is contained in:
parent
37809b891e
commit
09da1e79de
|
@ -94,6 +94,8 @@ class Field(object):
|
||||||
widget = widget or self.widget
|
widget = widget or self.widget
|
||||||
if isinstance(widget, type):
|
if isinstance(widget, type):
|
||||||
widget = widget()
|
widget = widget()
|
||||||
|
else:
|
||||||
|
widget = copy.deepcopy(widget)
|
||||||
|
|
||||||
# Trigger the localization machinery if needed.
|
# Trigger the localization machinery if needed.
|
||||||
self.localize = localize
|
self.localize = localize
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from django.forms import Field
|
from django.forms import ChoiceField, Field, Form, Select
|
||||||
from django.test import SimpleTestCase
|
from django.test import SimpleTestCase
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,3 +20,17 @@ class BasicFieldsTests(SimpleTestCase):
|
||||||
|
|
||||||
f = ComplexField()
|
f = ComplexField()
|
||||||
self.assertTrue(f.class_a_var)
|
self.assertTrue(f.class_a_var)
|
||||||
|
|
||||||
|
def test_field_deepcopies_widget_instance(self):
|
||||||
|
class CustomChoiceField(ChoiceField):
|
||||||
|
widget = Select(attrs={'class': 'my-custom-class'})
|
||||||
|
|
||||||
|
class TestForm(Form):
|
||||||
|
field1 = CustomChoiceField(choices=[])
|
||||||
|
field2 = CustomChoiceField(choices=[])
|
||||||
|
|
||||||
|
f = TestForm()
|
||||||
|
f.fields['field1'].choices = [('1', '1')]
|
||||||
|
f.fields['field2'].choices = [('2', '2')]
|
||||||
|
self.assertEqual(f.fields['field1'].widget.choices, [('1', '1')])
|
||||||
|
self.assertEqual(f.fields['field2'].widget.choices, [('2', '2')])
|
||||||
|
|
|
@ -2867,7 +2867,7 @@ class FormFieldCallbackTests(SimpleTestCase):
|
||||||
fields = "__all__"
|
fields = "__all__"
|
||||||
|
|
||||||
Form = modelform_factory(Person, form=BaseForm)
|
Form = modelform_factory(Person, form=BaseForm)
|
||||||
self.assertIs(Form.base_fields['name'].widget, widget)
|
self.assertIsInstance(Form.base_fields['name'].widget, forms.Textarea)
|
||||||
|
|
||||||
def test_factory_with_widget_argument(self):
|
def test_factory_with_widget_argument(self):
|
||||||
""" Regression for #15315: modelform_factory should accept widgets
|
""" Regression for #15315: modelform_factory should accept widgets
|
||||||
|
|
Loading…
Reference in New Issue