Commit 4737b923 authored by Zackery Spytz's avatar Zackery Spytz Committed by Andrew Svetlov

bpo-24638: Improve the error message in asyncio.ensure_future() (#12848)

parent ceb842e1
...@@ -628,7 +628,8 @@ def ensure_future(coro_or_future, *, loop=None): ...@@ -628,7 +628,8 @@ def ensure_future(coro_or_future, *, loop=None):
return task return task
elif futures.isfuture(coro_or_future): elif futures.isfuture(coro_or_future):
if loop is not None and loop is not futures._get_loop(coro_or_future): if loop is not None and loop is not futures._get_loop(coro_or_future):
raise ValueError('loop argument must agree with Future') raise ValueError('The future belongs to a different loop than '
'the one specified as the loop argument')
return coro_or_future return coro_or_future
elif inspect.isawaitable(coro_or_future): elif inspect.isawaitable(coro_or_future):
return ensure_future(_wrap_awaitable(coro_or_future), loop=loop) return ensure_future(_wrap_awaitable(coro_or_future), loop=loop)
......
...@@ -236,6 +236,15 @@ class BaseTaskTests: ...@@ -236,6 +236,15 @@ class BaseTaskTests:
with self.assertRaises(TypeError): with self.assertRaises(TypeError):
asyncio.ensure_future('ok') asyncio.ensure_future('ok')
def test_ensure_future_error_msg(self):
loop = asyncio.new_event_loop()
f = self.new_future(self.loop)
with self.assertRaisesRegex(ValueError, 'The future belongs to a '
'different loop than the one specified as '
'the loop argument'):
asyncio.ensure_future(f, loop=loop)
loop.close()
def test_get_stack(self): def test_get_stack(self):
T = None T = None
......
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