summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_json
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2013-11-26 19:25:28 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2013-11-26 19:25:28 (GMT)
commitc93329b3dd6dde3de76f473f5573233cb0366d9c (patch)
tree1dba9aa32ec2384766f56c49ffd4887c3e47bd13 /Lib/test/test_json
parentf45bbb62110a7bbcbbf45c1a52be6de7b791b189 (diff)
downloadcpython-c93329b3dd6dde3de76f473f5573233cb0366d9c.zip
cpython-c93329b3dd6dde3de76f473f5573233cb0366d9c.tar.gz
cpython-c93329b3dd6dde3de76f473f5573233cb0366d9c.tar.bz2
Issue #11489: JSON decoder now accepts lone surrogates.
Diffstat (limited to 'Lib/test/test_json')
-rw-r--r--Lib/test/test_json/test_scanstring.py51
1 files changed, 47 insertions, 4 deletions
diff --git a/Lib/test/test_json/test_scanstring.py b/Lib/test/test_json/test_scanstring.py
index 2e3a291..07f4358 100644
--- a/Lib/test/test_json/test_scanstring.py
+++ b/Lib/test/test_json/test_scanstring.py
@@ -6,10 +6,6 @@ class TestScanstring:
def test_scanstring(self):
scanstring = self.json.decoder.scanstring
self.assertEqual(
- scanstring('"z\\ud834\\udd20x"', 1, True),
- ('z\U0001d120x', 16))
-
- self.assertEqual(
scanstring('"z\U0001d120x"', 1, True),
('z\U0001d120x', 5))
@@ -89,6 +85,53 @@ class TestScanstring:
scanstring('["Bad value", truth]', 2, True),
('Bad value', 12))
+ def test_surrogates(self):
+ scanstring = self.json.decoder.scanstring
+ def assertScan(given, expect):
+ self.assertEqual(scanstring(given, 1, True),
+ (expect, len(given)))
+
+ assertScan('"z\\ud834\\u0079x"', 'z\ud834yx')
+ assertScan('"z\\ud834\\udd20x"', 'z\U0001d120x')
+ assertScan('"z\\ud834\\ud834\\udd20x"', 'z\ud834\U0001d120x')
+ assertScan('"z\\ud834x"', 'z\ud834x')
+ assertScan('"z\\ud834\udd20x12345"', 'z\ud834\udd20x12345')
+ assertScan('"z\\udd20x"', 'z\udd20x')
+ assertScan('"z\ud834\udd20x"', 'z\ud834\udd20x')
+ assertScan('"z\ud834\\udd20x"', 'z\ud834\udd20x')
+ assertScan('"z\ud834x"', 'z\ud834x')
+
+ def test_bad_escapes(self):
+ scanstring = self.json.decoder.scanstring
+ bad_escapes = [
+ '"\\"',
+ '"\\x"',
+ '"\\u"',
+ '"\\u0"',
+ '"\\u01"',
+ '"\\u012"',
+ '"\\uz012"',
+ '"\\u0z12"',
+ '"\\u01z2"',
+ '"\\u012z"',
+ '"\\u0x12"',
+ '"\\u0X12"',
+ '"\\ud834\\"',
+ '"\\ud834\\u"',
+ '"\\ud834\\ud"',
+ '"\\ud834\\udd"',
+ '"\\ud834\\udd2"',
+ '"\\ud834\\uzdd2"',
+ '"\\ud834\\udzd2"',
+ '"\\ud834\\uddz2"',
+ '"\\ud834\\udd2z"',
+ '"\\ud834\\u0x20"',
+ '"\\ud834\\u0X20"',
+ ]
+ for s in bad_escapes:
+ with self.assertRaises(ValueError, msg=s):
+ scanstring(s, 1, True)
+
def test_overflow(self):
with self.assertRaises(OverflowError):
self.json.decoder.scanstring(b"xxx", sys.maxsize+1)