diff options
author | Miss Islington (bot) <31488909+miss-islington@users.noreply.github.com> | 2017-09-26 22:21:47 -0700 |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2017-09-27 08:21:47 +0300 |
commit | 7c24e99c99c961e6633ac45390a211f65806c687 (patch) | |
tree | cb98bb49e763c9d57adecb7486d31989c6f926ef /Lib/test | |
parent | [3.6] bpo-31285: Fix an assertion failure and a SystemError in warnings.warn_... (diff) | |
download | cpython-7c24e99c99c961e6633ac45390a211f65806c687.tar.gz cpython-7c24e99c99c961e6633ac45390a211f65806c687.tar.bz2 cpython-7c24e99c99c961e6633ac45390a211f65806c687.zip |
[3.6] bpo-31505: Fix an assertion failure in json, in case _json.make_encoder() received a bad encoder() argument. (GH-3643) (#3777)
(cherry picked from commit 2b382dd6121bb1e4b75470fb3ef8555665df3eb6)
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/test_json/test_speedups.py | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/Lib/test/test_json/test_speedups.py b/Lib/test/test_json/test_speedups.py index 56f1882001d..5dad6920870 100644 --- a/Lib/test/test_json/test_speedups.py +++ b/Lib/test/test_json/test_speedups.py @@ -36,6 +36,27 @@ class TestEncode(CTest): b"\xCD\x7D\x3D\x4E\x12\x4C\xF9\x79\xD7\x52\xBA\x82\xF2\x27\x4A\x7D\xA0\xCA\x75", None) + def test_bad_str_encoder(self): + # Issue #31505: There shouldn't be an assertion failure in case + # c_make_encoder() receives a bad encoder() argument. + def bad_encoder1(*args): + return None + enc = self.json.encoder.c_make_encoder(None, lambda obj: str(obj), + bad_encoder1, None, ': ', ', ', + False, False, False) + with self.assertRaises(TypeError): + enc('spam', 4) + with self.assertRaises(TypeError): + enc({'spam': 42}, 4) + + def bad_encoder2(*args): + 1/0 + enc = self.json.encoder.c_make_encoder(None, lambda obj: str(obj), + bad_encoder2, None, ': ', ', ', + False, False, False) + with self.assertRaises(ZeroDivisionError): + enc('spam', 4) + def test_bad_bool_args(self): def test(name): self.json.encoder.JSONEncoder(**{name: BadBool()}).encode({'a': 1}) |