Commit dd5aa36f authored by Antoine Pitrou's avatar Antoine Pitrou

Issue #14308: Fix an exception when a dummy thread is in the threading...

Issue #14308: Fix an exception when a dummy thread is in the threading module's active list after a fork().
parents bf35c156 8e6e0fdb
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
import test.support import test.support
from test.support import verbose, strip_python_stderr, import_module from test.support import verbose, strip_python_stderr, import_module
from test.script_helper import assert_python_ok
import random import random
import re import re
import sys import sys
...@@ -415,6 +417,33 @@ class ThreadTests(BaseTestCase): ...@@ -415,6 +417,33 @@ class ThreadTests(BaseTestCase):
t = threading.Thread(daemon=True) t = threading.Thread(daemon=True)
self.assertTrue(t.daemon) self.assertTrue(t.daemon)
@unittest.skipUnless(hasattr(os, 'fork'), 'test needs fork()')
def test_dummy_thread_after_fork(self):
# Issue #14308: a dummy thread in the active list doesn't mess up
# the after-fork mechanism.
code = """if 1:
import _thread, threading, os, time
def background_thread(evt):
# Creates and registers the _DummyThread instance
threading.current_thread()
evt.set()
time.sleep(10)
evt = threading.Event()
_thread.start_new_thread(background_thread, (evt,))
evt.wait()
assert threading.active_count() == 2, threading.active_count()
if os.fork() == 0:
assert threading.active_count() == 1, threading.active_count()
os._exit(0)
else:
os.wait()
"""
_, out, err = assert_python_ok("-c", code)
self.assertEqual(out, b'')
self.assertEqual(err, b'')
class ThreadJoinOnShutdown(BaseTestCase): class ThreadJoinOnShutdown(BaseTestCase):
......
...@@ -871,6 +871,9 @@ class _DummyThread(Thread): ...@@ -871,6 +871,9 @@ class _DummyThread(Thread):
with _active_limbo_lock: with _active_limbo_lock:
_active[self._ident] = self _active[self._ident] = self
def _stop(self):
pass
def join(self, timeout=None): def join(self, timeout=None):
assert False, "cannot join a dummy thread" assert False, "cannot join a dummy thread"
......
...@@ -55,6 +55,9 @@ Core and Builtins ...@@ -55,6 +55,9 @@ Core and Builtins
Library Library
------- -------
- Issue #14308: Fix an exception when a "dummy" thread is in the threading
module's active list after a fork().
- Issue #11750: The Windows API functions scattered in the _subprocess and - Issue #11750: The Windows API functions scattered in the _subprocess and
_multiprocessing.win32 modules now live in a single module "_winapi". _multiprocessing.win32 modules now live in a single module "_winapi".
Patch by sbt. Patch by sbt.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment