diff options
| author | Stephan Groß | 2012-11-05 16:37:37 +0100 | 
|---|---|---|
| committer | Stephan Groß | 2012-11-05 16:37:37 +0100 | 
| commit | 03095f607a4f110c1dc831a394f6b480a691f1fd (patch) | |
| tree | 0660477698701f0bfbadf3fe91895edcdc4c61b4 | |
| parent | 44449fa1f5f2d68740c9fb6a13c8e0a0eb41434c (diff) | |
| download | django-rest-framework-03095f607a4f110c1dc831a394f6b480a691f1fd.tar.bz2 | |
added testcase for custom slug field in hyperlinkedrelatedfield
| -rw-r--r-- | rest_framework/fields.py | 6 | ||||
| -rw-r--r-- | rest_framework/tests/hyperlinkedserializers.py | 48 | ||||
| -rw-r--r-- | rest_framework/tests/models.py | 9 | 
3 files changed, 61 insertions, 2 deletions
diff --git a/rest_framework/fields.py b/rest_framework/fields.py index 2185cf34..305b7562 100644 --- a/rest_framework/fields.py +++ b/rest_framework/fields.py @@ -493,6 +493,12 @@ class HyperlinkedRelatedField(RelatedField):          self.format = kwargs.pop('format', None)          super(HyperlinkedRelatedField, self).__init__(*args, **kwargs) +    def get_slug_field(self): +        """ +        Get the name of a slug field to be used to look up by slug. +        """ +        return self.slug_field +      def to_native(self, obj):          view_name = self.view_name          request = self.context.get('request', None) diff --git a/rest_framework/tests/hyperlinkedserializers.py b/rest_framework/tests/hyperlinkedserializers.py index 92c3691e..eee09764 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() @@ -15,6 +15,14 @@ class BlogPostCommentSerializer(serializers.Serializer):          return BlogPostComment(**attrs) +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_kwargs='title') + +    def restore_object(self, attrs, instance=None): +        return Photo(**attrs) + +  class BasicList(generics.ListCreateAPIView):      model = BasicModel      model_serializer_class = serializers.HyperlinkedModelSerializer @@ -48,6 +56,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'), @@ -55,7 +73,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')  ) @@ -166,3 +186,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)  | 
