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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
|
from __future__ import print_function
import sys, re, io
import string
"""Simple script that scans all of the test suite results text fed in
through stdin and summarises the total number of failures, test
points, and test cases."""
# Read in everything
if sys.version_info[0]<3:
safe_stdin = sys.stdin
else:
safe_stdin = io.TextIOWrapper(sys.stdin.buffer, encoding="latin-1")
lines = safe_stdin.readlines()
found = False
for line in lines:
if (re.search(r'^--- Summary:', line)):
found = True
break
if not found:
fp = open(sys.argv[1], "w")
fp.write("--- Running: %s\n" % sys.argv[1])
fp.write("--- Summary: 1/0/0: 1 failed of 0 tests in 0 cases.\n")
fp.close()
# Init the running totals
failures = 0
cases = 0
tests = 0
bytes = 0
ticks = 0
invalid = 0
# hack for valdiag
name = ""
base = ""
for line in lines:
# --- Running: gen/ucz80/longor/longor
m = re.match(r'^--- Running: (.*)$', line)
if (m):
name = m.group(1)
# in case the test program crashes before the "--- Running" message
m = re.match(r'^[0-9]+ words read from (.*)\.ihx$',line)
if (m):
name = m.group(1)
base = name
m = re.match(r'([^/]*)/([^/]*)/([^/]*)/(.*)$', name)
if (m):
base = m.group(3)
# '--- Summary: f/t/c: ...', where f = # failures, t = # test points,
# c = # test cases.
if (re.search(r'^--- Summary:', line)):
try:
(summary, data, rest) = re.split(r':', line)
(nfailures, ntests, ncases) = re.split(r'/', data)
tests = tests + float(ntests)
cases = cases + float(ncases)
except ValueError:
print("Bad summary line:", line)
nfailures = '1'
failures = failures + float(nfailures)
if (float(nfailures)):
print("Failure: %s" % name)
# '--- Simulator: b/t: ...', where b = # bytes, t = # ticks
if (re.search(r'^--- Simulator:', line)):
try:
(simulator, data, rest) = re.split(r':', line)
(nbytes, nticks) = re.split(r'/', data)
except ValueError:
print("Bad simulator line:", line)
else:
bytes = bytes + float(nbytes)
ticks = ticks + float(nticks)
# Stop at 0x000228: (106) Invalid instruction 0x00fd
if (re.search(r'Invalid instruction', line) or re.search(r'unknown instruction', line)):
invalid += 1;
print("Invalid instruction: %s" % name)
print("%-35.35s" % base, end=' ')
if (invalid > 0):
print("%d invalid instructions," % invalid, end=' ')
print("(f: %2.0f, t:%4.0f, c: %2.0f, b: %6.0f, T: %8.0f)" % (failures, tests, cases, bytes, ticks))
|