diff options
| author | Michael Merickel <michael@merickel.org> | 2015-02-06 01:05:12 -0600 |
|---|---|---|
| committer | Michael Merickel <michael@merickel.org> | 2015-02-06 01:05:12 -0600 |
| commit | 4b13e0dfcdf47b3ef9befd529c0d78af8a2712d5 (patch) | |
| tree | 0642031c665a2da5e6190db20fb0291bdb4d2781 | |
| parent | 04ef03eb425945a4e3d15f7a86a13f7e7be68948 (diff) | |
| parent | 1ef35b7194ad744f23cf2881bbf881690d680c83 (diff) | |
| download | pyramid-4b13e0dfcdf47b3ef9befd529c0d78af8a2712d5.tar.gz pyramid-4b13e0dfcdf47b3ef9befd529c0d78af8a2712d5.tar.bz2 pyramid-4b13e0dfcdf47b3ef9befd529c0d78af8a2712d5.zip | |
Merge pull request #1561 from Pylons/fix.jsonp-without-request
fix #1535 by avoiding the request if it's None
| -rw-r--r-- | CHANGES.txt | 5 | ||||
| -rw-r--r-- | pyramid/renderers.py | 24 | ||||
| -rw-r--r-- | pyramid/tests/test_renderers.py | 6 |
3 files changed, 23 insertions, 12 deletions
diff --git a/CHANGES.txt b/CHANGES.txt index 832a2c216..b334f5258 100644 --- a/CHANGES.txt +++ b/CHANGES.txt @@ -120,6 +120,11 @@ Bug Fixes - Fix route generation for static view asset specifications having no path. See https://github.com/Pylons/pyramid/pull/1377 +- Allow the ``pyramid.renderers.JSONP`` renderer to work even if there is no + valid request object. In this case it will not wrap the object in a + callback and thus behave just like the ``pyramid.renderers.JSON` renderer. + See https://github.com/Pylons/pyramid/pull/1561 + Deprecations ------------ diff --git a/pyramid/renderers.py b/pyramid/renderers.py index d840cc317..3c35551ea 100644 --- a/pyramid/renderers.py +++ b/pyramid/renderers.py @@ -24,7 +24,7 @@ from pyramid.events import BeforeRender from pyramid.path import caller_package -from pyramid.response import Response, _get_response_factory +from pyramid.response import _get_response_factory from pyramid.threadlocal import get_current_registry # API @@ -355,19 +355,19 @@ class JSONP(JSON): ``self.param_name`` is present in request.GET; otherwise returns plain-JSON encoded string with content-type ``application/json``""" def _render(value, system): - request = system['request'] + request = system.get('request') default = self._make_default(request) val = self.serializer(value, default=default, **self.kw) - callback = request.GET.get(self.param_name) - if callback is None: - ct = 'application/json' - body = val - else: - ct = 'application/javascript' - body = '%s(%s);' % (callback, val) - response = request.response - if response.content_type == response.default_content_type: - response.content_type = ct + ct = 'application/json' + body = val + if request is not None: + callback = request.GET.get(self.param_name) + if callback is not None: + ct = 'application/javascript' + body = '%s(%s);' % (callback, val) + response = request.response + if response.content_type == response.default_content_type: + response.content_type = ct return body return _render diff --git a/pyramid/tests/test_renderers.py b/pyramid/tests/test_renderers.py index 30fdef051..6d79cc291 100644 --- a/pyramid/tests/test_renderers.py +++ b/pyramid/tests/test_renderers.py @@ -602,6 +602,12 @@ class TestJSONP(unittest.TestCase): self.assertEqual(request.response.content_type, 'application/json') + def test_render_without_request(self): + renderer_factory = self._makeOne() + renderer = renderer_factory(None) + result = renderer({'a':'1'}, {}) + self.assertEqual(result, '{"a": "1"}') + class Dummy: pass |
