Equivalent to calling ``get_event_loop_policy().new_event_loop()``.
+.. function:: get_running_loop()
+
+ Return the running event loop in the current OS thread. If there
+ is no running event loop a :exc:`RuntimeError` is raised.
+
+ .. versionadded:: 3.7
+
.. _asyncio-event-loops:
'get_event_loop_policy', 'set_event_loop_policy',
'get_event_loop', 'set_event_loop', 'new_event_loop',
'get_child_watcher', 'set_child_watcher',
- '_set_running_loop', '_get_running_loop',
+ '_set_running_loop', 'get_running_loop',
+ '_get_running_loop',
)
import functools
_running_loop = _RunningLoop()
+def get_running_loop():
+ """Return the running event loop. Raise a RuntimeError if there is none.
+
+ This function is thread-specific.
+ """
+ loop = _get_running_loop()
+ if loop is None:
+ raise RuntimeError('no running event loop')
+ return loop
+
+
def _get_running_loop():
"""Return the running event loop or None.
try:
asyncio.set_event_loop_policy(Policy())
loop = asyncio.new_event_loop()
+ with self.assertRaisesRegex(RuntimeError, 'no running'):
+ self.assertIs(asyncio.get_running_loop(), None)
self.assertIs(asyncio._get_running_loop(), None)
async def func():
self.assertIs(asyncio.get_event_loop(), loop)
+ self.assertIs(asyncio.get_running_loop(), loop)
self.assertIs(asyncio._get_running_loop(), loop)
loop.run_until_complete(func())
if loop is not None:
loop.close()
+ with self.assertRaisesRegex(RuntimeError, 'no running'):
+ self.assertIs(asyncio.get_running_loop(), None)
+
self.assertIs(asyncio._get_running_loop(), None)
--- /dev/null
+Add asyncio.get_running_loop() function.