diff options
Diffstat (limited to 'tests/curl/parser.py')
-rw-r--r-- | tests/curl/parser.py | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/curl/parser.py b/tests/curl/parser.py new file mode 100644 index 0000000..2c7ec63 --- /dev/null +++ b/tests/curl/parser.py @@ -0,0 +1,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 |