Commit c9f872b0 authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-23846: Fix ProactorEventLoop._write_to_self() (GH-11566)

asyncio.ProactorEventLoop now catchs and logs send errors when the
self-pipe is full: BaseProactorEventLoop._write_to_self() now catchs
and logs OSError exceptions, as done by
BaseSelectorEventLoop._write_to_self().
parent 3607ef43
...@@ -636,7 +636,13 @@ class BaseProactorEventLoop(base_events.BaseEventLoop): ...@@ -636,7 +636,13 @@ class BaseProactorEventLoop(base_events.BaseEventLoop):
f.add_done_callback(self._loop_self_reading) f.add_done_callback(self._loop_self_reading)
def _write_to_self(self): def _write_to_self(self):
try:
self._csock.send(b'\0') self._csock.send(b'\0')
except OSError:
if self._debug:
logger.debug("Fail to write a null byte into the "
"self-pipe socket",
exc_info=True)
def _start_serving(self, protocol_factory, sock, def _start_serving(self, protocol_factory, sock,
sslcontext=None, server=None, backlog=100, sslcontext=None, server=None, backlog=100,
......
:class:`asyncio.ProactorEventLoop` now catchs and logs send errors when the
self-pipe is full.
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