From 6befa34306fcb21dd3f26743144f5694b233bd2d Mon Sep 17 00:00:00 2001 From: Qiu Tingting Date: Fri, 30 Jun 2023 09:22:07 +0800 Subject: 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 Change-Id: I5a0e7efeb0c38c4ba96d472affa66cf5bcf381fa --- tests/kbd/__init__.py | 0 tests/kbd/parser.py | 34 ++++++++++++++++++++++++++++++++++ tests/kbd/run_tests.py | 27 +++++++++++++++++++++++++++ 3 files changed, 61 insertions(+) create mode 100644 tests/kbd/__init__.py create mode 100644 tests/kbd/parser.py create mode 100644 tests/kbd/run_tests.py diff --git a/tests/kbd/__init__.py b/tests/kbd/__init__.py new file mode 100644 index 0000000..e69de29 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") -- cgit 1.2.3-korg