aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorduerpei <duep.fnst@fujitsu.com>2022-09-03 16:01:29 +0800
committerJan-Simon Moeller <jsmoeller@linuxfoundation.org>2022-12-08 05:59:50 +0000
commit50df2b6904dc448c2a8c5ed4f974c631fd97b070 (patch)
tree6b1e29bb949d139bf196f9699d7e90dc3774064d
parent39b04de14116e2a681dc6bad474dc76620d2de57 (diff)
agl-test-framework: add test 'bash'
Add test script for 'bash' Bug-AGL: SPEC-4345 Signed-off-by: duerpei <duep.fnst@fujitsu.com> Change-Id: Id50dcc3d1a80b8d088b8af897aee82f6492e1a96
-rw-r--r--tests/bash/__init__.py0
-rw-r--r--tests/bash/parser.py20
-rw-r--r--tests/bash/run_tests.py48
3 files changed, 68 insertions, 0 deletions
diff --git a/tests/bash/__init__.py b/tests/bash/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/tests/bash/__init__.py
diff --git a/tests/bash/parser.py b/tests/bash/parser.py
new file mode 100644
index 0000000..8f2b635
--- /dev/null
+++ b/tests/bash/parser.py
@@ -0,0 +1,20 @@
+import re
+
+def log_parse(log_file):
+ reObj = re.compile('^(PASS|FAIL+?): (run.+)', re.MULTILINE)
+ case_list = dict()
+ test_log = open(log_file, 'r')
+
+ line = test_log.readline()
+ while line:
+ matchs = reObj.search(line)
+
+ if matchs:
+ groups = matchs.groups()
+ case_list[groups[1]] = [groups[1], groups[0], ""]
+
+ line = test_log.readline()
+
+ test_log.close()
+
+ return case_list
diff --git a/tests/bash/run_tests.py b/tests/bash/run_tests.py
new file mode 100644
index 0000000..d18ecf0
--- /dev/null
+++ b/tests/bash/run_tests.py
@@ -0,0 +1,48 @@
+import pytest
+import pathlib
+import tests.bash.parser as parser
+from plugins.agl_test_ptest_base import PTESTBase
+
+class BashBase(PTESTBase):
+ def __init__(self):
+ super().__init__(test_name="bash")
+
+ def log_process(self):
+ log_file = self.get_logfile()
+ self.case_info_list = parser.log_parse(log_file)
+
+ def precheck(self):
+ path_bash = pathlib.Path("/usr/bin/bash")
+ return super().precheck() and path_bash.is_file()
+
+ def get_para(self):
+ #Due to the bug of "ptest-runner", the test case "run-read" may fail
+ xfail_list = ["run-read"]
+ return self.set_xfail_case(xfail_list)
+
+ def set_xfail_case(self, xfail_list):
+ para = list(self.case_info_list.keys())
+ for test_case in xfail_list:
+ para.remove(test_case)
+ para.append(pytest.param(test_case, marks=pytest.mark.xfail))
+ if(self.case_info_list[test_case][1] == "PASS"):
+ self.case_info_list[test_case][2] = "xpassed"
+ else:
+ self.case_info_list[test_case][2] = "xfailed"
+ return para
+
+instance = BashBase()
+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.get_para())
+def test_bash(testbase: BashBase, case_name):
+ testbase.run_case(case_name)
+
+if __name__ == '__main__':
+ pytest.main("-s run_tests")