Commit 2b47c6b7 by Tom Christie

Merge pull request #1834 from piotrjakimiak/master

Fix returning None when allow_none is True in CharField
parents 4207d445 cb3cc00e
...@@ -475,8 +475,12 @@ class CharField(WritableField): ...@@ -475,8 +475,12 @@ class CharField(WritableField):
if isinstance(value, six.string_types): if isinstance(value, six.string_types):
return value return value
if value is None and not self.allow_none: if value is None:
return '' if not self.allow_none:
return ''
else:
# Return None explicitly because smart_text(None) == 'None'. See #1834 for details
return None
return smart_text(value) return smart_text(value)
......
...@@ -1004,6 +1004,18 @@ class BooleanField(TestCase): ...@@ -1004,6 +1004,18 @@ class BooleanField(TestCase):
self.assertFalse(BooleanRequiredSerializer(data={}).is_valid()) self.assertFalse(BooleanRequiredSerializer(data={}).is_valid())
class ModelCharField(TestCase):
"""
Tests for CharField
"""
def test_none_serializing(self):
class CharFieldSerializer(serializers.Serializer):
char = serializers.CharField(allow_none=True, required=False)
serializer = CharFieldSerializer(data={'char': None})
self.assertTrue(serializer.is_valid())
self.assertIsNone(serializer.object['char'])
class SerializerMethodFieldTest(TestCase): class SerializerMethodFieldTest(TestCase):
""" """
Tests for the SerializerMethodField field_to_native() behavior Tests for the SerializerMethodField field_to_native() behavior
......
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