import functools
import inspect
+import os
import reprlib
import socket
import subprocess
# A TLS for the running event loop, used by _get_running_loop.
class _RunningLoop(threading.local):
_loop = None
+ _pid = None
+
+
_running_loop = _RunningLoop()
This is a low-level function intended to be used by event loops.
This function is thread-specific.
"""
- return _running_loop._loop
+ if _running_loop._pid == os.getpid():
+ return _running_loop._loop
def _set_running_loop(loop):
This is a low-level function intended to be used by event loops.
This function is thread-specific.
"""
+ _running_loop._pid = os.getpid()
_running_loop._loop = loop
self.set_event_loop(loop)
return loop
+ def unpatch_get_running_loop(self):
+ events._get_running_loop = self._get_running_loop
+
def setUp(self):
self._get_running_loop = events._get_running_loop
events._get_running_loop = lambda: None
def tearDown(self):
- events._get_running_loop = self._get_running_loop
+ self.unpatch_get_running_loop()
events.set_event_loop(None)
"""Tests for events.py."""
import collections.abc
+import concurrent.futures
import functools
import gc
import io
return version < (10, 5)
+def _test_get_event_loop_new_process__sub_proc():
+ async def doit():
+ return 'hello'
+
+ loop = asyncio.new_event_loop()
+ asyncio.set_event_loop(loop)
+ return loop.run_until_complete(doit())
+
+
ONLYCERT = data_file('ssl_cert.pem')
ONLYKEY = data_file('ssl_key.pem')
SIGNED_CERTFILE = data_file('keycert3.pem')
asyncio.set_child_watcher(None)
super().tearDown()
+ def test_get_event_loop_new_process(self):
+ async def main():
+ pool = concurrent.futures.ProcessPoolExecutor()
+ return await self.loop.run_in_executor(
+ pool, _test_get_event_loop_new_process__sub_proc)
+
+ self.unpatch_get_running_loop()
+
+ self.assertEqual(
+ self.loop.run_until_complete(main()),
+ 'hello')
+
if hasattr(selectors, 'KqueueSelector'):
class KqueueEventLoopTests(UnixEventLoopTestsMixin,
SubprocessTestsMixin,
Library
-------
+- bpo-29703: Fix asyncio to support instantiation of new event loops
+ in child processes.
+
- bpo-29376: Fix assertion error in threading._DummyThread.is_alive().
- bpo-29110: Fix file object leak in aifc.open() when file is given as a