From f7c5f95fbd237ebfe87d3bec4ad3081db02f4c6a Mon Sep 17 00:00:00 2001 From: yanxk Date: Thu, 11 Aug 2022 17:05:08 +0800 Subject: agl-test-framework: enable ptest of 'libxml2' Base on the agl-test-framework, the ptest results of 'libxml2' can now be collected, analyzed and then reported. Here are 3 samples that the output result might look like: tests/libxml2/run_tests.py::test_libxml2[Reader regression tests] PASSED tests/libxml2/run_tests.py::test_libxml2[Reader entities substitution regression tests] PASSED tests/libxml2/run_tests.py::test_libxml2[Reader on memory regression tests] PASSED Bug-AGL: SPEC-4345 Signed-off-by: yanxk Change-Id: I8361fe54177d951c36732ebfbe8dd8915975d7a9 --- tests/libxml2/__init__.py | 1 + tests/libxml2/parser.py | 38 ++++++++++++++++++++++++++++++++++++++ tests/libxml2/run_tests.py | 30 ++++++++++++++++++++++++++++++ 3 files changed, 69 insertions(+) create mode 100644 tests/libxml2/__init__.py create mode 100644 tests/libxml2/parser.py create mode 100644 tests/libxml2/run_tests.py diff --git a/tests/libxml2/__init__.py b/tests/libxml2/__init__.py new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/tests/libxml2/__init__.py @@ -0,0 +1 @@ + diff --git a/tests/libxml2/parser.py b/tests/libxml2/parser.py new file mode 100644 index 0000000..558a68d --- /dev/null +++ b/tests/libxml2/parser.py @@ -0,0 +1,38 @@ +# +# this is a parser function specially designed for the 'libxml2.log' +# +import re + +def log_parse(log_file): + + # set up rule for regex + reObj = re.compile('^(PASS|FAIL+?): (.+)', re.MULTILINE) + + # init a dictionary, it stores the return result + case_list = dict() + + # open file + test_log = open(log_file, 'r') + + # start to read the new line + line = test_log.readline() + + while line: + + # checking regex status in line + matchs = reObj.search(line) + + # if the line fits the regex rule + if matchs: + # spliting elements into a tuple + groups = matchs.groups() + + # then just add a new key naming after case_name, along with its values + case_list[groups[1]] = [groups[1], groups[0], ""] + + # jump out if-else, read next line + line = test_log.readline() + + test_log.close() + + return case_list diff --git a/tests/libxml2/run_tests.py b/tests/libxml2/run_tests.py new file mode 100644 index 0000000..70d2ccc --- /dev/null +++ b/tests/libxml2/run_tests.py @@ -0,0 +1,30 @@ +import pytest + +import tests.libxml2.parser as parser + +from plugins.agl_test_ptest_base import PTESTBase + +class LIBXML2Base(PTESTBase): + def __init__(self): + super().__init__(test_name="libxml2") + + def log_process(self): + log_file = self.get_logfile() + self.case_info_list = parser.log_parse(log_file) + self.init_case_status() + +instance = LIBXML2Base() +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_libxml2(testbase: LIBXML2Base, case_name): + testbase.run_case(case_name) + +if __name__ == '__main__': + pytest.main("-s run_tests") -- cgit