diff options
| author | Mjumbe Wawatu Ukweli | 2013-03-11 17:32:32 -0400 | 
|---|---|---|
| committer | Mjumbe Wawatu Ukweli | 2013-03-11 17:32:32 -0400 | 
| commit | bd3fe75e1a41e45b0c9ff1e39707ee059ad0e06a (patch) | |
| tree | 541449e1adf87a063e0e788c23434df1a111a25e /rest_framework | |
| parent | 354fbc64ba5046ce49d58c8243a4f81caddf3823 (diff) | |
| download | django-rest-framework-bd3fe75e1a41e45b0c9ff1e39707ee059ad0e06a.tar.bz2 | |
Further group model inheritance tests
Diffstat (limited to 'rest_framework')
| -rw-r--r-- | rest_framework/tests/multitable_inheritance.py | 51 | ||||
| -rw-r--r-- | rest_framework/tests/serializer.py | 48 | 
2 files changed, 51 insertions, 48 deletions
diff --git a/rest_framework/tests/multitable_inheritance.py b/rest_framework/tests/multitable_inheritance.py index 1cca7823..00c15327 100644 --- a/rest_framework/tests/multitable_inheritance.py +++ b/rest_framework/tests/multitable_inheritance.py @@ -1,8 +1,11 @@  from __future__ import unicode_literals  from django.db import models +from django.test import TestCase +from rest_framework import serializers  from rest_framework.tests.models import RESTFrameworkModel +# Models  class ParentModel(RESTFrameworkModel):      name1 = models.CharField(max_length=100) @@ -14,3 +17,51 @@ class ChildModel(ParentModel):  class AssociatedModel(RESTFrameworkModel):      ref = models.OneToOneField(ParentModel, primary_key=True)      name = models.CharField(max_length=100) + + +# Serializers +class DerivedModelSerializer(serializers.ModelSerializer): +    class Meta: +        model = ChildModel + + +class AssociatedModelSerializer(serializers.ModelSerializer): +    class Meta: +        model = AssociatedModel + + +# Tests +class IneritedModelSerializationTests(TestCase): + +    def test_multitable_inherited_model_fields_as_expected(self): +        """ +        Assert that the parent pointer field is not included in the fields +        serialized fields +        """ +        child = ChildModel(name1='parent name', name2='child name') +        serializer = DerivedModelSerializer(child) +        self.assertEqual(set(serializer.data.keys()), +                         set(['name1', 'name2', 'id'])) + +    def test_onetoone_primary_key_model_fields_as_expected(self): +        """ +        Assert that a model with a onetoone field that is the primary key is +        not treated like a derived model +        """ +        parent = ParentModel(name1='parent name') +        associate = AssociatedModel(name='hello', ref=parent) +        serializer = AssociatedModelSerializer(associate) +        self.assertEqual(set(serializer.data.keys()), +                         set(['name', 'ref'])) + +    def test_data_is_valid_without_parent_ptr(self): +        """ +        Assert that the pointer to the parent table is not a required field +        for input data +        """ +        data = { +            'name1': 'parent name', +            'name2': 'child name', +        } +        serializer = DerivedModelSerializer(data=data) +        self.assertEqual(serializer.is_valid(), True) diff --git a/rest_framework/tests/serializer.py b/rest_framework/tests/serializer.py index c4a8a899..beb372c2 100644 --- a/rest_framework/tests/serializer.py +++ b/rest_framework/tests/serializer.py @@ -5,8 +5,6 @@ from rest_framework import serializers  from rest_framework.tests.models import (HasPositiveIntegerAsChoice, Album, ActionItem, Anchor, BasicModel,      BlankFieldModel, BlogPost, Book, CallableDefaultValueModel, DefaultValueModel,      ManyToManyModel, Person, ReadOnlyManyToManyModel, Photo) -from rest_framework.tests.multitable_inheritance import (ParentModel, -    ChildModel, AssociatedModel)  import datetime  import pickle @@ -98,16 +96,6 @@ class BrokenModelSerializer(serializers.ModelSerializer):          fields = ['some_field'] -class DerivedModelSerializer(serializers.ModelSerializer): -    class Meta: -        model = ChildModel - - -class AssociatedModelSerializer(serializers.ModelSerializer): -    class Meta: -        model = AssociatedModel - -  class BasicTests(TestCase):      def setUp(self):          self.comment = Comment( @@ -1122,39 +1110,3 @@ class DeserializeListTestCase(TestCase):          self.assertFalse(serializer.is_valid())          expected = [{}, {'email': ['This field is required.']}, {}]          self.assertEqual(serializer.errors, expected) - - -class IneritedModelSerializationTests(TestCase): - -    def test_multitable_inherited_model_fields_as_expected(self): -        """ -        Assert that the parent pointer field is not included in the fields -        serialized fields -        """ -        child = ChildModel(name1='parent name', name2='child name') -        serializer = DerivedModelSerializer(child) -        self.assertEqual(set(serializer.data.keys()), -                         set(['name1', 'name2', 'id'])) - -    def test_onetoone_primary_key_model_fields_as_expected(self): -        """ -        Assert that a model with a onetoone field that is the primary key is -        not treated like a derived model -        """ -        parent = ParentModel(name1='parent name') -        associate = AssociatedModel(name='hello', ref=parent) -        serializer = AssociatedModelSerializer(associate) -        self.assertEqual(set(serializer.data.keys()), -                         set(['name', 'ref'])) - -    def test_data_is_valid_without_parent_ptr(self): -        """ -        Assert that the pointer to the parent table is not a required field -        for input data -        """ -        data = { -            'name1': 'parent name', -            'name2': 'child name', -        } -        serializer = DerivedModelSerializer(data=data) -        self.assertEqual(serializer.is_valid(), True)  | 
