aboutsummaryrefslogtreecommitdiffstats
path: root/tests/kbd/parser.py
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/parser.py
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/parser.py')
-rw-r--r--tests/kbd/parser.py34
1 files changed, 34 insertions, 0 deletions
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