summaryrefslogtreecommitdiff
path: root/tests/extmod/utime_res.py
diff options
context:
space:
mode:
authorOliver Joos <oliver.joos@feller.ch>2020-12-16 21:25:18 +0100
committerDamien George <damien@micropython.org>2021-01-23 16:54:57 +1100
commit419134bea47953888344d325220c376117f6b2b4 (patch)
tree0eb0816c75fef53a8e6081939423d2bfd571ad5a /tests/extmod/utime_res.py
parent769e822f190b2ae3c67a6612b7141a54920a19bf (diff)
tests/extmod: Add test for the precision of utime functions.
According to documentation time() has a precision of at least 1 second. This test runs for 2.5 seconds and calls all utime functions every 100ms. Then it checks if they returned enough different results. All functions with sub-second precision will return ~25 results. This test passes with 15 results or more. Functions that do not exist are skipped silently.
Diffstat (limited to 'tests/extmod/utime_res.py')
-rw-r--r--tests/extmod/utime_res.py65
1 files changed, 65 insertions, 0 deletions
diff --git a/tests/extmod/utime_res.py b/tests/extmod/utime_res.py
new file mode 100644
index 000000000..4b6243348
--- /dev/null
+++ b/tests/extmod/utime_res.py
@@ -0,0 +1,65 @@
+# test utime resolutions
+
+try:
+ import utime
+except ImportError:
+ print("SKIP")
+ raise SystemExit
+
+
+def gmtime_time():
+ return utime.gmtime(utime.time())
+
+
+def localtime_time():
+ return utime.localtime(utime.time())
+
+
+def test():
+ TEST_TIME = 2500
+ EXPECTED_MAP = (
+ # (function name, min. number of results in 2.5 sec)
+ ("time", 3),
+ ("gmtime", 3),
+ ("localtime", 3),
+ ("gmtime_time", 3),
+ ("localtime_time", 3),
+ ("ticks_ms", 15),
+ ("ticks_us", 15),
+ ("ticks_ns", 15),
+ ("ticks_cpu", 15),
+ )
+
+ # call time functions
+ results_map = {}
+ end_time = utime.ticks_ms() + TEST_TIME
+ while utime.ticks_diff(end_time, utime.ticks_ms()) > 0:
+ utime.sleep_ms(100)
+ for func_name, _ in EXPECTED_MAP:
+ try:
+ time_func = getattr(utime, func_name, None) or globals()[func_name]
+ now = time_func() # may raise AttributeError
+ except (KeyError, AttributeError):
+ continue
+ try:
+ results_map[func_name].add(now)
+ except KeyError:
+ results_map[func_name] = {now}
+
+ # check results
+ for func_name, min_len in EXPECTED_MAP:
+ print("Testing %s" % func_name)
+ results = results_map.get(func_name)
+ if results is None:
+ pass
+ elif func_name == "ticks_cpu" and results == {0}:
+ # ticks_cpu() returns 0 on some ports (e.g. unix)
+ pass
+ elif len(results) < min_len:
+ print(
+ "%s() returns %s result%s in %s ms, expecting >= %s"
+ % (func_name, len(results), "s"[: len(results) != 1], TEST_TIME, min_len)
+ )
+
+
+test()