Commit 4652bf2a authored by Yury Selivanov's avatar Yury Selivanov Committed by GitHub

Rewrite asyncio test to be more meaningful (#4363)

parent 9f914a01
...@@ -530,20 +530,25 @@ class BaseEventLoopTests(test_utils.TestCase): ...@@ -530,20 +530,25 @@ class BaseEventLoopTests(test_utils.TestCase):
other_loop.run_until_complete, task) other_loop.run_until_complete, task)
def test_run_until_complete_loop_orphan_future_close_loop(self): def test_run_until_complete_loop_orphan_future_close_loop(self):
async def foo(sec=0): class ShowStopper(BaseException):
await asyncio.sleep(sec) pass
self.loop.close() async def foo(delay):
loop = asyncio.new_event_loop() await asyncio.sleep(delay, loop=self.loop)
asyncio.set_event_loop(loop)
def throw():
raise ShowStopper
self.loop._process_events = mock.Mock()
self.loop.call_soon(throw)
try: try:
with mock.patch('asyncio.base_events.BaseEventLoop.run_forever', self.loop.run_until_complete(foo(0.1))
side_effect=Exception): except ShowStopper:
loop.run_until_complete(foo())
except:
pass pass
loop.run_until_complete(foo(0.1))
loop.close() # This call fails if run_until_complete does not clean up
# done-callback for the previous future.
self.loop.run_until_complete(foo(0.2))
def test_subprocess_exec_invalid_args(self): def test_subprocess_exec_invalid_args(self):
args = [sys.executable, '-c', 'pass'] args = [sys.executable, '-c', 'pass']
......
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