diff options
| author | Tom Christie | 2012-10-04 16:58:18 +0100 | 
|---|---|---|
| committer | Tom Christie | 2012-10-04 16:58:18 +0100 | 
| commit | c91d926b0664981de0fd239a4398dd71367a5911 (patch) | |
| tree | bd259ce7df6b584e96467d6b22790b2074d308b7 /rest_framework/tests/hyperlinkedserializers.py | |
| parent | 55e9cbecac1456f0e1521a4bcceb1ef4f44e5e0b (diff) | |
| download | django-rest-framework-c91d926b0664981de0fd239a4398dd71367a5911.tar.bz2 | |
Initial tests for hyperlinked relationships
Diffstat (limited to 'rest_framework/tests/hyperlinkedserializers.py')
| -rw-r--r-- | rest_framework/tests/hyperlinkedserializers.py | 74 | 
1 files changed, 70 insertions, 4 deletions
diff --git a/rest_framework/tests/hyperlinkedserializers.py b/rest_framework/tests/hyperlinkedserializers.py index 4f9393aa..5532a8ee 100644 --- a/rest_framework/tests/hyperlinkedserializers.py +++ b/rest_framework/tests/hyperlinkedserializers.py @@ -2,7 +2,7 @@ from django.conf.urls.defaults import patterns, url  from django.test import TestCase  from django.test.client import RequestFactory  from rest_framework import generics, status, serializers -from rest_framework.tests.models import BasicModel +from rest_framework.tests.models import Anchor, BasicModel, ManyToManyModel  factory = RequestFactory() @@ -17,13 +17,31 @@ class BasicDetail(generics.RetrieveUpdateDestroyAPIView):      model_serializer_class = serializers.HyperlinkedModelSerializer +class AnchorDetail(generics.RetrieveAPIView): +    model = Anchor +    model_serializer_class = serializers.HyperlinkedModelSerializer + + +class ManyToManyList(generics.ListAPIView): +    model = ManyToManyModel +    model_serializer_class = serializers.HyperlinkedModelSerializer + + +class ManyToManyDetail(generics.RetrieveAPIView): +    model = ManyToManyModel +    model_serializer_class = serializers.HyperlinkedModelSerializer + +  urlpatterns = patterns('',      url(r'^basic/$', BasicList.as_view(), name='basicmodel-list'),      url(r'^basic/(?P<pk>\d+)/$', BasicDetail.as_view(), name='basicmodel-detail'), +    url(r'^anchor/(?P<pk>\d+)/$', AnchorDetail.as_view(), name='anchor-detail'), +    url(r'^manytomany/$', ManyToManyList.as_view(), name='manytomanymodel-list'), +    url(r'^manytomany/(?P<pk>\d+)/$', ManyToManyDetail.as_view(), name='manytomanymodel-detail'),  ) -class TestHyperlinkedView(TestCase): +class TestBasicHyperlinkedView(TestCase):      urls = 'rest_framework.tests.hyperlinkedserializers'      def setUp(self): @@ -45,7 +63,55 @@ class TestHyperlinkedView(TestCase):          """          GET requests to ListCreateAPIView should return list of objects.          """ -        request = factory.get('/') +        request = factory.get('/basic/') +        response = self.list_view(request).render() +        self.assertEquals(response.status_code, status.HTTP_200_OK) +        self.assertEquals(response.data, self.data) + +    def test_get_detail_view(self): +        """ +        GET requests to ListCreateAPIView should return list of objects. +        """ +        request = factory.get('/basic/1') +        response = self.detail_view(request, pk=1).render() +        self.assertEquals(response.status_code, status.HTTP_200_OK) +        self.assertEquals(response.data, self.data[0]) + + +class TestManyToManyHyperlinkedView(TestCase): +    urls = 'rest_framework.tests.hyperlinkedserializers' + +    def setUp(self): +        """ +        Create 3 BasicModel intances. +        """ +        items = ['foo', 'bar', 'baz'] +        anchors = [] +        for item in items: +            anchor = Anchor(text=item) +            anchor.save() +            anchors.append(anchor) + +        manytomany = ManyToManyModel() +        manytomany.save() +        manytomany.rel.add(*anchors) + +        self.data = [{ +            'url': 'http://testserver/manytomany/1/', +            'rel': [ +                'http://testserver/anchor/1/', +                'http://testserver/anchor/2/', +                'http://testserver/anchor/3/', +            ] +        }] +        self.list_view = ManyToManyList.as_view() +        self.detail_view = ManyToManyDetail.as_view() + +    def test_get_list_view(self): +        """ +        GET requests to ListCreateAPIView should return list of objects. +        """ +        request = factory.get('/manytomany/')          response = self.list_view(request).render()          self.assertEquals(response.status_code, status.HTTP_200_OK)          self.assertEquals(response.data, self.data) @@ -54,7 +120,7 @@ class TestHyperlinkedView(TestCase):          """          GET requests to ListCreateAPIView should return list of objects.          """ -        request = factory.get('/1') +        request = factory.get('/manytomany/1/')          response = self.detail_view(request, pk=1).render()          self.assertEquals(response.status_code, status.HTTP_200_OK)          self.assertEquals(response.data, self.data[0])  | 
