diff options
| author | Tom Christie | 2013-02-22 14:15:57 -0800 |
|---|---|---|
| committer | Tom Christie | 2013-02-22 14:15:57 -0800 |
| commit | 26ba11101b3fe7aa3db881f10db746d1441f053b (patch) | |
| tree | 81fdb2986a50225ba7129b20378fb171d8ba7032 | |
| parent | bba918fb2a04ace16657f717e24cd220565837a6 (diff) | |
| parent | 5f531fc1ea0b6417b162c5cce7cd8193a1231019 (diff) | |
| download | django-rest-framework-26ba11101b3fe7aa3db881f10db746d1441f053b.tar.bz2 | |
Merge pull request #669 from yprez/datetimefield_fail
DateTimeField validation with non-str value
| -rw-r--r-- | rest_framework/fields.py | 8 | ||||
| -rw-r--r-- | rest_framework/tests/serializer.py | 15 |
2 files changed, 19 insertions, 4 deletions
diff --git a/rest_framework/fields.py b/rest_framework/fields.py index e1fd1b64..86c3a837 100644 --- a/rest_framework/fields.py +++ b/rest_framework/fields.py @@ -472,7 +472,7 @@ class DateField(WritableField): parsed = parse_date(value) if parsed is not None: return parsed - except ValueError: + except (ValueError, TypeError): msg = self.error_messages['invalid_date'] % value raise ValidationError(msg) @@ -520,7 +520,7 @@ class DateTimeField(WritableField): parsed = parse_datetime(value) if parsed is not None: return parsed - except ValueError: + except (ValueError, TypeError): msg = self.error_messages['invalid_datetime'] % value raise ValidationError(msg) @@ -528,7 +528,7 @@ class DateTimeField(WritableField): parsed = parse_date(value) if parsed is not None: return datetime.datetime(parsed.year, parsed.month, parsed.day) - except ValueError: + except (ValueError, TypeError): msg = self.error_messages['invalid_date'] % value raise ValidationError(msg) @@ -558,7 +558,7 @@ class TimeField(WritableField): parsed = parse_time(value) assert parsed is not None return parsed - except ValueError: + except (ValueError, TypeError): msg = self.error_messages['invalid'] % value raise ValidationError(msg) diff --git a/rest_framework/tests/serializer.py b/rest_framework/tests/serializer.py index da110138..e85323e0 100644 --- a/rest_framework/tests/serializer.py +++ b/rest_framework/tests/serializer.py @@ -338,6 +338,21 @@ class ValidationTests(TestCase): self.assertEquals(serializer.is_valid(), False) 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 CommentSerializerWithFieldValidator(CommentSerializer): |
