aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTom Christie2013-06-12 12:39:57 -0700
committerTom Christie2013-06-12 12:39:57 -0700
commit614d8fec3c022170e0b18758777ab5febebfc201 (patch)
tree2673cd4ac9999ead0eeed86c5ba54ca97717ec3e
parentc4ab77b9e97be4780f7f2fe946fd31ac6d156ce1 (diff)
parent82c515c19cb4050804d8255f4904e45b9b1b884b (diff)
downloaddjango-rest-framework-614d8fec3c022170e0b18758777ab5febebfc201.tar.bz2
Merge pull request #929 from mhsparks/positive-integer-field
Added test for custom fields with min_value and max_value validators
-rw-r--r--rest_framework/tests/test_fields.py30
1 files changed, 30 insertions, 0 deletions
diff --git a/rest_framework/tests/test_fields.py b/rest_framework/tests/test_fields.py
index 69a0468e..6836ec86 100644
--- a/rest_framework/tests/test_fields.py
+++ b/rest_framework/tests/test_fields.py
@@ -866,3 +866,33 @@ class FieldCallableDefault(TestCase):
into = {}
field.field_from_native({}, {}, 'field', into)
self.assertEqual(into, {'field': 'foo bar'})
+
+
+class CustomIntegerField(TestCase):
+ """
+ Test that custom fields apply min_value and max_value constraints
+ """
+ def test_custom_fields_can_be_validated_for_value(self):
+
+ class MoneyField(models.PositiveIntegerField):
+ pass
+
+ class EntryModel(models.Model):
+ bank = MoneyField(validators=[validators.MaxValueValidator(100)])
+
+ class EntrySerializer(serializers.ModelSerializer):
+ class Meta:
+ model = EntryModel
+
+ entry = EntryModel(bank=1)
+
+ serializer = EntrySerializer(entry, data={"bank": 11})
+ self.assertTrue(serializer.is_valid())
+
+ serializer = EntrySerializer(entry, data={"bank": -1})
+ self.assertFalse(serializer.is_valid())
+
+ serializer = EntrySerializer(entry, data={"bank": 101})
+ self.assertFalse(serializer.is_valid())
+
+