Skip to content

Commit

Permalink
00371: Revert "bpo-1596321: Fix threading._shutdown() for the main th…
Browse files Browse the repository at this point in the history
…read (pythonGH-28549) (pythonGH-28589)"

This reverts commit 94d19f6. It
introduced regression causing FreeIPA's tests to fail.

For more info see:
https://bodhi.fedoraproject.org/updates/FEDORA-2021-e152ce5f31
GrahamDumpleton/mod_wsgi#730
  • Loading branch information
hrnciar committed Jan 17, 2022
1 parent 275834f commit 8e089bc
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 50 deletions.
33 changes: 0 additions & 33 deletions Lib/test/test_threading.py
Original file line number Diff line number Diff line change
Expand Up @@ -814,39 +814,6 @@ def noop(): pass
threading.Thread(target=noop).start()
# Thread.join() is not called

def test_import_from_another_thread(self):
# bpo-1596321: If the threading module is first import from a thread
# different than the main thread, threading._shutdown() must handle
# this case without logging an error at Python exit.
code = textwrap.dedent('''
import _thread
import sys
event = _thread.allocate_lock()
event.acquire()
def import_threading():
import threading
event.release()
if 'threading' in sys.modules:
raise Exception('threading is already imported')
_thread.start_new_thread(import_threading, ())
# wait until the threading module is imported
event.acquire()
event.release()
if 'threading' not in sys.modules:
raise Exception('threading is not imported')
# don't wait until the thread completes
''')
rc, out, err = assert_python_ok("-c", code)
self.assertEqual(out, b'')
self.assertEqual(err, b'')


class ThreadJoinOnShutdown(BaseTestCase):

Expand Down
25 changes: 8 additions & 17 deletions Lib/threading.py
Original file line number Diff line number Diff line change
Expand Up @@ -1433,29 +1433,20 @@ def _shutdown():

global _SHUTTING_DOWN
_SHUTTING_DOWN = True
# Main thread
tlock = _main_thread._tstate_lock
# The main thread isn't finished yet, so its thread state lock can't have
# been released.
assert tlock is not None
assert tlock.locked()
tlock.release()
_main_thread._stop()

# Call registered threading atexit functions before threads are joined.
# Order is reversed, similar to atexit.
for atexit_call in reversed(_threading_atexits):
atexit_call()

# Main thread
if _main_thread.ident == get_ident():
tlock = _main_thread._tstate_lock
# The main thread isn't finished yet, so its thread state lock can't
# have been released.
assert tlock is not None
assert tlock.locked()
tlock.release()
_main_thread._stop()
else:
# bpo-1596321: _shutdown() must be called in the main thread.
# If the threading module was not imported by the main thread,
# _main_thread is the thread which imported the threading module.
# In this case, ignore _main_thread, similar behavior than for threads
# spawned by C libraries or using _thread.start_new_thread().
pass

# Join all non-deamon threads
while True:
with _shutdown_locks_lock:
Expand Down

0 comments on commit 8e089bc

Please sign in to comment.