mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[1.8.x] Fixed #25597 -- Fixed crash with SplitArrayField and IntegerField on invalid value.
Backport of 1f07da3e29 from master
			
			
This commit is contained in:
		| @@ -166,7 +166,7 @@ class SplitArrayField(forms.Field): | |||||||
|                 errors.append(None) |                 errors.append(None) | ||||||
|             except ValidationError as error: |             except ValidationError as error: | ||||||
|                 errors.append(ValidationError( |                 errors.append(ValidationError( | ||||||
|                     string_concat(self.error_messages['item_invalid'], error.message), |                     string_concat(self.error_messages['item_invalid'], ' '.join(error.messages)), | ||||||
|                     code='item_invalid', |                     code='item_invalid', | ||||||
|                     params={'nth': i}, |                     params={'nth': i}, | ||||||
|                 )) |                 )) | ||||||
|   | |||||||
| @@ -38,3 +38,6 @@ Bugfixes | |||||||
|  |  | ||||||
| * Fixed a typo in the name of the `strictly_above` PostGIS lookup | * Fixed a typo in the name of the `strictly_above` PostGIS lookup | ||||||
|   (:ticket:`25592`). |   (:ticket:`25592`). | ||||||
|  |  | ||||||
|  | * Fixed crash with ``contrib.postgres.forms.SplitArrayField`` and | ||||||
|  |   ``IntegerField`` on invalid value (:ticket:`25597`). | ||||||
|   | |||||||
| @@ -484,6 +484,11 @@ class TestSplitFormField(TestCase): | |||||||
|         self.assertFalse(form.is_valid()) |         self.assertFalse(form.is_valid()) | ||||||
|         self.assertEqual(form.errors, {'array': ['Item 2 in the array did not validate: This field is required.']}) |         self.assertEqual(form.errors, {'array': ['Item 2 in the array did not validate: This field is required.']}) | ||||||
|  |  | ||||||
|  |     def test_invalid_integer(self): | ||||||
|  |         msg = 'Item 1 in the array did not validate: Ensure this value is less than or equal to 100.' | ||||||
|  |         with self.assertRaisesMessage(exceptions.ValidationError, msg): | ||||||
|  |             SplitArrayField(forms.IntegerField(max_value=100), size=2).clean([0, 101]) | ||||||
|  |  | ||||||
|     def test_rendering(self): |     def test_rendering(self): | ||||||
|         class SplitForm(forms.Form): |         class SplitForm(forms.Form): | ||||||
|             array = SplitArrayField(forms.CharField(), size=3) |             array = SplitArrayField(forms.CharField(), size=3) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user