mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #30907 -- Fixed SplitArrayField.has_changed() with removal of empty trailing values.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							bcfbb71c63
						
					
				
				
					commit
					711a7d4d50
				
			| @@ -221,3 +221,14 @@ class SplitArrayField(forms.Field): | ||||
|         if errors: | ||||
|             raise ValidationError(list(chain.from_iterable(errors))) | ||||
|         return cleaned_data | ||||
|  | ||||
|     def has_changed(self, initial, data): | ||||
|         try: | ||||
|             data = self.to_python(data) | ||||
|         except ValidationError: | ||||
|             pass | ||||
|         else: | ||||
|             data, _ = self._remove_trailing_nulls(data) | ||||
|             if initial in self.empty_values and data in self.empty_values: | ||||
|                 return False | ||||
|         return super().has_changed(initial, data) | ||||
|   | ||||
| @@ -975,6 +975,26 @@ class TestSplitFormField(PostgreSQLSimpleTestCase): | ||||
|                 form = Form(data, instance=obj) | ||||
|                 self.assertIs(form.has_changed(), expected_result) | ||||
|  | ||||
|     def test_splitarrayfield_remove_trailing_nulls_has_changed(self): | ||||
|         class Form(forms.ModelForm): | ||||
|             field = SplitArrayField(forms.IntegerField(), required=False, size=2, remove_trailing_nulls=True) | ||||
|  | ||||
|             class Meta: | ||||
|                 model = IntegerArrayModel | ||||
|                 fields = ('field',) | ||||
|  | ||||
|         tests = [ | ||||
|             ({}, {'field_0': '', 'field_1': ''}, False), | ||||
|             ({'field': None}, {'field_0': '', 'field_1': ''}, False), | ||||
|             ({'field': []}, {'field_0': '', 'field_1': ''}, False), | ||||
|             ({'field': [1]}, {'field_0': '1', 'field_1': ''}, False), | ||||
|         ] | ||||
|         for initial, data, expected_result in tests: | ||||
|             with self.subTest(initial=initial, data=data): | ||||
|                 obj = IntegerArrayModel(**initial) | ||||
|                 form = Form(data, instance=obj) | ||||
|                 self.assertIs(form.has_changed(), expected_result) | ||||
|  | ||||
|  | ||||
| class TestSplitFormWidget(PostgreSQLWidgetTestCase): | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user