-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathevaluate_tests.py
27 lines (26 loc) · 1.1 KB
/
evaluate_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
import re
import subprocess
import sys
if __name__ == '__main__':
try:
# run the actual tests, this assumes the tests will run in less than 5 seconds.
# as the number of tests grows, the timeout will need to be increased
# this is done this way because the tests run in a VM, so they are hard to get the
# exit code from, so we timeout and read the logs to find the results
subprocess.run(['make', 'run-arm', '>', 'test_log.txt'], timeout=5)
except subprocess.TimeoutExpired as e:
# we are expecting the tests to timeout, ignore this error and get the status from the logs
pass
with open('test_log.txt') as test_log:
logs = test_log.read();
print(logs)
tests_results = re.search(r'([0-9]*) Tests ([0-9]*) Failures ([0-9]*) Ignored', logs)
if tests_results is None:
print('could not find test results line')
sys.exit(1)
failures = tests_results.group(2)
print('found {} failures'.format(failures))
if (failures == '0'):
sys.exit(0)
else:
sys.exit(1)