From 9648099248359cb00aa0c31d5436b537b0571853 Mon Sep 17 00:00:00 2001 From: yanxk Date: Sat, 22 Jul 2023 00:52:49 +0800 Subject: agl-test-framework: add "cpio" it is new ptest, newly supported in YP master-next by us, now we add it into our test framework. sample output: tests/cpio/run_tests.py::test_cpio[cpio version ] PASSED tests/cpio/run_tests.py::test_cpio[basic functionality: copyin/copyout ] PASSED tests/cpio/run_tests.py::test_cpio[symlink ] PASSED Bug-AGL: SPEC-4345 Signed-off-by: yanxk Change-Id: I08d8c18c1f1f4ec7df5f5447e6177490958fad37 --- tests/cpio/parser.py | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 tests/cpio/parser.py (limited to 'tests/cpio/parser.py') diff --git a/tests/cpio/parser.py b/tests/cpio/parser.py new file mode 100644 index 0000000..290bbf4 --- /dev/null +++ b/tests/cpio/parser.py @@ -0,0 +1,38 @@ +# +# this is a parser function specially designed for the 'cpio.log' +# +import re + +def log_parse(log_file): + + # set up rule for regex + reObj = re.compile('^(PASS|FAIL|SKIP+?): (.+)', 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 -- cgit