diff options
| author | Tom Christie | 2012-09-28 15:54:00 +0100 |
|---|---|---|
| committer | Tom Christie | 2012-09-28 15:54:00 +0100 |
| commit | 9f71f8e618555d888fff8edd322c440b49f331bc (patch) | |
| tree | eb0672888424a454678f0fbf8eab9cabac394725 | |
| parent | 4ebd701be74fbb1f44f7763f7ab9e19f6483ac96 (diff) | |
| download | django-rest-framework-9f71f8e618555d888fff8edd322c440b49f331bc.tar.bz2 | |
Fix broken bits of generic views
| -rw-r--r-- | rest_framework/serializers.py | 14 | ||||
| -rw-r--r-- | rest_framework/tests/generics.py | 76 |
2 files changed, 84 insertions, 6 deletions
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py index bdb0f10a..9cbdb9de 100644 --- a/rest_framework/serializers.py +++ b/rest_framework/serializers.py @@ -231,6 +231,9 @@ class BaseSerializer(Field): """ Serialize objects -> primatives. """ + if isinstance(obj, DeserializedObject): + obj = obj.object + if isinstance(obj, dict): return dict([(key, self.to_native(val)) for (key, val) in obj.items()]) @@ -295,11 +298,7 @@ class ModelSerializer(RelatedField, Serializer): """ Return all the fields that should be serialized for the model. """ - if serialize: - cls = obj.__class__ - else: - cls = self.opts.model - + cls = self.opts.model opts = get_concrete_model(cls)._meta pk_field = opts.pk while pk_field.rel: @@ -342,6 +341,11 @@ class ModelSerializer(RelatedField, Serializer): """ Restore the model instance. """ + if instance: + for key, val in attrs.items(): + setattr(instance, key, val) + return DeserializedObject(instance) + m2m_data = {} for field in self.opts.model._meta.many_to_many: if field.name in attrs: diff --git a/rest_framework/tests/generics.py b/rest_framework/tests/generics.py index dc9c6226..fd1060a8 100644 --- a/rest_framework/tests/generics.py +++ b/rest_framework/tests/generics.py @@ -1,5 +1,6 @@ from django.test import TestCase from django.test.client import RequestFactory +from django.utils import simplejson as json from rest_framework import generics, status from rest_framework.tests.models import BasicModel @@ -11,8 +12,15 @@ class RootView(generics.RootAPIView): model = BasicModel -class TestListView(TestCase): +class InstanceView(generics.InstanceAPIView): + model = BasicModel + + +class TestRootView(TestCase): def setUp(self): + """ + Create 3 BasicModel intances. + """ items = ['foo', 'bar', 'baz'] for item in items: BasicModel(text=item).save() @@ -23,8 +31,74 @@ class TestListView(TestCase): ] def test_get_root_view(self): + """ + GET requests to RootAPIView should return list of objects. + """ view = RootView.as_view() request = factory.get('/') response = view(request).render() self.assertEquals(response.status_code, status.HTTP_200_OK) self.assertEquals(response.data, self.data) + + def test_post_root_view(self): + """ + POST requests to RootAPIView should create a new object. + """ + view = RootView.as_view() + content = {'text': 'foobar'} + request = factory.post('/', json.dumps(content), content_type='application/json') + response = view(request).render() + self.assertEquals(response.status_code, status.HTTP_201_CREATED) + self.assertEquals(response.data, {'id': 4, 'text': u'foobar'}) + created = self.objects.get(id=4) + self.assertEquals(created.text, 'foobar') + + +class TestInstanceView(TestCase): + def setUp(self): + """ + Create 3 BasicModel intances. + """ + items = ['foo', 'bar', 'baz'] + for item in items: + BasicModel(text=item).save() + self.objects = BasicModel.objects + self.data = [ + {'id': obj.id, 'text': obj.text} + for obj in self.objects.all() + ] + + def test_get_instance_view(self): + """ + GET requests to InstanceAPIView should return a single object. + """ + view = InstanceView.as_view() + request = factory.get('/1') + response = view(request, pk=1).render() + self.assertEquals(response.status_code, status.HTTP_200_OK) + self.assertEquals(response.data, self.data[0]) + + def test_put_instance_view(self): + """ + PUT requests to InstanceAPIView should update an object. + """ + view = InstanceView.as_view() + content = {'text': 'foobar'} + request = factory.put('/1', json.dumps(content), content_type='application/json') + response = 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) + self.assertEquals(updated.text, 'foobar') + + def test_delete_instance_view(self): + """ + DELETE requests to InstanceAPIView should delete an object. + """ + view = InstanceView.as_view() + request = factory.delete('/1') + response = view(request, pk=1).render() + self.assertEquals(response.status_code, status.HTTP_204_NO_CONTENT) + self.assertEquals(response.content, '') + ids = [obj.id for obj in self.objects.all()] + self.assertEquals(ids, [2, 3]) |
