summaryrefslogtreecommitdiffstats
path: root/tests/curl/parser.py
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