diff options
| author | Charles-François Natali <cf.natali@gmail.com> | 2013-08-30 23:32:53 +0200 | 
|---|---|---|
| committer | Charles-François Natali <cf.natali@gmail.com> | 2013-08-30 23:32:53 +0200 | 
| commit | 9939cc89a4ee54ab50719a597a8b8a0795a691f6 (patch) | |
| tree | dc42155f1d67de7d96c2f3938cda274b5e6da11a /Lib/test/test_threading.py | |
| parent | dee0434e2fb030df448770199627e87c9e06a6bf (diff) | |
| download | cpython-git-9939cc89a4ee54ab50719a597a8b8a0795a691f6.tar.gz | |
Issue #18418: After fork(), reinit all threads states, not only active ones.
Patch by A. Jesse Jiryu Davis.
Diffstat (limited to 'Lib/test/test_threading.py')
| -rw-r--r-- | Lib/test/test_threading.py | 21 | 
1 files changed, 21 insertions, 0 deletions
| diff --git a/Lib/test/test_threading.py b/Lib/test/test_threading.py index 79967dc0cf..bd019cddd3 100644 --- a/Lib/test/test_threading.py +++ b/Lib/test/test_threading.py @@ -444,6 +444,27 @@ class ThreadTests(BaseTestCase):          self.assertEqual(out, b'')          self.assertEqual(err, b'') +    @unittest.skipUnless(hasattr(os, 'fork'), "needs os.fork()") +    def test_is_alive_after_fork(self): +        # Try hard to trigger #18418: is_alive() could sometimes be True on +        # threads that vanished after a fork. +        old_interval = sys.getswitchinterval() +        self.addCleanup(sys.setswitchinterval, old_interval) + +        # Make the bug more likely to manifest. +        sys.setswitchinterval(1e-6) + +        for i in range(20): +            t = threading.Thread(target=lambda: None) +            t.start() +            self.addCleanup(t.join) +            pid = os.fork() +            if pid == 0: +                os._exit(1 if t.is_alive() else 0) +            else: +                pid, status = os.waitpid(pid, 0) +                self.assertEqual(0, status) +  class ThreadJoinOnShutdown(BaseTestCase): | 
