diff options
author | Jim Mussared <jim.mussared@gmail.com> | 2023-06-08 16:01:38 +1000 |
---|---|---|
committer | Damien George <damien@micropython.org> | 2023-06-19 17:33:03 +1000 |
commit | 6027c41c8f5b8f1a9e7b85b2bb93b3e6f2718e54 (patch) | |
tree | 08f41a4d0cd48fa5c0bc49519832ac2faba6923a /tests/extmod/asyncio_micropython.py | |
parent | 2fbc08c462e247e7f78460783c9a07c76c5b762e (diff) | |
download | micropython-6027c41c8f5b8f1a9e7b85b2bb93b3e6f2718e54.tar.gz micropython-6027c41c8f5b8f1a9e7b85b2bb93b3e6f2718e54.zip |
tests: Rename uasyncio to asyncio.
This work was funded through GitHub Sponsors.
Signed-off-by: Jim Mussared <jim.mussared@gmail.com>
Diffstat (limited to 'tests/extmod/asyncio_micropython.py')
-rw-r--r-- | tests/extmod/asyncio_micropython.py | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/tests/extmod/asyncio_micropython.py b/tests/extmod/asyncio_micropython.py new file mode 100644 index 0000000000..cc96d34be2 --- /dev/null +++ b/tests/extmod/asyncio_micropython.py @@ -0,0 +1,43 @@ +# Test MicroPython extensions on CPython asyncio: +# - sleep_ms +# - wait_for_ms + +try: + import time, asyncio +except ImportError: + print("SKIP") + raise SystemExit + + +async def task(id, t): + print("task start", id) + await asyncio.sleep_ms(t) + print("task end", id) + return id * 2 + + +async def main(): + # Simple sleep_ms + t0 = time.ticks_ms() + await asyncio.sleep_ms(1) + print(time.ticks_diff(time.ticks_ms(), t0) < 100) + + try: + # Sleep 1ms beyond maximum allowed sleep value + await asyncio.sleep_ms(time.ticks_add(0, -1) // 2 + 1) + except OverflowError: + print("OverflowError") + + # When task finished before the timeout + print(await asyncio.wait_for_ms(task(1, 5), 50)) + + # When timeout passes and task is cancelled + try: + print(await asyncio.wait_for_ms(task(2, 50), 5)) + except asyncio.TimeoutError: + print("timeout") + + print("finish") + + +asyncio.run(main()) |