mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
gh-116631: Fix race condition in test_shutdown_immediate_put_join
(#116670)
The test case had a race condition: if `q.task_done()` was executed after `shutdown(immediate=True)`, then it would raise an exception because the immediate shutdown already emptied the queue. This happened rarely with the GIL (due to the switching interval), but frequently in the free-threaded build.
This commit is contained in:
parent
25684e7131
commit
98ab21cce6
1 changed files with 11 additions and 6 deletions
|
@ -567,7 +567,6 @@ class BaseQueueTestMixin(BlockingTestMixin):
|
|||
results = []
|
||||
go = threading.Event()
|
||||
q.put("Y")
|
||||
nb = q.qsize()
|
||||
# queue not fulled
|
||||
|
||||
thrds = (
|
||||
|
@ -578,13 +577,19 @@ class BaseQueueTestMixin(BlockingTestMixin):
|
|||
for func, params in thrds:
|
||||
threads.append(threading.Thread(target=func, args=params))
|
||||
threads[-1].start()
|
||||
self.assertEqual(q.unfinished_tasks, nb)
|
||||
for i in range(nb):
|
||||
t = threading.Thread(target=q.task_done)
|
||||
t.start()
|
||||
threads.append(t)
|
||||
self.assertEqual(q.unfinished_tasks, 1)
|
||||
|
||||
q.shutdown(immediate)
|
||||
go.set()
|
||||
|
||||
if immediate:
|
||||
with self.assertRaises(self.queue.ShutDown):
|
||||
q.get_nowait()
|
||||
else:
|
||||
result = q.get()
|
||||
self.assertEqual(result, "Y")
|
||||
q.task_done()
|
||||
|
||||
for t in threads:
|
||||
t.join()
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue