aboutsummaryrefslogtreecommitdiffstats
path: root/djangorestframework/tests/response.py
diff options
context:
space:
mode:
authorTom Christie2012-09-16 21:48:55 +0100
committerTom Christie2012-09-16 21:48:55 +0100
commita96211d3d1ba246512af5e32c31726a666c467ac (patch)
treef27dc9f1f6900320588bb91fcad76f3366cef815 /djangorestframework/tests/response.py
parent6543ccd244a8d482b8aec18b5d03ee964292f17f (diff)
downloaddjango-rest-framework-a96211d3d1ba246512af5e32c31726a666c467ac.tar.bz2
Simplify negotiation. Drop MSIE hacks. Etc.
Diffstat (limited to 'djangorestframework/tests/response.py')
-rw-r--r--djangorestframework/tests/response.py136
1 files changed, 2 insertions, 134 deletions
diff --git a/djangorestframework/tests/response.py b/djangorestframework/tests/response.py
index cdddfff4..5083f6d2 100644
--- a/djangorestframework/tests/response.py
+++ b/djangorestframework/tests/response.py
@@ -1,4 +1,3 @@
-import json
import unittest
from django.conf.urls.defaults import patterns, url, include
@@ -6,13 +5,11 @@ from django.test import TestCase
from djangorestframework.response import Response
from djangorestframework.views import APIView
-from djangorestframework.compat import RequestFactory
-from djangorestframework import status, exceptions
+from djangorestframework import status
from djangorestframework.renderers import (
BaseRenderer,
JSONRenderer,
- DocumentingHTMLRenderer,
- DEFAULT_RENDERERS
+ DocumentingHTMLRenderer
)
@@ -24,126 +21,6 @@ class MockJsonRenderer(BaseRenderer):
media_type = 'application/json'
-class TestResponseDetermineRenderer(TestCase):
-
- def get_response(self, url='', accept_list=[], renderer_classes=[]):
- kwargs = {}
- if accept_list is not None:
- kwargs['HTTP_ACCEPT'] = ','.join(accept_list)
- request = RequestFactory().get(url, **kwargs)
- return Response(request=request, renderer_classes=renderer_classes)
-
- def test_determine_accept_list_accept_header(self):
- """
- Test that determine_accept_list takes the Accept header.
- """
- accept_list = ['application/pickle', 'application/json']
- response = self.get_response(accept_list=accept_list)
- self.assertEqual(response._determine_accept_list(), accept_list)
-
- def test_determine_accept_list_default(self):
- """
- Test that determine_accept_list takes the default renderer if Accept is not specified.
- """
- response = self.get_response(accept_list=None)
- self.assertEqual(response._determine_accept_list(), ['*/*'])
-
- def test_determine_accept_list_overriden_header(self):
- """
- Test Accept header overriding.
- """
- accept_list = ['application/pickle', 'application/json']
- response = self.get_response(url='?_accept=application/x-www-form-urlencoded',
- accept_list=accept_list)
- self.assertEqual(response._determine_accept_list(), ['application/x-www-form-urlencoded'])
-
- def test_determine_renderer(self):
- """
- Test that right renderer is chosen, in the order of Accept list.
- """
- accept_list = ['application/pickle', 'application/json']
- renderer_classes = (MockPickleRenderer, MockJsonRenderer)
- response = self.get_response(accept_list=accept_list, renderer_classes=renderer_classes)
- renderer, media_type = response._determine_renderer()
- self.assertEqual(media_type, 'application/pickle')
- self.assertTrue(isinstance(renderer, MockPickleRenderer))
-
- renderer_classes = (MockJsonRenderer, )
- response = self.get_response(accept_list=accept_list, renderer_classes=renderer_classes)
- renderer, media_type = response._determine_renderer()
- self.assertEqual(media_type, 'application/json')
- self.assertTrue(isinstance(renderer, MockJsonRenderer))
-
- def test_determine_renderer_default(self):
- """
- Test determine renderer when Accept was not specified.
- """
- renderer_classes = (MockPickleRenderer, )
- response = self.get_response(accept_list=None, renderer_classes=renderer_classes)
- renderer, media_type = response._determine_renderer()
- self.assertEqual(media_type, '*/*')
- self.assertTrue(isinstance(renderer, MockPickleRenderer))
-
- def test_determine_renderer_no_renderer(self):
- """
- Test determine renderer when no renderer can satisfy the Accept list.
- """
- accept_list = ['application/json']
- renderer_classes = (MockPickleRenderer, )
- response = self.get_response(accept_list=accept_list, renderer_classes=renderer_classes)
- self.assertRaises(exceptions.NotAcceptable, response._determine_renderer)
-
-
-class TestResponseRenderContent(TestCase):
- def get_response(self, url='', accept_list=[], content=None, renderer_classes=None):
- request = RequestFactory().get(url, HTTP_ACCEPT=','.join(accept_list))
- return Response(request=request, content=content, renderer_classes=renderer_classes or DEFAULT_RENDERERS)
-
- def test_render(self):
- """
- Test rendering simple data to json.
- """
- content = {'a': 1, 'b': [1, 2, 3]}
- content_type = 'application/json'
- response = self.get_response(accept_list=[content_type], content=content)
- response = response.render()
- self.assertEqual(json.loads(response.content), content)
- self.assertEqual(response['Content-Type'], content_type)
-
- def test_render_no_renderer(self):
- """
- Test rendering response when no renderer can satisfy accept.
- """
- content = 'bla'
- content_type = 'weirdcontenttype'
- response = self.get_response(accept_list=[content_type], content=content)
- response = response.render()
- self.assertEqual(response.status_code, 406)
- self.assertIsNotNone(response.content)
-
- # def test_render_renderer_raises_ImmediateResponse(self):
- # """
- # Test rendering response when renderer raises ImmediateResponse
- # """
- # class PickyJSONRenderer(BaseRenderer):
- # """
- # A renderer that doesn't make much sense, just to try
- # out raising an ImmediateResponse
- # """
- # media_type = 'application/json'
-
- # def render(self, obj=None, media_type=None):
- # raise ImmediateResponse({'error': '!!!'}, status=400)
-
- # response = self.get_response(
- # accept_list=['application/json'],
- # renderers=[PickyJSONRenderer, JSONRenderer]
- # )
- # response = response.render()
- # self.assertEqual(response.status_code, 400)
- # self.assertEqual(response.content, json.dumps({'error': '!!!'}))
-
-
DUMMYSTATUS = status.HTTP_200_OK
DUMMYCONTENT = 'dummycontent'
@@ -280,15 +157,6 @@ class RendererIntegrationTests(TestCase):
self.assertEquals(resp.content, RENDERER_B_SERIALIZER(DUMMYCONTENT))
self.assertEquals(resp.status_code, DUMMYSTATUS)
- def test_conflicting_format_query_and_accept_ignores_accept(self):
- """If a 'format' query is specified that does not match the Accept
- header, we should only honor the 'format' query string."""
- resp = self.client.get('/?format=%s' % RendererB.format,
- HTTP_ACCEPT='dummy')
- self.assertEquals(resp['Content-Type'], RendererB.media_type)
- self.assertEquals(resp.content, RENDERER_B_SERIALIZER(DUMMYCONTENT))
- self.assertEquals(resp.status_code, DUMMYSTATUS)
-
class Issue122Tests(TestCase):
"""