forked from iree-org/iree-llvm-sandbox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_tests.py
70 lines (67 loc) · 2.23 KB
/
run_tests.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/usr/bin/env python
# Script to run tests and benchmarks.
import glob
import os
import subprocess
import sys
def _convert_path_to_module(test_script : str) -> str:
"""Convert the path of the test script to its module name."""
test_script = test_script.replace(os.sep, ".")
test_script = test_script.strip(".")
if test_script.endswith(".py"):
return test_script[:-3]
return test_script
def _run_test(test_script: str) -> bool:
"""Run the provided test script an return failure or success.
A test succeeds if:
- it does not time out
- it returns zero
- it does not print FAILURE
"""
print(f"- running {test_script}: ", end="")
module = _convert_path_to_module(test_script)
env = os.environ
build_dir = env["IREE_LLVM_SANDBOX_BUILD_DIR"]
env["PYTHONPATH"] = os.path.join(build_dir, "tools/sandbox/python_package")
env["MLIR_RUNNER_UTILS_LIB"] = os.path.join(
build_dir, "lib/libmlir_runner_utils.so")
proc = subprocess.Popen(["python", "-m", module],
stdout=subprocess.PIPE, stderr=subprocess.PIPE,
env=env)
try:
outs, errs = proc.communicate(timeout=20)
except subprocess.TimeoutExpired:
proc.kill()
print("\033[31m" + "FAILED" + "\033[m")
print(" -> test execution timed out")
return False
if proc.returncode != 0:
print("\033[31m" + "FAILED" + "\033[m")
print(f" -> test returned code {proc.returncode}")
return False
# Check the output for numerical failures.
outs = outs.decode("utf-8")
errs = errs.decode("utf-8")
for line in outs.splitlines() + errs.splitlines():
if line.count("FAILURE") != 0:
print("\033[31m" + "FAILED" + "\033[m")
print(f" -> test failure: {line}")
return False
print("\033[32m" + "SUCCESS" + "\033[m")
return True
def main():
results = []
for f in glob.glob("./python/**/*test.py", recursive=True):
results.append(_run_test(f))
errors = results.count(False)
if errors:
print(f"-> {errors} tests failed!")
# Additionally run the lit tests.
print(f"- running lit tests:")
returncode = subprocess.call(["lit", "-v", "test"])
if returncode != 0:
print(f"-> lit tests failed!")
if returncode != 0 or errors:
exit(1)
if __name__ == '__main__':
main()