summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--scripts/lib/resulttool/report.py43
-rw-r--r--scripts/lib/resulttool/template/test_report_full_text.txt17
2 files changed, 59 insertions, 1 deletions
diff --git a/scripts/lib/resulttool/report.py b/scripts/lib/resulttool/report.py
index b1c9d13418..a98f2393e6 100644
--- a/scripts/lib/resulttool/report.py
+++ b/scripts/lib/resulttool/report.py
@@ -17,6 +17,7 @@ import oeqa.utils.gitarchive as gitarchive
17class ResultsTextReport(object): 17class ResultsTextReport(object):
18 def __init__(self): 18 def __init__(self):
19 self.ptests = {} 19 self.ptests = {}
20 self.ltptests = {}
20 self.result_types = {'passed': ['PASSED', 'passed'], 21 self.result_types = {'passed': ['PASSED', 'passed'],
21 'failed': ['FAILED', 'failed', 'ERROR', 'error', 'UNKNOWN'], 22 'failed': ['FAILED', 'failed', 'ERROR', 'error', 'UNKNOWN'],
22 'skipped': ['SKIPPED', 'skipped']} 23 'skipped': ['SKIPPED', 'skipped']}
@@ -51,6 +52,38 @@ class ResultsTextReport(object):
51 if status in self.result_types[tk]: 52 if status in self.result_types[tk]:
52 self.ptests[suite][tk] += 1 53 self.ptests[suite][tk] += 1
53 54
55 def handle_ltptest_result(self, k, status, result):
56 if k == 'ltpresult.sections':
57 # Ensure tests without any test results still show up on the report
58 for suite in result['ltpresult.sections']:
59 if suite not in self.ltptests:
60 self.ltptests[suite] = {'passed': 0, 'failed': 0, 'skipped': 0, 'duration' : '-', 'failed_testcases': []}
61 if 'duration' in result['ltpresult.sections'][suite]:
62 self.ltptests[suite]['duration'] = result['ltpresult.sections'][suite]['duration']
63 if 'timeout' in result['ltpresult.sections'][suite]:
64 self.ltptests[suite]['duration'] += " T"
65 return
66 try:
67 _, suite, test = k.split(".", 2)
68 except ValueError:
69 return
70 # Handle 'glib-2.0'
71 if 'ltpresult.sections' in result and suite not in result['ltpresult.sections']:
72 try:
73 _, suite, suite1, test = k.split(".", 3)
74 print("split2: %s %s %s" % (suite, suite1, test))
75 if suite + "." + suite1 in result['ltpresult.sections']:
76 suite = suite + "." + suite1
77 except ValueError:
78 pass
79 if suite not in self.ltptests:
80 self.ltptests[suite] = {'passed': 0, 'failed': 0, 'skipped': 0, 'duration' : '-', 'failed_testcases': []}
81 for tk in self.result_types:
82 if status in self.result_types[tk]:
83 self.ltptests[suite][tk] += 1
84
85 def get_aggregated_test_result(self, logger, testresult):
86 test_count_report = {'passed': 0, 'failed': 0, 'skipped': 0, 'failed_testcases': []}
54 def get_aggregated_test_result(self, logger, testresult): 87 def get_aggregated_test_result(self, logger, testresult):
55 test_count_report = {'passed': 0, 'failed': 0, 'skipped': 0, 'failed_testcases': []} 88 test_count_report = {'passed': 0, 'failed': 0, 'skipped': 0, 'failed_testcases': []}
56 result = testresult.get('result', []) 89 result = testresult.get('result', [])
@@ -63,6 +96,8 @@ class ResultsTextReport(object):
63 test_count_report['failed_testcases'].append(k) 96 test_count_report['failed_testcases'].append(k)
64 if k.startswith("ptestresult."): 97 if k.startswith("ptestresult."):
65 self.handle_ptest_result(k, test_status, result) 98 self.handle_ptest_result(k, test_status, result)
99 if k.startswith("ltpresult."):
100 self.handle_ltptest_result(k, test_status, result)
66 return test_count_report 101 return test_count_report
67 102
68 def print_test_report(self, template_file_name, test_count_reports): 103 def print_test_report(self, template_file_name, test_count_reports):
@@ -73,9 +108,10 @@ class ResultsTextReport(object):
73 template = env.get_template(template_file_name) 108 template = env.get_template(template_file_name)
74 havefailed = False 109 havefailed = False
75 haveptest = bool(self.ptests) 110 haveptest = bool(self.ptests)
111 haveltp = bool(self.ltptests)
76 reportvalues = [] 112 reportvalues = []
77 cols = ['passed', 'failed', 'skipped'] 113 cols = ['passed', 'failed', 'skipped']
78 maxlen = {'passed' : 0, 'failed' : 0, 'skipped' : 0, 'result_id': 0, 'testseries' : 0, 'ptest' : 0 } 114 maxlen = {'passed' : 0, 'failed' : 0, 'skipped' : 0, 'result_id': 0, 'testseries' : 0, 'ptest' : 0 ,'ltptest': 0}
79 for line in test_count_reports: 115 for line in test_count_reports:
80 total_tested = line['passed'] + line['failed'] + line['skipped'] 116 total_tested = line['passed'] + line['failed'] + line['skipped']
81 vals = {} 117 vals = {}
@@ -94,10 +130,15 @@ class ResultsTextReport(object):
94 for ptest in self.ptests: 130 for ptest in self.ptests:
95 if len(ptest) > maxlen['ptest']: 131 if len(ptest) > maxlen['ptest']:
96 maxlen['ptest'] = len(ptest) 132 maxlen['ptest'] = len(ptest)
133 for ltptest in self.ltptests:
134 if len(ltptest) > maxlen['ltptest']:
135 maxlen['ltptest'] = len(ltptest)
97 output = template.render(reportvalues=reportvalues, 136 output = template.render(reportvalues=reportvalues,
98 havefailed=havefailed, 137 havefailed=havefailed,
99 haveptest=haveptest, 138 haveptest=haveptest,
100 ptests=self.ptests, 139 ptests=self.ptests,
140 haveltp=haveltp,
141 ltptests=self.ltptests,
101 maxlen=maxlen) 142 maxlen=maxlen)
102 print(output) 143 print(output)
103 144
diff --git a/scripts/lib/resulttool/template/test_report_full_text.txt b/scripts/lib/resulttool/template/test_report_full_text.txt
index 590f35c7dd..6ecd5bce59 100644
--- a/scripts/lib/resulttool/template/test_report_full_text.txt
+++ b/scripts/lib/resulttool/template/test_report_full_text.txt
@@ -25,6 +25,23 @@ PTest Result Summary
25There was no ptest data 25There was no ptest data
26{% endif %} 26{% endif %}
27 27
28{% if haveltp %}
29==============================================================================================================
30Ltp Test Result Summary
31==============================================================================================================
32--------------------------------------------------------------------------------------------------------------
33{{ 'Recipe'.ljust(maxlen['ltptest']) }} | {{ 'Passed'.ljust(maxlen['passed']) }} | {{ 'Failed'.ljust(maxlen['failed']) }} | {{ 'Skipped'.ljust(maxlen['skipped']) }} | {{ 'Time(s)'.ljust(10) }}
34--------------------------------------------------------------------------------------------------------------
35{% for ltptest in ltptests |sort %}
36{{ ltptest.ljust(maxlen['ltptest']) }} | {{ (ltptests[ltptest]['passed']|string).ljust(maxlen['passed']) }} | {{ (ltptests[ltptest]['failed']|string).ljust(maxlen['failed']) }} | {{ (ltptests[ltptest]['skipped']|string).ljust(maxlen['skipped']) }} | {{ (ltptests[ltptest]['duration']|string) }}
37{% endfor %}
38--------------------------------------------------------------------------------------------------------------
39
40{% else %}
41There was no LTP Test data
42{% endif %}
43
44
28============================================================================================================== 45==============================================================================================================
29Failed test cases (sorted by testseries, ID) 46Failed test cases (sorted by testseries, ID)
30============================================================================================================== 47==============================================================================================================