aboutsummaryrefslogtreecommitdiffstats
path: root/tests/libxml2/parser.py
diff options
context:
space:
mode:
authoryanxk <yanxk.fnst@fujitsu.com>2022-08-11 17:05:08 +0800
committerJan-Simon Moeller <jsmoeller@linuxfoundation.org>2022-11-10 12:04:06 +0000
commitf7c5f95fbd237ebfe87d3bec4ad3081db02f4c6a (patch)
tree90ab987c1f8f3bb2641f31a2cd7bfb516d765ce1 /tests/libxml2/parser.py
parent51d16bd9bee5f0fc5d197fbfdbcae98178e58915 (diff)
agl-test-framework: enable ptest of 'libxml2'
Base on the agl-test-framework, the ptest results of 'libxml2' can now be collected, analyzed and then reported. Here are 3 samples that the output result might look like: tests/libxml2/run_tests.py::test_libxml2[Reader regression tests] PASSED tests/libxml2/run_tests.py::test_libxml2[Reader entities substitution regression tests] PASSED tests/libxml2/run_tests.py::test_libxml2[Reader on memory regression tests] PASSED Bug-AGL: SPEC-4345 Signed-off-by: yanxk <yanxk.fnst@fujitsu.com> Change-Id: I8361fe54177d951c36732ebfbe8dd8915975d7a9
Diffstat (limited to 'tests/libxml2/parser.py')
-rw-r--r--tests/libxml2/parser.py38
1 files changed, 38 insertions, 0 deletions
diff --git a/tests/libxml2/parser.py b/tests/libxml2/parser.py
new file mode 100644
index 0000000..558a68d
--- /dev/null
+++ b/tests/libxml2/parser.py
@@ -0,0 +1,38 @@
+#
+# this is a parser function specially designed for the 'libxml2.log'
+#
+import re
+
+def log_parse(log_file):
+
+ # set up rule for regex
+ reObj = re.compile('^(PASS|FAIL+?): (.+)', re.MULTILINE)
+
+ # init a dictionary, it stores the return result
+ case_list = dict()
+
+ # open file
+ test_log = open(log_file, 'r')
+
+ # start to read the new line
+ line = test_log.readline()
+
+ while line:
+
+ # checking regex status in line
+ matchs = reObj.search(line)
+
+ # if the line fits the regex rule
+ if matchs:
+ # spliting elements into a tuple
+ groups = matchs.groups()
+
+ # then just add a new key naming after case_name, along with its values
+ case_list[groups[1]] = [groups[1], groups[0], ""]
+
+ # jump out if-else, read next line
+ line = test_log.readline()
+
+ test_log.close()
+
+ return case_list