diff options
| author | Tom Christie | 2015-02-27 09:13:01 +0000 | 
|---|---|---|
| committer | Tom Christie | 2015-02-27 09:13:01 +0000 | 
| commit | cda74b59971f85da873b0e15da8b4afb4411a026 (patch) | |
| tree | 8981ad8adf5b2f16e6771be3790952bd51ab61fc /tests | |
| parent | c66f23391ac669f2a9a27431e66588e9092300f2 (diff) | |
| parent | e6b06c34c1ee526b65c92b9071c47be2ddc668c4 (diff) | |
| download | django-rest-framework-cda74b59971f85da873b0e15da8b4afb4411a026.tar.bz2 | |
Merge pull request #2608 from ezheidtmann/dont-swallow-errors-in-callable-sources
Dont swallow errors in callable sources
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/test_fields.py | 25 | 
1 files changed, 25 insertions, 0 deletions
| diff --git a/tests/test_fields.py b/tests/test_fields.py index ab3418bd..7f5f8102 100644 --- a/tests/test_fields.py +++ b/tests/test_fields.py @@ -93,6 +93,31 @@ class TestSource:              "same as the field name. Remove the `source` keyword argument."          ) +    def test_callable_source(self): +        class ExampleSerializer(serializers.Serializer): +            example_field = serializers.CharField(source='example_callable') + +        class ExampleInstance(object): +            def example_callable(self): +                return 'example callable value' + +        serializer = ExampleSerializer(ExampleInstance()) +        assert serializer.data['example_field'] == 'example callable value' + +    def test_callable_source_raises(self): +        class ExampleSerializer(serializers.Serializer): +            example_field = serializers.CharField(source='example_callable', read_only=True) + +        class ExampleInstance(object): +            def example_callable(self): +                raise AttributeError('method call failed') + +        with pytest.raises(ValueError) as exc_info: +            serializer = ExampleSerializer(ExampleInstance()) +            serializer.data.items() + +        assert 'method call failed' in str(exc_info.value) +  class TestReadOnly:      def setup(self): | 
