diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2024-06-06 17:12:32 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-06-06 17:12:32 (GMT) |
commit | 2d7ff6e0e7d4c08ba84079a5c19a4a485626e1de (patch) | |
tree | 22ca219acbd22e3a5e0e5e71f41612b7207c7036 | |
parent | d50a7c478feb4037e65fcaea453d9ecc00259dd9 (diff) | |
download | cpython-2d7ff6e0e7d4c08ba84079a5c19a4a485626e1de.zip cpython-2d7ff6e0e7d4c08ba84079a5c19a4a485626e1de.tar.gz cpython-2d7ff6e0e7d4c08ba84079a5c19a4a485626e1de.tar.bz2 |
Restore decimal context after decimal doctests (GH-120149)
The modified context caused tests failures in several other tests.
-rw-r--r-- | Lib/test/test_decimal.py | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/Lib/test/test_decimal.py b/Lib/test/test_decimal.py index e927e24..4675510 100644 --- a/Lib/test/test_decimal.py +++ b/Lib/test/test_decimal.py @@ -5892,13 +5892,17 @@ def load_tests(loader, tests, pattern): if TODO_TESTS is None: from doctest import DocTestSuite, IGNORE_EXCEPTION_DETAIL + orig_context = orig_sys_decimal.getcontext().copy() for mod in C, P: if not mod: continue def setUp(slf, mod=mod): sys.modules['decimal'] = mod - def tearDown(slf): + init(mod) + def tearDown(slf, mod=mod): sys.modules['decimal'] = orig_sys_decimal + mod.setcontext(ORIGINAL_CONTEXT[mod].copy()) + orig_sys_decimal.setcontext(orig_context.copy()) optionflags = IGNORE_EXCEPTION_DETAIL if mod is C else 0 sys.modules['decimal'] = mod tests.addTest(DocTestSuite(mod, setUp=setUp, tearDown=tearDown, @@ -5913,8 +5917,8 @@ def setUpModule(): TEST_ALL = ARITH if ARITH is not None else is_resource_enabled('decimal') def tearDownModule(): - if C: C.setcontext(ORIGINAL_CONTEXT[C]) - P.setcontext(ORIGINAL_CONTEXT[P]) + if C: C.setcontext(ORIGINAL_CONTEXT[C].copy()) + P.setcontext(ORIGINAL_CONTEXT[P].copy()) if not C: warnings.warn('C tests skipped: no module named _decimal.', UserWarning) |