diff options
author | Qiu Tingting <qiutt@fujitsu.com> | 2023-06-30 09:22:07 +0800 |
---|---|---|
committer | Qiu Tingting <qiutt@fujitsu.com> | 2023-06-30 09:22:07 +0800 |
commit | 6befa34306fcb21dd3f26743144f5694b233bd2d (patch) | |
tree | 2377b30efce62b50814c52914daa435a6bce8dae /tests/kbd | |
parent | 1497d67ce8a16c40c5c9c87b23203331dad41012 (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__.py | 0 | ||||
-rw-r--r-- | tests/kbd/parser.py | 34 | ||||
-rw-r--r-- | tests/kbd/run_tests.py | 27 |
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") |