diff options
author | Qiu Tingting <qiutt@fujitsu.com> | 2023-05-09 16:11:37 +0800 |
---|---|---|
committer | du erp <duep.fnst@fujitsu.com> | 2023-05-15 07:18:42 +0000 |
commit | eae50bd0b48073716ed5490ea74095fd52e4f2c0 (patch) | |
tree | f41d27c73d960cfc1f2812ad1f05288f3db45e49 | |
parent | f0262528eb2e746e227be3488437e0ad3834eb36 (diff) |
agl-test-framework: add ptest gdbm
Add ptest gdbm in agl-test-framework.
Testing costs 5s.
Bug-AGL: SPEC-4753
Signed-off-by: Qiu Tingting <qiutt@fujitsu.com>
Change-Id: Ieb91a394373a4140ca29214ec26f5133f8896b08
-rw-r--r-- | tests/gdbm/__init__.py | 0 | ||||
-rw-r--r-- | tests/gdbm/parser.py | 30 | ||||
-rw-r--r-- | tests/gdbm/run_tests.py | 26 |
3 files changed, 56 insertions, 0 deletions
diff --git a/tests/gdbm/__init__.py b/tests/gdbm/__init__.py new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/tests/gdbm/__init__.py diff --git a/tests/gdbm/parser.py b/tests/gdbm/parser.py new file mode 100644 index 0000000..9835b9e --- /dev/null +++ b/tests/gdbm/parser.py @@ -0,0 +1,30 @@ +import re + +def log_parser(log_file): + prefix = "Version" + pattern_types = '^(GDBM|Block|Compatibility|DB|Cloexec|Wordwrap|gdbmtool|Database+?).*' + regex_type = re.compile(pattern_types, re.MULTILINE) + pattern = '^(FAIL|PASS|SKIP+?): (.+)' + regex = re.compile(pattern, re.MULTILINE) + case_list = dict() + + test_log = open(log_file, 'r') + line = test_log.readline() + while line: + # match test suite name + matchs_type = regex_type.search(line) + if matchs_type: + groups_type = matchs_type.groups() + prefix = groups_type[0] + + # match case and result + matchs = regex.search(line) + if matchs: + groups = matchs.groups() + case_name = prefix + " " + groups[1] + case_list[case_name] = [case_name, groups[0], ""] + + line=test_log.readline() + + test_log.close() + return case_list diff --git a/tests/gdbm/run_tests.py b/tests/gdbm/run_tests.py new file mode 100644 index 0000000..a5b8226 --- /dev/null +++ b/tests/gdbm/run_tests.py @@ -0,0 +1,26 @@ +import pytest +import tests.gdbm.parser as parser +from plugins.agl_test_ptest_base import PTESTBase + +class Gdbm(PTESTBase): + def __init__(self): + super().__init__(test_name="gdbm") + + def log_process(self): + log_file = self.get_logfile() + self.case_info_list = parser.log_parser(log_file) + +instance = Gdbm() +instance.run_ptest() + +@pytest.fixture(scope='module') +def testbase(): + yield instance + instance.log_report() + +@pytest.mark.parametrize('case_name', instance.case_info_list.keys()) +def test_gdbm(testbase: Gdbm, case_name): + testbase.run_case(case_name) + +if __name__ == '__main__': + pytest.main("-s run_tests") |