diff options
| author | Tom Christie | 2012-10-05 05:11:17 -0700 |
|---|---|---|
| committer | Tom Christie | 2012-10-05 05:11:17 -0700 |
| commit | 2455bebd8733a11ba06dfbc33f9f2378025f538c (patch) | |
| tree | aeacef5a09d7bd815dd02fcb0baa5a81d777c9c5 /rest_framework/tests/negotiation.py | |
| parent | 5a14e3eff29c1c28ab1c217680d9f25b92405221 (diff) | |
| parent | 61a6d0c1094706db137b2fe57f117f263a61923d (diff) | |
| download | django-rest-framework-2455bebd8733a11ba06dfbc33f9f2378025f538c.tar.bz2 | |
Merge pull request #282 from tomchristie/html-template-responses
Html template responses
Diffstat (limited to 'rest_framework/tests/negotiation.py')
| -rw-r--r-- | rest_framework/tests/negotiation.py | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/rest_framework/tests/negotiation.py b/rest_framework/tests/negotiation.py new file mode 100644 index 00000000..d8265b43 --- /dev/null +++ b/rest_framework/tests/negotiation.py @@ -0,0 +1,37 @@ +from django.test import TestCase +from django.test.client import RequestFactory +from rest_framework.negotiation import DefaultContentNegotiation + +factory = RequestFactory() + + +class MockJSONRenderer(object): + media_type = 'application/json' + + +class MockHTMLRenderer(object): + media_type = 'text/html' + + +class TestAcceptedMediaType(TestCase): + def setUp(self): + self.renderers = [MockJSONRenderer(), MockHTMLRenderer()] + self.negotiator = DefaultContentNegotiation() + + def negotiate(self, request): + return self.negotiator.negotiate(request, self.renderers) + + def test_client_without_accept_use_renderer(self): + request = factory.get('/') + accepted_renderer, accepted_media_type = self.negotiate(request) + self.assertEquals(accepted_media_type, 'application/json') + + def test_client_underspecifies_accept_use_renderer(self): + request = factory.get('/', HTTP_ACCEPT='*/*') + accepted_renderer, accepted_media_type = self.negotiate(request) + self.assertEquals(accepted_media_type, 'application/json') + + def test_client_overspecifies_accept_use_client(self): + request = factory.get('/', HTTP_ACCEPT='application/json; indent=8') + accepted_renderer, accepted_media_type = self.negotiate(request) + self.assertEquals(accepted_media_type, 'application/json; indent=8') |
