Commit 1b7863c3 authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-30595: Fix multiprocessing.Queue.get(timeout) (#2027)

multiprocessing.Queue.get() with a timeout now polls its reader in
non-blocking mode if it succeeded to aquire the lock but the acquire
took longer than the timeout.
Co-Authored-By: default avatarGrzegorz Grzywacz <grzgrzgrz3@gmail.com>
parent 5f31d5cf
...@@ -101,7 +101,7 @@ class Queue(object): ...@@ -101,7 +101,7 @@ class Queue(object):
try: try:
if block: if block:
timeout = deadline - time.time() timeout = deadline - time.time()
if timeout < 0 or not self._poll(timeout): if not self._poll(timeout):
raise Empty raise Empty
elif not self._poll(): elif not self._poll():
raise Empty raise Empty
......
...@@ -350,6 +350,10 @@ Extension Modules ...@@ -350,6 +350,10 @@ Extension Modules
Library Library
------- -------
- bpo-30595: multiprocessing.Queue.get() with a timeout now polls its reader in
non-blocking mode if it succeeded to aquire the lock but the acquire took
longer than the timeout.
- bpo-30605: re.compile() no longer raises a BytesWarning when compiling a - bpo-30605: re.compile() no longer raises a BytesWarning when compiling a
bytes instance with misplaced inline modifier. Patch by Roy Williams. bytes instance with misplaced inline modifier. Patch by Roy Williams.
......
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