aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/curl/__init__.py0
-rw-r--r--tests/curl/parser.py46
-rw-r--r--tests/curl/run_tests.py27
3 files changed, 73 insertions, 0 deletions
diff --git a/tests/curl/__init__.py b/tests/curl/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/tests/curl/__init__.py
diff --git a/tests/curl/parser.py b/tests/curl/parser.py
new file mode 100644
index 0000000..2c7ec63
--- /dev/null
+++ b/tests/curl/parser.py
@@ -0,0 +1,46 @@
+import re
+
+def log_parser(log_file):
+ prefix = ""
+ pattern_pre = '(^test [0-9]+)...(.*?)'
+ regex_pre = re.compile(pattern_pre, re.MULTILINE)
+ pattern = '^(FAIL|PASS|SKIP+?): (test [0-9]+) .*'
+ regex = re.compile(pattern, re.MULTILINE)
+ suffix_msg = "does not exist"
+ end_msg = "TESTDONE:"
+ case_list = dict()
+
+ test_log = open(log_file, 'r')
+ line = test_log.readline()
+ while line:
+ if end_msg in line:
+ break
+
+ # match pass/fail case with formate msg
+ matchs = regex.search(line)
+ if matchs:
+ groups = matchs.groups()
+ case_name = groups[1].strip()
+ case_list[case_name] = [case_name, groups[0], ""]
+
+ # match cases with org msg
+ matchs_pre = regex_pre.search(line)
+ if matchs_pre:
+ groups_pre = matchs_pre.groups()
+ case_name = groups_pre[0].strip()
+ if suffix_msg in line:
+ # match skip cases
+ case_list[case_name] = [case_name, "SKIP", ""]
+ else:
+ nextline = test_log.readline()
+ if "OK" in nextline:
+ # match pass cases
+ case_list[case_name] = [case_name, "PASS", ""]
+ else:
+ # match fail cases
+ case_list[case_name] = [case_name, "FAIL", ""]
+
+ line=test_log.readline()
+
+ test_log.close()
+ return case_list
diff --git a/tests/curl/run_tests.py b/tests/curl/run_tests.py
new file mode 100644
index 0000000..bb9bf1c
--- /dev/null
+++ b/tests/curl/run_tests.py
@@ -0,0 +1,27 @@
+import pytest
+import tests.curl.parser as log
+from plugins.agl_test_ptest_base import PTESTBase
+
+class Curl(PTESTBase):
+ def __init__(self):
+ super().__init__(test_name="curl")
+
+ def log_process(self):
+ log_file = self.get_logfile()
+ self.case_info_list = log.log_parser(log_file)
+
+instance = Curl()
+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.case_info_list.keys())
+def test_curl(testbase: Curl, case_name):
+ testbase.run_case(case_name)
+
+if __name__ == '__main__':
+ pytest.main("-s run_tests")