diff options
author | yanxk <yanxk.fnst@fujitsu.com> | 2022-08-11 16:56:47 +0800 |
---|---|---|
committer | Xinkuan Yan <yanxk.fnst@fujitsu.com> | 2022-11-08 09:15:19 +0000 |
commit | 51d16bd9bee5f0fc5d197fbfdbcae98178e58915 (patch) | |
tree | 77681177f269d0b552b4f43ff54e0e7c0bc6d1f6 /tests/libpam/parser.py | |
parent | 897c981ba437823f9c691247c97815599fbddc3f (diff) |
agl-test-framework: enable ptest of 'libpam'
Base on the agl-test-framework, the ptest results of 'libpam'
can now be collected, analyzed and then reported.
Here are 3 samples that the output result might look like:
tests/libpam/run_tests.py::test_libpam[tst-pam_acct_mgmt] PASSED
tests/libpam/run_tests.py::test_libpam[tst-pam_authenticate] PASSED
tests/libpam/run_tests.py::test_libpam[tst-pam_chauthtok] PASSED
Bug-AGL: SPEC-4345
Signed-off-by: yanxk <yanxk.fnst@fujitsu.com>
Change-Id: I11c73689b5073ca4bf24b34d128287e029afdb3a
Diffstat (limited to 'tests/libpam/parser.py')
-rw-r--r-- | tests/libpam/parser.py | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/tests/libpam/parser.py b/tests/libpam/parser.py new file mode 100644 index 0000000..dae4f12 --- /dev/null +++ b/tests/libpam/parser.py @@ -0,0 +1,37 @@ +# +# this is a parser function specially designed for the 'libpam.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 |