blob: 2c7ec633aa4d78485d59bd6afed8533d71420a3e (
plain)
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
|
import re
def log_parser(log_file):
prefix = ""
pattern_pre = '(^test [0-9]+)...(.*?)'
regex_pre = re.compile(pattern_pre, re.MULTILINE)
pattern = '^(FAIL|PASS|SKIP+?): (test [0-9]+) .*'
regex = re.compile(pattern, re.MULTILINE)
suffix_msg = "does not exist"
end_msg = "TESTDONE:"
case_list = dict()
test_log = open(log_file, 'r')
line = test_log.readline()
while line:
if end_msg in line:
break
# match pass/fail case with formate msg
matchs = regex.search(line)
if matchs:
groups = matchs.groups()
case_name = groups[1].strip()
case_list[case_name] = [case_name, groups[0], ""]
# match cases with org msg
matchs_pre = regex_pre.search(line)
if matchs_pre:
groups_pre = matchs_pre.groups()
case_name = groups_pre[0].strip()
if suffix_msg in line:
# match skip cases
case_list[case_name] = [case_name, "SKIP", ""]
else:
nextline = test_log.readline()
if "OK" in nextline:
# match pass cases
case_list[case_name] = [case_name, "PASS", ""]
else:
# match fail cases
case_list[case_name] = [case_name, "FAIL", ""]
line=test_log.readline()
test_log.close()
return case_list
|