diff options
| author | Tom Christie | 2014-12-18 10:55:28 +0000 | 
|---|---|---|
| committer | Tom Christie | 2014-12-18 10:55:28 +0000 | 
| commit | 22ffeafc3e67295d93b5f5d6dcb98917237d29eb (patch) | |
| tree | 29d246a361c8c4f224450cc0b4771ef8ef35b579 /tests | |
| parent | e8b46413a769d04ffac2c35bb10a9556d242022c (diff) | |
| parent | 1087ccbb258ca79ee42509abc4bb17b6c277f9ce (diff) | |
| download | django-rest-framework-22ffeafc3e67295d93b5f5d6dcb98917237d29eb.tar.bz2 | |
Merge pull request #2311 from tomchristie/allow-empty-text-or-boolean-html-input-if-not-required
Fixes for behavior with empty HTML fields.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/test_fields.py | 46 | 
1 files changed, 34 insertions, 12 deletions
| diff --git a/tests/test_fields.py b/tests/test_fields.py index 7f7af5cc..04c721d3 100644 --- a/tests/test_fields.py +++ b/tests/test_fields.py @@ -215,25 +215,47 @@ class TestBooleanHTMLInput:          assert serializer.validated_data == {'archived': False} +class MockHTMLDict(dict): +    """ +    This class mocks up a dictionary like object, that behaves +    as if it was returned for multipart or urlencoded data. +    """ +    getlist = None + +  class TestCharHTMLInput: -    def setup(self): +    def test_empty_html_checkbox(self):          class TestSerializer(serializers.Serializer):              message = serializers.CharField(default='happy') -        self.Serializer = TestSerializer -    def test_empty_html_checkbox(self): -        """ -        HTML checkboxes do not send any value, but should be treated -        as `False` by BooleanField. -        """ -        # This class mocks up a dictionary like object, that behaves -        # as if it was returned for multipart or urlencoded data. -        class MockHTMLDict(dict): -            getlist = None -        serializer = self.Serializer(data=MockHTMLDict()) +        serializer = TestSerializer(data=MockHTMLDict())          assert serializer.is_valid()          assert serializer.validated_data == {'message': 'happy'} +    def test_empty_html_checkbox_allow_null(self): +        class TestSerializer(serializers.Serializer): +            message = serializers.CharField(allow_null=True) + +        serializer = TestSerializer(data=MockHTMLDict()) +        assert serializer.is_valid() +        assert serializer.validated_data == {'message': None} + +    def test_empty_html_checkbox_allow_null_allow_blank(self): +        class TestSerializer(serializers.Serializer): +            message = serializers.CharField(allow_null=True, allow_blank=True) + +        serializer = TestSerializer(data=MockHTMLDict({})) +        assert serializer.is_valid() +        assert serializer.validated_data == {'message': ''} + +    def test_empty_html_required_false(self): +        class TestSerializer(serializers.Serializer): +            message = serializers.CharField(required=False) + +        serializer = TestSerializer(data=MockHTMLDict()) +        assert serializer.is_valid() +        assert serializer.validated_data == {} +  class TestCreateOnlyDefault:      def setup(self): | 
