mirror of
				https://github.com/django/django.git
				synced 2025-10-24 14:16:09 +00:00 
			
		
		
		
	Fixed #28758 -- Fixed RangeMax/MinValueValidators crash with unbound ranges.
This commit is contained in:
		| @@ -69,11 +69,11 @@ class KeysValidator: | ||||
|  | ||||
| class RangeMaxValueValidator(MaxValueValidator): | ||||
|     def compare(self, a, b): | ||||
|         return a.upper > b | ||||
|         return a.upper is None or a.upper > b | ||||
|     message = _('Ensure that this range is completely less than or equal to %(limit_value)s.') | ||||
|  | ||||
|  | ||||
| class RangeMinValueValidator(MinValueValidator): | ||||
|     def compare(self, a, b): | ||||
|         return a.lower < b | ||||
|         return a.lower is None or a.lower < b | ||||
|     message = _('Ensure that this range is completely greater than or equal to %(limit_value)s.') | ||||
|   | ||||
| @@ -408,18 +408,24 @@ class TestValidators(PostgreSQLTestCase): | ||||
|     def test_max(self): | ||||
|         validator = RangeMaxValueValidator(5) | ||||
|         validator(NumericRange(0, 5)) | ||||
|         msg = 'Ensure that this range is completely less than or equal to 5.' | ||||
|         with self.assertRaises(exceptions.ValidationError) as cm: | ||||
|             validator(NumericRange(0, 10)) | ||||
|         self.assertEqual(cm.exception.messages[0], 'Ensure that this range is completely less than or equal to 5.') | ||||
|         self.assertEqual(cm.exception.messages[0], msg) | ||||
|         self.assertEqual(cm.exception.code, 'max_value') | ||||
|         with self.assertRaisesMessage(exceptions.ValidationError, msg): | ||||
|             validator(NumericRange(0, None))  # an unbound range | ||||
|  | ||||
|     def test_min(self): | ||||
|         validator = RangeMinValueValidator(5) | ||||
|         validator(NumericRange(10, 15)) | ||||
|         msg = 'Ensure that this range is completely greater than or equal to 5.' | ||||
|         with self.assertRaises(exceptions.ValidationError) as cm: | ||||
|             validator(NumericRange(0, 10)) | ||||
|         self.assertEqual(cm.exception.messages[0], 'Ensure that this range is completely greater than or equal to 5.') | ||||
|         self.assertEqual(cm.exception.messages[0], msg) | ||||
|         self.assertEqual(cm.exception.code, 'min_value') | ||||
|         with self.assertRaisesMessage(exceptions.ValidationError, msg): | ||||
|             validator(NumericRange(None, 10))  # an unbound range | ||||
|  | ||||
|  | ||||
| class TestFormField(PostgreSQLTestCase): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user