diff options
| author | Tom Christie | 2014-12-05 12:46:36 +0000 |
|---|---|---|
| committer | Tom Christie | 2014-12-05 12:46:36 +0000 |
| commit | 99a43748eb5664ae152939deee3d0145da04e07b (patch) | |
| tree | 0997ab92f1344c874d35f08de1162677aee29fe7 | |
| parent | 1b8c06aefe33f178610d2c4195a72637757698e8 (diff) | |
| parent | de4ef6e3945e1281e0145d7ca19b6213f2aebfc6 (diff) | |
| download | django-rest-framework-99a43748eb5664ae152939deee3d0145da04e07b.tar.bz2 | |
Merge branch 'master' of https://github.com/tomchristie/django-rest-framework
| -rw-r--r-- | rest_framework/renderers.py | 5 | ||||
| -rw-r--r-- | tests/test_renderers.py | 9 |
2 files changed, 14 insertions, 0 deletions
diff --git a/rest_framework/renderers.py b/rest_framework/renderers.py index 31d3ef5f..07f1c628 100644 --- a/rest_framework/renderers.py +++ b/rest_framework/renderers.py @@ -102,6 +102,11 @@ class JSONRenderer(BaseRenderer): # and may (or may not) be unicode. # On python 3.x json.dumps() returns unicode strings. if isinstance(ret, six.text_type): + # We always fully escape \u2028 and \u2029 to ensure we output JSON + # that is a strict javascript subset. If bytes were returned + # by json.dumps() then we don't have these characters in any case. + # See: http://timelessrepo.com/json-isnt-a-javascript-subset + ret = ret.replace('\u2028', '\\u2028').replace('\u2029', '\\u2029') return bytes(ret.encode('utf-8')) return ret diff --git a/tests/test_renderers.py b/tests/test_renderers.py index 416d7f22..61dd7c7a 100644 --- a/tests/test_renderers.py +++ b/tests/test_renderers.py @@ -384,6 +384,15 @@ class UnicodeJSONRendererTests(TestCase): content = renderer.render(obj, 'application/json') self.assertEqual(content, '{"countries":["United Kingdom","France","EspaƱa"]}'.encode('utf-8')) + def test_u2028_u2029(self): + # The \u2028 and \u2029 characters should be escaped, + # even when the non-escaping unicode representation is used. + # Regression test for #2169 + obj = {'should_escape': '\u2028\u2029'} + renderer = JSONRenderer() + content = renderer.render(obj, 'application/json') + self.assertEqual(content, '{"should_escape":"\\u2028\\u2029"}'.encode('utf-8')) + class AsciiJSONRendererTests(TestCase): """ |
