summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2024-06-06 17:12:32 (GMT)
committerGitHub <noreply@github.com>2024-06-06 17:12:32 (GMT)
commit2d7ff6e0e7d4c08ba84079a5c19a4a485626e1de (patch)
tree22ca219acbd22e3a5e0e5e71f41612b7207c7036
parentd50a7c478feb4037e65fcaea453d9ecc00259dd9 (diff)
downloadcpython-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.py10
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)