summaryrefslogtreecommitdiffstats
path: root/tests/kbd
diff options
context:
space:
mode:
authorQiu Tingting <qiutt@fujitsu.com>2023-06-30 09:22:07 +0800
committerQiu Tingting <qiutt@fujitsu.com>2023-06-30 09:22:07 +0800
commit6befa34306fcb21dd3f26743144f5694b233bd2d (patch)
tree2377b30efce62b50814c52914daa435a6bce8dae /tests/kbd
parent1497d67ce8a16c40c5c9c87b23203331dad41012 (diff)
agl-test-framework: add ptest kbd
Add ptest kbd in agl-test-framework. Testing costs 6s. Bug-AGL: SPEC-4753 Signed-off-by: Qiu Tingting <qiutt@fujitsu.com> Change-Id: I5a0e7efeb0c38c4ba96d472affa66cf5bcf381fa
Diffstat (limited to 'tests/kbd')
-rw-r--r--tests/kbd/__init__.py0
-rw-r--r--tests/kbd/parser.py34
-rw-r--r--tests/kbd/run_tests.py27
3 files changed, 61 insertions, 0 deletions
diff --git a/tests/kbd/__init__.py b/tests/kbd/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/tests/kbd/__init__.py
diff --git a/tests/kbd/parser.py b/tests/kbd/parser.py
new file mode 100644
index 0000000..315ae27
--- /dev/null
+++ b/tests/kbd/parser.py
@@ -0,0 +1,34 @@
+import re
+
+def log_parser(log_file):
+ prefix = ""
+ pattern_types = '^(libkeymap|libkbdfile+?).*'
+ regex_type = re.compile(pattern_types, re.MULTILINE)
+ pattern = '^(FAIL|PASS|SKIP+?): (.+)'
+ regex = re.compile(pattern, re.MULTILINE)
+ end_msg = "Test results"
+ case_list = dict()
+
+ test_log = open(log_file, 'r')
+ line = test_log.readline()
+ while line:
+ if end_msg in line:
+ break
+
+ # 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].strip()
+ case_list[case_name] = [case_name, groups[0], ""]
+
+ line=test_log.readline()
+
+ test_log.close()
+ return case_list
diff --git a/tests/kbd/run_tests.py b/tests/kbd/run_tests.py
new file mode 100644
index 0000000..edcd893
--- /dev/null
+++ b/tests/kbd/run_tests.py
@@ -0,0 +1,27 @@
+import pytest
+import tests.kbd.parser as log
+from plugins.agl_test_ptest_base import PTESTBase
+
+class Kbd(PTESTBase):
+ def __init__(self):
+ super().__init__(test_name="kbd")
+
+ def log_process(self):
+ log_file = self.get_logfile()
+ self.case_info_list = log.log_parser(log_file)
+
+instance = Kbd()
+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_kbd(testbase: Kbd, case_name):
+ testbase.run_case(case_name)
+
+if __name__ == '__main__':
+ pytest.main("-s run_tests")