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