Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
D
django-rest-framework
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
django-rest-framework
Commits
26ba1110
Commit
26ba1110
authored
Feb 22, 2013
by
Tom Christie
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #669 from yprez/datetimefield_fail
DateTimeField validation with non-str value
parents
bba918fb
5f531fc1
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
19 additions
and
4 deletions
+19
-4
rest_framework/fields.py
+4
-4
rest_framework/tests/serializer.py
+15
-0
No files found.
rest_framework/fields.py
View file @
26ba1110
...
@@ -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
)
...
...
rest_framework/tests/serializer.py
View file @
26ba1110
...
@@ -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
):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment