micropython/tests/run-tests

62 lines
1.6 KiB
Plaintext
Raw Normal View History

2014-01-27 21:53:28 +00:00
#! /usr/bin/env python3.3
import os
import subprocess
import sys
from glob import glob
if os.name == 'nt':
CPYTHON3 = 'python3.3.exe'
MP_PY = '../windows/micropython.exe'
else:
CPYTHON3 = 'python3.3'
MP_PY = '../unix/micropython'
def rm_f(fname):
if os.path.exists(fname):
os.remove(fname)
2014-01-27 21:53:28 +00:00
test_count = 0
testcase_count = 0
passed_count = 0
failed_tests = []
tests = []
if not sys.argv[1:]:
2014-01-29 22:32:23 +00:00
tests = sorted(glob('basics/*.py') + glob('io/*.py'))
2014-01-27 21:53:28 +00:00
else:
tests = sys.argv[1:]
for test_file in tests:
test_name = os.path.splitext(os.path.basename(test_file))[0]
output_expected = subprocess.check_output([CPYTHON3, '-B', test_file])
2014-01-29 22:32:23 +00:00
try:
output_mupy = subprocess.check_output([MP_PY, test_file])
except subprocess.CalledProcessError:
output_mupy = b'CRASH'
2014-01-27 21:53:28 +00:00
testcase_count += len(output_expected.splitlines())
2014-01-29 22:32:23 +00:00
if output_expected == output_mupy:
2014-01-27 21:53:28 +00:00
print("pass ", test_file)
passed_count += 1
rm_f(os.path.basename(test_file + ".exp"))
rm_f(os.path.basename(test_file + ".out"))
2014-01-27 21:53:28 +00:00
else:
with open(os.path.basename(test_file + ".exp"), "w") as f:
f.write(str(output_expected, "ascii"))
with open(os.path.basename(test_file + ".out"), "w") as f:
f.write(str(output_mupy, "ascii"))
2014-01-27 21:53:28 +00:00
print("FAIL ", test_file)
failed_tests.append(test_name)
test_count += 1
2014-01-29 22:32:23 +00:00
print("{} tests performed ({} individual testcases)".format(test_count, testcase_count))
2014-01-27 21:53:28 +00:00
print("{} tests passed".format(passed_count))
if len(failed_tests) > 0:
2014-01-29 22:32:23 +00:00
print("{} tests failed: {}".format(len(failed_tests), ' '.join(failed_tests)))
2014-01-27 21:53:28 +00:00
sys.exit(1)