Skip to content
Closed
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
test case for #3598
  • Loading branch information
akolpakov committed Dec 7, 2015
commit 03a9137abd2ed69c4a8fc1784cfce2d7ce444f23
33 changes: 33 additions & 0 deletions tests/test_model_serializer.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
from django.db import models
from django.test import TestCase
from django.utils import six
from django.http import QueryDict

from rest_framework import serializers
from rest_framework.compat import DurationField as ModelDurationField
Expand Down Expand Up @@ -899,3 +900,35 @@ class Meta:
serializer = TestSerializer()

assert len(serializer.fields['decimal_field'].validators) == 2


class Issue3598TestCase(TestCase):
def test_queryset_all(self):
class TestRelationSerializer(serializers.ModelSerializer):
class Meta:
model = RelationalModel
fields = ('many_to_many', )

class TestSerializer(serializers.ModelSerializer):
reverse_foreign_key = TestRelationSerializer(required=False)

class Meta:
model = ForeignKeyTargetModel

new_many_to_many = [
ManyToManyTargetModel.objects.create(
name='new many_to_many (%d)' % idx
) for idx in range(3)
]

data = QueryDict('name=test&' + '&'.join(['reverse_foreign_key.many_to_many=%s' % item.pk for item in new_many_to_many]))

serializer = TestSerializer(data=data)
assert serializer.is_valid()

expected_data = {
'name': 'test',
'reverse_foreign_key': {'many_to_many': [item.pk for item in new_many_to_many]}
}

self.assertEqual(serializer.data, expected_data)