diff options
| author | Tom Christie | 2012-09-07 15:14:23 +0100 | 
|---|---|---|
| committer | Tom Christie | 2012-09-07 15:14:23 +0100 | 
| commit | 72bdd0fcec7faa32d7f24e0698736f9433b56f3f (patch) | |
| tree | 0209f259eaaf2b8c32709576bcf2fa1260fd6e4d /djangorestframework | |
| parent | a01d6153547980f12034b6e872019e1ac94b5b78 (diff) | |
| download | django-rest-framework-72bdd0fcec7faa32d7f24e0698736f9433b56f3f.tar.bz2 | |
Add basic serializer tests
Diffstat (limited to 'djangorestframework')
| -rw-r--r-- | djangorestframework/tests/renderers.py | 2 | ||||
| -rw-r--r-- | djangorestframework/tests/serializer.py | 278 | 
2 files changed, 118 insertions, 162 deletions
diff --git a/djangorestframework/tests/renderers.py b/djangorestframework/tests/renderers.py index a57cf35d..0a1cd9c7 100644 --- a/djangorestframework/tests/renderers.py +++ b/djangorestframework/tests/renderers.py @@ -54,7 +54,7 @@ class MockView(APIView):      renderers = (RendererA, RendererB)      def get(self, request, **kwargs): -        response = Response(DUMMYSTATUS, DUMMYCONTENT) +        response = Response(DUMMYCONTENT, status=DUMMYSTATUS)          return self.render(response) diff --git a/djangorestframework/tests/serializer.py b/djangorestframework/tests/serializer.py index 7e9f4149..93ae81ee 100644 --- a/djangorestframework/tests/serializer.py +++ b/djangorestframework/tests/serializer.py @@ -1,161 +1,117 @@ -# """Tests for the resource module""" -# from django.db import models -# from django.test import TestCase -# from django.utils.translation import ugettext_lazy -# from djangorestframework.serializer import Serializer - -# import datetime -# import decimal - - -# class TestObjectToData(TestCase): -#     """ -#     Tests for the Serializer class. -#     """ - -#     def setUp(self): -#         self.serializer = Serializer() -#         self.serialize = self.serializer.serialize - -#     def test_decimal(self): -#         """Decimals need to be converted to a string representation.""" -#         self.assertEquals(self.serialize(decimal.Decimal('1.5')), decimal.Decimal('1.5')) - -#     def test_function(self): -#         """Functions with no arguments should be called.""" -#         def foo(): -#             return 1 -#         self.assertEquals(self.serialize(foo), 1) - -#     def test_method(self): -#         """Methods with only a ``self`` argument should be called.""" -#         class Foo(object): -#             def foo(self): -#                 return 1 -#         self.assertEquals(self.serialize(Foo().foo), 1) - -#     def test_datetime(self): -#         """datetime objects are left as-is.""" -#         now = datetime.datetime.now() -#         self.assertEquals(self.serialize(now), now) - -#     def test_dict_method_name_collision(self): -#         """dict with key that collides with dict method name""" -#         self.assertEquals(self.serialize({'items': 'foo'}), {'items': u'foo'}) -#         self.assertEquals(self.serialize({'keys': 'foo'}), {'keys': u'foo'}) -#         self.assertEquals(self.serialize({'values': 'foo'}), {'values': u'foo'}) - -#     def test_ugettext_lazy(self): -#         self.assertEquals(self.serialize(ugettext_lazy('foobar')), u'foobar') - - -# class TestFieldNesting(TestCase): -#     """ -#     Test nesting the fields in the Serializer class -#     """ -#     def setUp(self): -#         self.serializer = Serializer() -#         self.serialize = self.serializer.serialize - -#         class M1(models.Model): -#             field1 = models.CharField(max_length=256) -#             field2 = models.CharField(max_length=256) - -#         class M2(models.Model): -#             field = models.OneToOneField(M1) - -#         class M3(models.Model): -#             field = models.ForeignKey(M1) - -#         self.m1 = M1(field1='foo', field2='bar') -#         self.m2 = M2(field=self.m1) -#         self.m3 = M3(field=self.m1) - - -#     def test_tuple_nesting(self): -#         """ -#         Test tuple nesting on `fields` attr -#         """ -#         class SerializerM2(Serializer): -#             fields = (('field', ('field1',)),) - -#         class SerializerM3(Serializer): -#             fields = (('field', ('field2',)),) - -#         self.assertEqual(SerializerM2().serialize(self.m2), {'field': {'field1': u'foo'}}) -#         self.assertEqual(SerializerM3().serialize(self.m3), {'field': {'field2': u'bar'}}) - - -#     def test_serializer_class_nesting(self): -#         """ -#         Test related model serialization -#         """ -#         class NestedM2(Serializer): -#             fields = ('field1', ) - -#         class NestedM3(Serializer): -#             fields = ('field2', ) - -#         class SerializerM2(Serializer): -#             fields = [('field', NestedM2)] - -#         class SerializerM3(Serializer): -#             fields = [('field', NestedM3)] - -#         self.assertEqual(SerializerM2().serialize(self.m2), {'field': {'field1': u'foo'}}) -#         self.assertEqual(SerializerM3().serialize(self.m3), {'field': {'field2': u'bar'}}) - -#     def test_serializer_no_fields(self): -#         """ -#         Test related serializer works when the fields attr isn't present. Fix for -#         #178. -#         """ -#         class NestedM2(Serializer): -#             fields = ('field1', ) - -#         class NestedM3(Serializer): -#             fields = ('field2', ) - -#         class SerializerM2(Serializer): -#             include = [('field', NestedM2)] -#             exclude = ('id', ) - -#         class SerializerM3(Serializer): -#             fields = [('field', NestedM3)] - -#         self.assertEqual(SerializerM2().serialize(self.m2), {'field': {'field1': u'foo'}}) -#         self.assertEqual(SerializerM3().serialize(self.m3), {'field': {'field2': u'bar'}}) - -#     def test_serializer_classname_nesting(self): -#         """ -#         Test related model serialization -#         """ -#         class SerializerM2(Serializer): -#             fields = [('field', 'NestedM2')] - -#         class SerializerM3(Serializer): -#             fields = [('field', 'NestedM3')] - -#         class NestedM2(Serializer): -#             fields = ('field1', ) - -#         class NestedM3(Serializer): -#             fields = ('field2', ) - -#         self.assertEqual(SerializerM2().serialize(self.m2), {'field': {'field1': u'foo'}}) -#         self.assertEqual(SerializerM3().serialize(self.m3), {'field': {'field2': u'bar'}}) - -#     def test_serializer_overridden_hook_method(self): -#         """ -#         Test serializing a model instance which overrides a class method on the -#         serializer.  Checks for correct behaviour in odd edge case. -#         """ -#         class SerializerM2(Serializer): -#             fields = ('overridden', ) - -#             def overridden(self): -#                 return False - -#         self.m2.overridden = True -#         self.assertEqual(SerializerM2().serialize_model(self.m2), -#                          {'overridden': True}) +import datetime +from django.test import TestCase +from djangorestframework import serializers + + +class Comment(object): +    def __init__(self, email, content, created): +        self.email = email +        self.content = content +        self.created = created or datetime.datetime.now() + +    def __eq__(self, other): +        return all([getattr(self, attr) == getattr(other, attr) +                    for attr in ('email', 'content', 'created')]) + + +class CommentSerializer(serializers.Serializer): +    email = serializers.EmailField() +    content = serializers.CharField(max_length=1000) +    created = serializers.DateTimeField() + +    def restore_object(self, data, instance=None): +        if instance is None: +            return Comment(**data) +        for key, val in data.items(): +            setattr(instance, key, val) +        return instance + + +class BasicTests(TestCase): +    def setUp(self): +        self.comment = Comment( +            'tom@example.com', +            'Happy new year!', +            datetime.datetime(2012, 1, 1) +        ) +        self.data = { +            'email': 'tom@example.com', +            'content': 'Happy new year!', +            'created': datetime.datetime(2012, 1, 1) +        } + +    def test_empty(self): +        serializer = CommentSerializer() +        expected = { +            'email': '', +            'content': '', +            'created': None +        } +        self.assertEquals(serializer.data, expected) + +    def test_serialization(self): +        serializer = CommentSerializer(instance=self.comment) +        expected = self.data +        self.assertEquals(serializer.data, expected) + +    def test_deserialization_for_create(self): +        serializer = CommentSerializer(self.data) +        expected = self.comment +        self.assertEquals(serializer.is_valid(), True) +        self.assertEquals(serializer.object, expected) +        self.assertFalse(serializer.object is expected) + +    def test_deserialization_for_update(self): +        serializer = CommentSerializer(self.data, instance=self.comment) +        expected = self.comment +        self.assertEquals(serializer.is_valid(), True) +        self.assertEquals(serializer.object, expected) +        self.assertTrue(serializer.object is expected) + + +class ValidationTests(TestCase): +    def setUp(self): +        self.comment = Comment( +            'tom@example.com', +            'Happy new year!', +            datetime.datetime(2012, 1, 1) +        ) +        self.data = { +            'email': 'tom@example.com', +            'content': 'x' * 1001, +            'created': datetime.datetime(2012, 1, 1) +        } + +    def test_deserialization_for_create(self): +        serializer = CommentSerializer(self.data) +        self.assertEquals(serializer.is_valid(), False) +        self.assertEquals(serializer.errors, {'content': [u'Ensure this value has at most 1000 characters (it has 1001).']}) + +    def test_deserialization_for_update(self): +        serializer = CommentSerializer(self.data, instance=self.comment) +        self.assertEquals(serializer.is_valid(), False) +        self.assertEquals(serializer.errors, {'content': [u'Ensure this value has at most 1000 characters (it has 1001).']}) + + +class MetadataTests(TestCase): +    # def setUp(self): +    #     self.comment = Comment( +    #         'tomchristie', +    #         'Happy new year!', +    #         datetime.datetime(2012, 1, 1) +    #     ) +    #     self.data = { +    #         'email': 'tomchristie', +    #         'content': 'Happy new year!', +    #         'created': datetime.datetime(2012, 1, 1) +    #     } + +    def test_empty(self): +        serializer = CommentSerializer() +        expected = { +            'email': serializers.CharField, +            'content': serializers.CharField, +            'created': serializers.DateTimeField +        } +        for field_name, field in expected.items(): +            self.assertTrue(isinstance(serializer.data.fields[field_name], field))  | 
