diff options
author | Ezio Melotti <ezio.melotti@gmail.com> | 2013-03-12 23:52:34 (GMT) |
---|---|---|
committer | Ezio Melotti <ezio.melotti@gmail.com> | 2013-03-12 23:52:34 (GMT) |
commit | a7d64a6f4c0307f9c58ea170705b1552580d93eb (patch) | |
tree | dec59285d3c60b71c205dc3f62cb52aa4f5d7d52 /Lib/test | |
parent | 7343cb0790d3ac722ee788d5c2044cbda770a140 (diff) | |
download | cpython-a7d64a6f4c0307f9c58ea170705b1552580d93eb.zip cpython-a7d64a6f4c0307f9c58ea170705b1552580d93eb.tar.gz cpython-a7d64a6f4c0307f9c58ea170705b1552580d93eb.tar.bz2 |
#17368: Fix an off-by-one error in the Python JSON decoder that caused a failure while decoding empty object literals when object_pairs_hook was specified.
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/json_tests/test_decode.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/Lib/test/json_tests/test_decode.py b/Lib/test/json_tests/test_decode.py index 0a55a33..15a427f 100644 --- a/Lib/test/json_tests/test_decode.py +++ b/Lib/test/json_tests/test_decode.py @@ -25,16 +25,22 @@ class TestDecode: p = [("xkd", 1), ("kcw", 2), ("art", 3), ("hxm", 4), ("qrt", 5), ("pad", 6), ("hoy", 7)] self.assertEqual(self.loads(s), eval(s)) - self.assertEqual(self.loads(s, object_pairs_hook = lambda x: x), p) + self.assertEqual(self.loads(s, object_pairs_hook=lambda x: x), p) self.assertEqual(self.json.load(StringIO(s), object_pairs_hook=lambda x: x), p) - od = self.loads(s, object_pairs_hook = OrderedDict) + od = self.loads(s, object_pairs_hook=OrderedDict) self.assertEqual(od, OrderedDict(p)) self.assertEqual(type(od), OrderedDict) # the object_pairs_hook takes priority over the object_hook - self.assertEqual(self.loads(s, object_pairs_hook = OrderedDict, - object_hook = lambda x: None), + self.assertEqual(self.loads(s, object_pairs_hook=OrderedDict, + object_hook=lambda x: None), OrderedDict(p)) + # check that empty objects literals work (see #17368) + self.assertEqual(self.loads('{}', object_pairs_hook=OrderedDict), + OrderedDict()) + self.assertEqual(self.loads('{"empty": {}}', + object_pairs_hook=OrderedDict), + OrderedDict([('empty', OrderedDict())])) def test_decoder_optimizations(self): # Several optimizations were made that skip over calls to |