Commit 26ba1110 by Tom Christie

Merge pull request #669 from yprez/datetimefield_fail

DateTimeField validation with non-str value
parents bba918fb 5f531fc1
...@@ -472,7 +472,7 @@ class DateField(WritableField): ...@@ -472,7 +472,7 @@ class DateField(WritableField):
parsed = parse_date(value) parsed = parse_date(value)
if parsed is not None: if parsed is not None:
return parsed return parsed
except ValueError: except (ValueError, TypeError):
msg = self.error_messages['invalid_date'] % value msg = self.error_messages['invalid_date'] % value
raise ValidationError(msg) raise ValidationError(msg)
...@@ -520,7 +520,7 @@ class DateTimeField(WritableField): ...@@ -520,7 +520,7 @@ class DateTimeField(WritableField):
parsed = parse_datetime(value) parsed = parse_datetime(value)
if parsed is not None: if parsed is not None:
return parsed return parsed
except ValueError: except (ValueError, TypeError):
msg = self.error_messages['invalid_datetime'] % value msg = self.error_messages['invalid_datetime'] % value
raise ValidationError(msg) raise ValidationError(msg)
...@@ -528,7 +528,7 @@ class DateTimeField(WritableField): ...@@ -528,7 +528,7 @@ class DateTimeField(WritableField):
parsed = parse_date(value) parsed = parse_date(value)
if parsed is not None: if parsed is not None:
return datetime.datetime(parsed.year, parsed.month, parsed.day) return datetime.datetime(parsed.year, parsed.month, parsed.day)
except ValueError: except (ValueError, TypeError):
msg = self.error_messages['invalid_date'] % value msg = self.error_messages['invalid_date'] % value
raise ValidationError(msg) raise ValidationError(msg)
...@@ -558,7 +558,7 @@ class TimeField(WritableField): ...@@ -558,7 +558,7 @@ class TimeField(WritableField):
parsed = parse_time(value) parsed = parse_time(value)
assert parsed is not None assert parsed is not None
return parsed return parsed
except ValueError: except (ValueError, TypeError):
msg = self.error_messages['invalid'] % value msg = self.error_messages['invalid'] % value
raise ValidationError(msg) raise ValidationError(msg)
......
...@@ -338,6 +338,21 @@ class ValidationTests(TestCase): ...@@ -338,6 +338,21 @@ class ValidationTests(TestCase):
self.assertEquals(serializer.is_valid(), False) self.assertEquals(serializer.is_valid(), False)
self.assertEquals(serializer.errors, {'info': ['Ensure this value has at most 12 characters (it has 13).']}) self.assertEquals(serializer.errors, {'info': ['Ensure this value has at most 12 characters (it has 13).']})
def test_datetime_validation_failure(self):
"""
Test DateTimeField validation errors on non-str values.
Regression test for #669.
https://github.com/tomchristie/django-rest-framework/issues/669
"""
data = self.data
data['created'] = 0
serializer = CommentSerializer(data=data)
self.assertEquals(serializer.is_valid(), False)
self.assertIn('created', serializer.errors)
class CustomValidationTests(TestCase): class CustomValidationTests(TestCase):
class CommentSerializerWithFieldValidator(CommentSerializer): class CommentSerializerWithFieldValidator(CommentSerializer):
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment