2019-11-13 21:08:22 +11:00
|
|
|
# test uasyncio.gather() function
|
|
|
|
|
|
|
|
try:
|
|
|
|
import uasyncio as asyncio
|
|
|
|
except ImportError:
|
|
|
|
try:
|
|
|
|
import asyncio
|
|
|
|
except ImportError:
|
|
|
|
print("SKIP")
|
|
|
|
raise SystemExit
|
|
|
|
|
|
|
|
|
|
|
|
async def factorial(name, number):
|
|
|
|
f = 1
|
|
|
|
for i in range(2, number + 1):
|
|
|
|
print("Task {}: Compute factorial({})...".format(name, i))
|
|
|
|
await asyncio.sleep(0.01)
|
|
|
|
f *= i
|
|
|
|
print("Task {}: factorial({}) = {}".format(name, number, f))
|
|
|
|
return f
|
|
|
|
|
|
|
|
|
|
|
|
async def task(id):
|
|
|
|
print("start", id)
|
2021-11-17 13:45:42 +11:00
|
|
|
await asyncio.sleep(0.02)
|
2019-11-13 21:08:22 +11:00
|
|
|
print("end", id)
|
2021-11-17 13:45:42 +11:00
|
|
|
return id
|
2019-11-13 21:08:22 +11:00
|
|
|
|
|
|
|
|
|
|
|
async def gather_task():
|
|
|
|
print("gather_task")
|
|
|
|
await asyncio.gather(task(1), task(2))
|
|
|
|
print("gather_task2")
|
|
|
|
|
|
|
|
|
|
|
|
async def main():
|
|
|
|
# Simple gather with return values
|
2020-08-29 15:14:29 +10:00
|
|
|
print(await asyncio.gather(factorial("A", 2), factorial("B", 3), factorial("C", 4)))
|
2019-11-13 21:08:22 +11:00
|
|
|
|
2021-11-17 13:45:42 +11:00
|
|
|
# Test return_exceptions, where one task is cancelled and the other finishes normally
|
|
|
|
tasks = [asyncio.create_task(task(1)), asyncio.create_task(task(2))]
|
|
|
|
tasks[0].cancel()
|
|
|
|
print(await asyncio.gather(*tasks, return_exceptions=True))
|
|
|
|
|
2019-11-13 21:08:22 +11:00
|
|
|
# Cancel a multi gather
|
|
|
|
# TODO doesn't work, Task should not forward cancellation from gather to sub-task
|
|
|
|
# but rather CancelledError should cancel the gather directly, which will then cancel
|
|
|
|
# all sub-tasks explicitly
|
|
|
|
# t = asyncio.create_task(gather_task())
|
2021-11-17 13:45:42 +11:00
|
|
|
# await asyncio.sleep(0.01)
|
2019-11-13 21:08:22 +11:00
|
|
|
# t.cancel()
|
|
|
|
# await asyncio.sleep(0.01)
|
|
|
|
|
|
|
|
|
|
|
|
asyncio.run(main())
|