summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_asyncio
diff options
context:
space:
mode:
authorYury Selivanov <yselivanov@gmail.com>2017-03-03 01:07:11 (GMT)
committerGitHub <noreply@github.com>2017-03-03 01:07:11 (GMT)
commitba7e1f9a4e06c0b4ad594fd64edcaf7292515820 (patch)
tree97e42c3e5ec67118d5953fcf3c86a0254340bcd1 /Lib/test/test_asyncio
parentcdf037c212675b11c10c4d0d76496f5d81154882 (diff)
downloadcpython-ba7e1f9a4e06c0b4ad594fd64edcaf7292515820.zip
cpython-ba7e1f9a4e06c0b4ad594fd64edcaf7292515820.tar.gz
cpython-ba7e1f9a4e06c0b4ad594fd64edcaf7292515820.tar.bz2
bpo-29703: asyncio: Fix creating new event loops in child processes. (#404)
Diffstat (limited to 'Lib/test/test_asyncio')
-rw-r--r--Lib/test/test_asyncio/test_events.py22
1 files changed, 22 insertions, 0 deletions
diff --git a/Lib/test/test_asyncio/test_events.py b/Lib/test/test_asyncio/test_events.py
index 28d92a9..802763b 100644
--- a/Lib/test/test_asyncio/test_events.py
+++ b/Lib/test/test_asyncio/test_events.py
@@ -1,6 +1,7 @@
"""Tests for events.py."""
import collections.abc
+import concurrent.futures
import functools
import gc
import io
@@ -57,6 +58,15 @@ def osx_tiger():
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')
@@ -2181,6 +2191,18 @@ else:
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,