summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorQiu Tingting <qiutt@fujitsu.com>2023-05-09 16:11:37 +0800
committerdu erp <duep.fnst@fujitsu.com>2023-05-15 07:18:42 +0000
commiteae50bd0b48073716ed5490ea74095fd52e4f2c0 (patch)
treef41d27c73d960cfc1f2812ad1f05288f3db45e49
parentf0262528eb2e746e227be3488437e0ad3834eb36 (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__.py0
-rw-r--r--tests/gdbm/parser.py30
-rw-r--r--tests/gdbm/run_tests.py26
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")