diff options
Diffstat (limited to 'tests/curl')
-rw-r--r-- | tests/curl/__init__.py | 0 | ||||
-rw-r--r-- | tests/curl/parser.py | 46 | ||||
-rw-r--r-- | tests/curl/run_tests.py | 27 |
3 files changed, 73 insertions, 0 deletions
diff --git a/tests/curl/__init__.py b/tests/curl/__init__.py new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/tests/curl/__init__.py 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 diff --git a/tests/curl/run_tests.py b/tests/curl/run_tests.py new file mode 100644 index 0000000..bb9bf1c --- /dev/null +++ b/tests/curl/run_tests.py @@ -0,0 +1,27 @@ +import pytest +import tests.curl.parser as log +from plugins.agl_test_ptest_base import PTESTBase + +class Curl(PTESTBase): + def __init__(self): + super().__init__(test_name="curl") + + def log_process(self): + log_file = self.get_logfile() + self.case_info_list = log.log_parser(log_file) + +instance = Curl() +instance.run_ptest() + +@pytest.fixture(scope='module') +def testbase(): + yield instance + #package log files and make report file + instance.log_report() + +@pytest.mark.parametrize('case_name', instance.case_info_list.keys()) +def test_curl(testbase: Curl, case_name): + testbase.run_case(case_name) + +if __name__ == '__main__': + pytest.main("-s run_tests") |