Commit 18cdfcd7 by Tom Christie

Merge pull request #3731 from mjparker777/master

Issue 3726 DateTimeField not handling empty values
parents 61e7f7b0 d9c36084
...@@ -1061,6 +1061,9 @@ class DateTimeField(Field): ...@@ -1061,6 +1061,9 @@ class DateTimeField(Field):
self.fail('invalid', format=humanized_format) self.fail('invalid', format=humanized_format)
def to_representation(self, value): def to_representation(self, value):
if not value:
return None
output_format = getattr(self, 'format', api_settings.DATETIME_FORMAT) output_format = getattr(self, 'format', api_settings.DATETIME_FORMAT)
if output_format is None: if output_format is None:
...@@ -1118,11 +1121,11 @@ class DateField(Field): ...@@ -1118,11 +1121,11 @@ class DateField(Field):
self.fail('invalid', format=humanized_format) self.fail('invalid', format=humanized_format)
def to_representation(self, value): def to_representation(self, value):
output_format = getattr(self, 'format', api_settings.DATE_FORMAT)
if not value: if not value:
return None return None
output_format = getattr(self, 'format', api_settings.DATE_FORMAT)
if output_format is None: if output_format is None:
return value return value
...@@ -1183,6 +1186,9 @@ class TimeField(Field): ...@@ -1183,6 +1186,9 @@ class TimeField(Field):
self.fail('invalid', format=humanized_format) self.fail('invalid', format=humanized_format)
def to_representation(self, value): def to_representation(self, value):
if not value:
return None
output_format = getattr(self, 'format', api_settings.TIME_FORMAT) output_format = getattr(self, 'format', api_settings.TIME_FORMAT)
if output_format is None: if output_format is None:
......
...@@ -959,7 +959,9 @@ class TestDateTimeField(FieldValues): ...@@ -959,7 +959,9 @@ class TestDateTimeField(FieldValues):
} }
outputs = { outputs = {
datetime.datetime(2001, 1, 1, 13, 00): '2001-01-01T13:00:00', datetime.datetime(2001, 1, 1, 13, 00): '2001-01-01T13:00:00',
datetime.datetime(2001, 1, 1, 13, 00, tzinfo=timezone.UTC()): '2001-01-01T13:00:00Z' datetime.datetime(2001, 1, 1, 13, 00, tzinfo=timezone.UTC()): '2001-01-01T13:00:00Z',
None: None,
'': None,
} }
field = serializers.DateTimeField(default_timezone=timezone.UTC()) field = serializers.DateTimeField(default_timezone=timezone.UTC())
...@@ -1028,7 +1030,9 @@ class TestTimeField(FieldValues): ...@@ -1028,7 +1030,9 @@ class TestTimeField(FieldValues):
'99:99': ['Time has wrong format. Use one of these formats instead: hh:mm[:ss[.uuuuuu]].'], '99:99': ['Time has wrong format. Use one of these formats instead: hh:mm[:ss[.uuuuuu]].'],
} }
outputs = { outputs = {
datetime.time(13, 00): '13:00:00' datetime.time(13, 00): '13:00:00',
None: None,
'': None,
} }
field = serializers.TimeField() field = serializers.TimeField()
......
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