]> git.ipfire.org Git - thirdparty/Python/cpython.git/commit
[3.13] gh-143650: Fix importlib race condition on import failure (GH-143651) (#144697)
authorGregory P. Smith <68491+gpshead@users.noreply.github.com>
Wed, 11 Feb 2026 06:37:25 +0000 (22:37 -0800)
committerGitHub <noreply@github.com>
Wed, 11 Feb 2026 06:37:25 +0000 (06:37 +0000)
commitc117ef1a1c3940a22caa9c95f426e03547f48160
treeef710b24027cbbbc9db42fadbaf7f693c30f1086
parent36aa0815cac736e3e56bda7eed5c48a95ebdb85d
[3.13] gh-143650: Fix importlib race condition on import failure (GH-143651) (#144697)

gh-143650: Fix importlib race condition on import failure (GH-143651)

Fix a race condition where a thread could receive a partially-initialized
module when another thread's import fails. The race occurs when:

1. Thread 1 starts importing, adds module to sys.modules
2. Thread 2 sees the module in sys.modules via the fast path
3. Thread 1's import fails, removes module from sys.modules
4. Thread 2 returns a stale module reference not in sys.modules

The fix adds verification after the "skip lock" optimization in both Python
and C code paths to check if the module is still in sys.modules. If the
module was removed (due to import failure), we retry the import so the
caller receives the actual exception from the import failure rather than
a stale module reference.

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
cherry picked from ac8b5b6890006ee7254ea878866cb486ff835ecb
Lib/importlib/_bootstrap.py
Lib/test/test_importlib/test_threaded_import.py
Misc/NEWS.d/next/Core and Builtins/2026-01-10-10-58-36.gh-issue-143650.k8mR4x.rst [new file with mode: 0644]
Python/import.c