diff options
| author | Tom Christie | 2015-01-21 14:18:13 +0000 | 
|---|---|---|
| committer | Tom Christie | 2015-01-21 14:18:13 +0000 | 
| commit | e59b3d1718de549d0e165d03aeea1488ddfe20ee (patch) | |
| tree | 121045a26ab759b7634e6f990c6b87c203d4809b /tests | |
| parent | 9d24809a4dee67ee414ee79820331f0794c42a13 (diff) | |
| download | django-rest-framework-e59b3d1718de549d0e165d03aeea1488ddfe20ee.tar.bz2 | |
Make ReturnDict cachable. Closes #2360.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/test_serializer.py | 17 | 
1 files changed, 17 insertions, 0 deletions
| diff --git a/tests/test_serializer.py b/tests/test_serializer.py index 68bbbe98..b7a0484b 100644 --- a/tests/test_serializer.py +++ b/tests/test_serializer.py @@ -3,6 +3,7 @@ from __future__ import unicode_literals  from .utils import MockObject  from rest_framework import serializers  from rest_framework.compat import unicode_repr +import pickle  import pytest @@ -278,3 +279,19 @@ class TestNotRequiredOutput:          serializer = ExampleSerializer(instance)          with pytest.raises(AttributeError):              serializer.data + + +class TestCacheSerializerData: +    def test_cache_serializer_data(self): +        """ +        Caching serializer data with pickle will drop the serializer info, +        but does preserve the data itself. +        """ +        class ExampleSerializer(serializers.Serializer): +            field1 = serializers.CharField() +            field2 = serializers.CharField() + +        serializer = ExampleSerializer({'field1': 'a', 'field2': 'b'}) +        pickled = pickle.dumps(serializer.data) +        data = pickle.loads(pickled) +        assert data == {'field1': 'a', 'field2': 'b'} | 
