diff options
| author | Tom Christie | 2013-03-13 12:48:27 +0000 | 
|---|---|---|
| committer | Tom Christie | 2013-03-13 12:48:27 +0000 | 
| commit | 76bf8db83aada25b76be9389b538ec3f3b99c6ac (patch) | |
| tree | 3f85911664daeebf38275a6e0417490c78ffb145 /rest_framework | |
| parent | 73ab7dc3f18c43d7bfb0c6f7581784d398cb36cf (diff) | |
| parent | 0cf94cbd8b88de5da65f940351da2c2701ed877d (diff) | |
| download | django-rest-framework-76bf8db83aada25b76be9389b538ec3f3b99c6ac.tar.bz2 | |
Merge branch 'master' of https://github.com/tomchristie/django-rest-framework
Diffstat (limited to 'rest_framework')
| -rw-r--r-- | rest_framework/serializers.py | 7 | ||||
| -rw-r--r-- | rest_framework/tests/multitable_inheritance.py | 67 | 
2 files changed, 72 insertions, 2 deletions
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py index 2ae7c215..cd2bb8f1 100644 --- a/rest_framework/serializers.py +++ b/rest_framework/serializers.py @@ -456,8 +456,11 @@ class ModelSerializer(Serializer):                  "Serializer class '%s' is missing 'model' Meta option" % self.__class__.__name__          opts = get_concrete_model(cls)._meta          pk_field = opts.pk -        # while pk_field.rel: -        #     pk_field = pk_field.rel.to._meta.pk + +        # If model is a child via multitable inheritance, use parent's pk +        while pk_field.rel and pk_field.rel.parent_link: +            pk_field = pk_field.rel.to._meta.pk +          fields = [pk_field]          fields += [field for field in opts.fields if field.serialize]          fields += [field for field in opts.many_to_many if field.serialize] diff --git a/rest_framework/tests/multitable_inheritance.py b/rest_framework/tests/multitable_inheritance.py new file mode 100644 index 00000000..00c15327 --- /dev/null +++ b/rest_framework/tests/multitable_inheritance.py @@ -0,0 +1,67 @@ +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) + + +class ChildModel(ParentModel): +    name2 = models.CharField(max_length=100) + + +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)  | 
