mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #27369 -- Prevented widgets from being shared between form field instances.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						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 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user