diff options
| author | Andrew Hankinson | 2012-12-30 14:03:08 -0400 | 
|---|---|---|
| committer | Andrew Hankinson | 2012-12-30 14:03:08 -0400 | 
| commit | c6f212238c238561749574a54aec3b1b1fd8df61 (patch) | |
| tree | 6c235aa1f61cdbcd834bccaa2c31c4c1bb32de0e /rest_framework/tests/generics.py | |
| parent | df1880185c87733a82a41392898e67fe02c769aa (diff) | |
| parent | 33580c82b3487bdf00cbbaef409a4dd41e6750d5 (diff) | |
| download | django-rest-framework-c6f212238c238561749574a54aec3b1b1fd8df61.tar.bz2 | |
Merge branch 'master' of git://github.com/tomchristie/django-rest-framework into patch-support
Diffstat (limited to 'rest_framework/tests/generics.py')
| -rw-r--r-- | rest_framework/tests/generics.py | 36 | 
1 files changed, 35 insertions, 1 deletions
| diff --git a/rest_framework/tests/generics.py b/rest_framework/tests/generics.py index 33ac4b32..843017eb 100644 --- a/rest_framework/tests/generics.py +++ b/rest_framework/tests/generics.py @@ -1,3 +1,4 @@ +from django.db import models  from django.test import TestCase  from django.utils import simplejson as json  from rest_framework import generics, serializers, status @@ -174,7 +175,7 @@ class TestInstanceView(TestCase):          content = {'text': 'foobar'}          request = factory.put('/1', json.dumps(content),                                content_type='application/json') -        response = self.view(request, pk=1).render() +        response = self.view(request, pk='1').render()          self.assertEquals(response.status_code, status.HTTP_200_OK)          self.assertEquals(response.data, {'id': 1, 'text': 'foobar'})          updated = self.objects.get(id=1) @@ -315,3 +316,36 @@ class TestCreateModelWithAutoNowAddField(TestCase):          self.assertEquals(response.status_code, status.HTTP_201_CREATED)          created = self.objects.get(id=1)          self.assertEquals(created.content, 'foobar') + + +# Test for particularly ugly reression with m2m in browseable API +class ClassB(models.Model): +    name = models.CharField(max_length=255) + + +class ClassA(models.Model): +    name = models.CharField(max_length=255) +    childs = models.ManyToManyField(ClassB, blank=True, null=True) + + +class ClassASerializer(serializers.ModelSerializer): +    childs = serializers.ManyPrimaryKeyRelatedField(source='childs') + +    class Meta: +        model = ClassA + + +class ExampleView(generics.ListCreateAPIView): +    serializer_class = ClassASerializer +    model = ClassA + + +class TestM2MBrowseableAPI(TestCase): +    def test_m2m_in_browseable_api(self): +        """ +        Test for particularly ugly reression with m2m in browseable API +        """ +        request = factory.get('/', HTTP_ACCEPT='text/html') +        view = ExampleView().as_view() +        response = view(request).render() +        self.assertEquals(response.status_code, status.HTTP_200_OK) | 
