summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgrzgrzgrz3 <grzgrzgrz3@gmail.com>2017-05-25 16:22:57 +0200
committerAntoine Pitrou <pitrou@free.fr>2017-05-25 16:22:57 +0200
commitbc50f03db4f58c869b78e98468e374d7e61f1227 (patch)
tree432d3da98baf4590ccf03e2a6ddb4e797a363fab
parent7ff1e88a57a37a4cca3af9b0a3528b703d975ea2 (diff)
downloadcpython-git-bc50f03db4f58c869b78e98468e374d7e61f1227.tar.gz
bpo-30414: multiprocessing.Queue._feed do not break from main loop on exc (#1683)
* bpo-30414: multiprocesing.Queue._feed do not break from main loop on exc Queue background running thread was not handling exceptions correctly. Any exception occurred inside thread (putting unpickable object) cause feeder to finish running. After that every message put into queue is silently ignored. * bpo-30414: multiprocesing.Queue._feed do not break from main loop on exc Queue background running thread was not handling exceptions correctly. Any exception occurred inside thread (putting unpickable object) cause feeder to finish running. After that every message put into queue is silently ignored.
-rw-r--r--Lib/multiprocessing/queues.py22
-rw-r--r--Lib/test/_test_multiprocessing.py14
-rw-r--r--Misc/NEWS3
3 files changed, 27 insertions, 12 deletions
diff --git a/Lib/multiprocessing/queues.py b/Lib/multiprocessing/queues.py
index a4f4ef8b7b..7f77837a74 100644
--- a/Lib/multiprocessing/queues.py
+++ b/Lib/multiprocessing/queues.py
@@ -221,8 +221,8 @@ class Queue(object):
else:
wacquire = None
- try:
- while 1:
+ while 1:
+ try:
nacquire()
try:
if not buffer:
@@ -249,21 +249,19 @@ class Queue(object):
wrelease()
except IndexError:
pass
- except Exception as e:
- if ignore_epipe and getattr(e, 'errno', 0) == errno.EPIPE:
- return
- # Since this runs in a daemon thread the resources it uses
- # may be become unusable while the process is cleaning up.
- # We ignore errors which happen after the process has
- # started to cleanup.
- try:
+ except Exception as e:
+ if ignore_epipe and getattr(e, 'errno', 0) == errno.EPIPE:
+ return
+ # Since this runs in a daemon thread the resources it uses
+ # may be become unusable while the process is cleaning up.
+ # We ignore errors which happen after the process has
+ # started to cleanup.
if is_exiting():
info('error in queue thread: %s', e)
+ return
else:
import traceback
traceback.print_exc()
- except Exception:
- pass
_sentinel = object()
diff --git a/Lib/test/_test_multiprocessing.py b/Lib/test/_test_multiprocessing.py
index 3eb83c59ab..f1f9367493 100644
--- a/Lib/test/_test_multiprocessing.py
+++ b/Lib/test/_test_multiprocessing.py
@@ -752,6 +752,20 @@ class _TestQueue(BaseTestCase):
# Windows (usually 15.6 ms)
self.assertGreaterEqual(delta, 0.170)
+ def test_queue_feeder_donot_stop_onexc(self):
+ # bpo-30414: verify feeder handles exceptions correctly
+ if self.TYPE != 'processes':
+ self.skipTest('test not appropriate for {}'.format(self.TYPE))
+
+ class NotSerializable(object):
+ def __reduce__(self):
+ raise AttributeError
+ with test.support.captured_stderr():
+ q = self.Queue()
+ q.put(NotSerializable())
+ q.put(True)
+ self.assertTrue(q.get(timeout=0.1))
+
#
#
#
diff --git a/Misc/NEWS b/Misc/NEWS
index 47bfdabb53..98d508a34d 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -341,6 +341,9 @@ Extension Modules
Library
-------
+- bpo-30414: multiprocessing.Queue._feed background running
+ thread do not break from main loop on exception.
+
- bpo-30003: Fix handling escape characters in HZ codec. Based on patch
by Ma Lin.