diff options
| author | Tom Christie | 2012-11-05 08:36:59 -0800 | 
|---|---|---|
| committer | Tom Christie | 2012-11-05 08:36:59 -0800 | 
| commit | 9731b95fc36040ef24dc6fd7ae2cf66c0a8f6a1c (patch) | |
| tree | 9d2bc1cb1dddb27f20c253712d4dc269afd3e3e8 /rest_framework/tests | |
| parent | b87f01aa54739ad82e090da1622e4f711a364402 (diff) | |
| parent | 85b176cf47cd0d4f392ee0a4bae971c709dbfddc (diff) | |
| download | django-rest-framework-9731b95fc36040ef24dc6fd7ae2cf66c0a8f6a1c.tar.bz2 | |
Merge pull request #347 from minddust/master
support for passing custom slug options to HyperlinkedRelatedField
Diffstat (limited to 'rest_framework/tests')
| -rw-r--r-- | rest_framework/tests/hyperlinkedserializers.py | 48 | ||||
| -rw-r--r-- | rest_framework/tests/models.py | 9 | 
2 files changed, 55 insertions, 2 deletions
diff --git a/rest_framework/tests/hyperlinkedserializers.py b/rest_framework/tests/hyperlinkedserializers.py index 147943c6..f991c3b5 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 Anchor, BasicModel, ManyToManyModel, BlogPost, BlogPostComment +from rest_framework.tests.models import Anchor, BasicModel, ManyToManyModel, BlogPost, BlogPostComment, Album, Photo  factory = RequestFactory() @@ -16,6 +16,14 @@ class BlogPostCommentSerializer(serializers.ModelSerializer):          fields = ('text', 'blog_post_url') +class PhotoSerializer(serializers.Serializer): +    description = serializers.CharField() +    album_url = serializers.HyperlinkedRelatedField(source='album', view_name='album-detail', queryset=Album.objects.all(), slug_field='title', slug_url_kwarg='title') + +    def restore_object(self, attrs, instance=None): +        return Photo(**attrs) + +  class BasicList(generics.ListCreateAPIView):      model = BasicModel      model_serializer_class = serializers.HyperlinkedModelSerializer @@ -49,6 +57,16 @@ class BlogPostCommentListCreate(generics.ListCreateAPIView):  class BlogPostDetail(generics.RetrieveAPIView):      model = BlogPost + +class PhotoListCreate(generics.ListCreateAPIView): +    model = Photo +    model_serializer_class = PhotoSerializer + + +class AlbumDetail(generics.RetrieveAPIView): +    model = Album + +  urlpatterns = patterns('',      url(r'^basic/$', BasicList.as_view(), name='basicmodel-list'),      url(r'^basic/(?P<pk>\d+)/$', BasicDetail.as_view(), name='basicmodel-detail'), @@ -56,7 +74,9 @@ urlpatterns = patterns('',      url(r'^manytomany/$', ManyToManyList.as_view(), name='manytomanymodel-list'),      url(r'^manytomany/(?P<pk>\d+)/$', ManyToManyDetail.as_view(), name='manytomanymodel-detail'),      url(r'^posts/(?P<pk>\d+)/$', BlogPostDetail.as_view(), name='blogpost-detail'), -    url(r'^comments/$', BlogPostCommentListCreate.as_view(), name='blogpostcomment-list') +    url(r'^comments/$', BlogPostCommentListCreate.as_view(), name='blogpostcomment-list'), +    url(r'^albums/(?P<title>\w[\w-]*)/$', AlbumDetail.as_view(), name='album-detail'), +    url(r'^photos/$', PhotoListCreate.as_view(), name='photo-list')  ) @@ -167,3 +187,27 @@ class TestCreateWithForeignKeys(TestCase):          self.assertEqual(response.status_code, 201)          self.assertEqual(self.post.blogpostcomment_set.count(), 1)          self.assertEqual(self.post.blogpostcomment_set.all()[0].text, 'A test comment') + + +class TestCreateWithForeignKeysAndCustomSlug(TestCase): +    urls = 'rest_framework.tests.hyperlinkedserializers' + +    def setUp(self): +        """ +        Create an Album +        """ +        self.post = Album.objects.create(title='test-album') +        self.list_create_view = PhotoListCreate.as_view() + +    def test_create_photo(self): + +        data = { +            'description': 'A test photo', +            'album_url': 'http://testserver/albums/test-album/' +        } + +        request = factory.post('/photos/', data=data) +        response = self.list_create_view(request).render() +        self.assertEqual(response.status_code, status.HTTP_201_CREATED) +        self.assertEqual(self.post.photo_set.count(), 1) +        self.assertEqual(self.post.photo_set.all()[0].description, 'A test photo') diff --git a/rest_framework/tests/models.py b/rest_framework/tests/models.py index 1a0078e8..0e23734e 100644 --- a/rest_framework/tests/models.py +++ b/rest_framework/tests/models.py @@ -118,6 +118,15 @@ class BlogPostComment(RESTFrameworkModel):      blog_post = models.ForeignKey(BlogPost) +class Album(RESTFrameworkModel): +    title = models.CharField(max_length=100, unique=True) + + +class Photo(RESTFrameworkModel): +    description = models.TextField() +    album = models.ForeignKey(Album) + +  class Person(RESTFrameworkModel):      name = models.CharField(max_length=10)      age = models.IntegerField(null=True, blank=True)  | 
