2014-05-05 01:24:16 +03:00
|
|
|
#! /usr/bin/env python3
|
|
|
|
|
|
|
|
import os
|
|
|
|
import subprocess
|
|
|
|
import sys
|
|
|
|
import argparse
|
|
|
|
import re
|
|
|
|
from glob import glob
|
|
|
|
from collections import defaultdict
|
|
|
|
|
|
|
|
# Tests require at least CPython 3.3. If your default python3 executable
|
|
|
|
# is of lower version, you can point MICROPY_CPYTHON3 environment var
|
|
|
|
# to the correct executable.
|
|
|
|
if os.name == "nt":
|
|
|
|
CPYTHON3 = os.getenv("MICROPY_CPYTHON3", "python3.exe")
|
2022-11-29 16:58:21 +01:00
|
|
|
MICROPYTHON = os.getenv(
|
|
|
|
"MICROPY_MICROPYTHON", "../ports/windows/build-standard/micropython.exe"
|
|
|
|
)
|
2014-05-05 01:24:16 +03:00
|
|
|
else:
|
|
|
|
CPYTHON3 = os.getenv("MICROPY_CPYTHON3", "python3")
|
2022-08-18 11:46:53 +10:00
|
|
|
MICROPYTHON = os.getenv("MICROPY_MICROPYTHON", "../ports/unix/build-standard/micropython")
|
2020-03-22 21:26:08 -05:00
|
|
|
|
2014-05-05 01:24:16 +03:00
|
|
|
|
|
|
|
def run_tests(pyb, test_dict):
|
|
|
|
test_count = 0
|
|
|
|
testcase_count = 0
|
|
|
|
|
2016-05-01 10:34:18 +03:00
|
|
|
for base_test, tests in sorted(test_dict.items()):
|
2014-05-05 01:24:16 +03:00
|
|
|
print(base_test + ":")
|
|
|
|
for test_file in tests:
|
2017-06-30 09:22:17 +02:00
|
|
|
# run MicroPython
|
2014-05-05 01:24:16 +03:00
|
|
|
if pyb is None:
|
|
|
|
# run on PC
|
|
|
|
try:
|
|
|
|
output_mupy = subprocess.check_output(
|
|
|
|
[MICROPYTHON, "-X", "emit=bytecode", test_file[0]]
|
|
|
|
)
|
|
|
|
except subprocess.CalledProcessError:
|
|
|
|
output_mupy = b"CRASH"
|
|
|
|
else:
|
|
|
|
# run on pyboard
|
|
|
|
pyb.enter_raw_repl()
|
|
|
|
try:
|
|
|
|
output_mupy = pyb.execfile(test_file).replace(b"\r\n", b"\n")
|
|
|
|
except pyboard.PyboardError:
|
|
|
|
output_mupy = b"CRASH"
|
|
|
|
|
|
|
|
output_mupy = float(output_mupy.strip())
|
|
|
|
test_file[1] = output_mupy
|
|
|
|
testcase_count += 1
|
|
|
|
|
|
|
|
test_count += 1
|
|
|
|
baseline = None
|
|
|
|
for t in tests:
|
|
|
|
if baseline is None:
|
|
|
|
baseline = t[1]
|
|
|
|
print(" %.3fs (%+06.2f%%) %s" % (t[1], (t[1] * 100 / baseline) - 100, t[0]))
|
|
|
|
|
|
|
|
print("{} tests performed ({} individual testcases)".format(test_count, testcase_count))
|
|
|
|
|
|
|
|
# all tests succeeded
|
|
|
|
return True
|
|
|
|
|
2020-03-22 21:26:08 -05:00
|
|
|
|
2014-05-05 01:24:16 +03:00
|
|
|
def main():
|
2015-10-12 00:06:25 +01:00
|
|
|
cmd_parser = argparse.ArgumentParser(description="Run tests for MicroPython.")
|
2014-05-05 01:24:16 +03:00
|
|
|
cmd_parser.add_argument("--pyboard", action="store_true", help="run the tests on the pyboard")
|
|
|
|
cmd_parser.add_argument("files", nargs="*", help="input test files")
|
|
|
|
args = cmd_parser.parse_args()
|
|
|
|
|
2021-03-11 16:09:27 +11:00
|
|
|
# Note pyboard support is copied over from run-tests.py, not tests, and likely needs revamping
|
2014-05-05 01:24:16 +03:00
|
|
|
if args.pyboard:
|
|
|
|
import pyboard
|
2020-03-22 21:26:08 -05:00
|
|
|
|
2014-05-05 01:24:16 +03:00
|
|
|
pyb = pyboard.Pyboard("/dev/ttyACM0")
|
|
|
|
pyb.enter_raw_repl()
|
|
|
|
else:
|
|
|
|
pyb = None
|
|
|
|
|
|
|
|
if len(args.files) == 0:
|
|
|
|
if pyb is None:
|
|
|
|
# run PC tests
|
2019-06-18 23:44:16 +10:00
|
|
|
test_dirs = ("internal_bench",)
|
2014-05-05 01:24:16 +03:00
|
|
|
else:
|
|
|
|
# run pyboard tests
|
|
|
|
test_dirs = ("basics", "float", "pyb")
|
|
|
|
tests = sorted(
|
|
|
|
test_file
|
|
|
|
for test_files in (glob("{}/*.py".format(dir)) for dir in test_dirs)
|
|
|
|
for test_file in test_files
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
# tests explicitly given
|
|
|
|
tests = sorted(args.files)
|
|
|
|
|
|
|
|
test_dict = defaultdict(lambda: [])
|
|
|
|
for t in tests:
|
|
|
|
m = re.match(r"(.+?)-(.+)\.py", t)
|
|
|
|
if not m:
|
|
|
|
continue
|
|
|
|
test_dict[m.group(1)].append([t, None])
|
|
|
|
|
|
|
|
if not run_tests(pyb, test_dict):
|
|
|
|
sys.exit(1)
|
|
|
|
|
2020-03-22 21:26:08 -05:00
|
|
|
|
2014-05-05 01:24:16 +03:00
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|