summaryrefslogtreecommitdiffstatshomepage
path: root/tests/extmod/uasyncio_basic.py
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2019-11-13 21:08:22 +1100
committerDamien George <damien.p.george@gmail.com>2020-03-26 01:25:45 +1100
commitc4935f30490d0446e16a51dbf7a6397b771cf804 (patch)
treeb095dd91914950939d4d0cdc10e7be3625fff00d /tests/extmod/uasyncio_basic.py
parent63b99443820f53afbdab5201044629d2bfecd73b (diff)
downloadmicropython-c4935f30490d0446e16a51dbf7a6397b771cf804.tar.gz
micropython-c4935f30490d0446e16a51dbf7a6397b771cf804.zip
tests/extmod: Add uasyncio tests.
All .exp files are included because they require CPython 3.8 which may not always be available.
Diffstat (limited to 'tests/extmod/uasyncio_basic.py')
-rw-r--r--tests/extmod/uasyncio_basic.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/tests/extmod/uasyncio_basic.py b/tests/extmod/uasyncio_basic.py
new file mode 100644
index 0000000000..f6685fa674
--- /dev/null
+++ b/tests/extmod/uasyncio_basic.py
@@ -0,0 +1,43 @@
+try:
+ import uasyncio as asyncio
+except ImportError:
+ try:
+ import asyncio
+ except ImportError:
+ print("SKIP")
+ raise SystemExit
+
+
+try:
+ import utime
+
+ ticks = utime.ticks_ms
+ ticks_diff = utime.ticks_diff
+except:
+ import time
+
+ ticks = lambda: int(time.time() * 1000)
+ ticks_diff = lambda t1, t0: t1 - t0
+
+
+async def delay_print(t, s):
+ await asyncio.sleep(t)
+ print(s)
+
+
+async def main():
+ print("start")
+
+ await asyncio.sleep(0.001)
+ print("after sleep")
+
+ t0 = ticks()
+ await delay_print(0.02, "short")
+ t1 = ticks()
+ await delay_print(0.04, "long")
+ t2 = ticks()
+
+ print("took {} {}".format(round(ticks_diff(t1, t0), -1), round(ticks_diff(t2, t1), -1)))
+
+
+asyncio.run(main())