5.2.1 - Updated I2C files

Dependents:   mbed-TFT-example-NCS36510 mbed-Accelerometer-example-NCS36510 mbed-Accelerometer-example-NCS36510

Committer:
jacobjohnson
Date:
Mon Feb 27 17:45:05 2017 +0000
Revision:
1:f30bdcd2b33b
Parent:
0:098463de4c5d
changed the inputscale from 1 to 7 in analogin_api.c.  This will need to be changed later, and accessed from the main level, but for now this allows the  adc to read a value from 0 to 3.7V, instead of just up to 1V.;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
group-onsemi 0:098463de4c5d 1 """
group-onsemi 0:098463de4c5d 2 mbed SDK
group-onsemi 0:098463de4c5d 3 Copyright (c) 2011-2014 ARM Limited
group-onsemi 0:098463de4c5d 4
group-onsemi 0:098463de4c5d 5 Licensed under the Apache License, Version 2.0 (the "License");
group-onsemi 0:098463de4c5d 6 you may not use this file except in compliance with the License.
group-onsemi 0:098463de4c5d 7 You may obtain a copy of the License at
group-onsemi 0:098463de4c5d 8
group-onsemi 0:098463de4c5d 9 http://www.apache.org/licenses/LICENSE-2.0
group-onsemi 0:098463de4c5d 10
group-onsemi 0:098463de4c5d 11 Unless required by applicable law or agreed to in writing, software
group-onsemi 0:098463de4c5d 12 distributed under the License is distributed on an "AS IS" BASIS,
group-onsemi 0:098463de4c5d 13 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
group-onsemi 0:098463de4c5d 14 See the License for the specific language governing permissions and
group-onsemi 0:098463de4c5d 15 limitations under the License.
group-onsemi 0:098463de4c5d 16
group-onsemi 0:098463de4c5d 17 Author: Przemyslaw Wirkus <Przemyslaw.wirkus@arm.com>
group-onsemi 0:098463de4c5d 18 """
group-onsemi 0:098463de4c5d 19
group-onsemi 0:098463de4c5d 20 from tools.utils import construct_enum, mkdir
group-onsemi 0:098463de4c5d 21 from prettytable import PrettyTable
group-onsemi 0:098463de4c5d 22 import os
group-onsemi 0:098463de4c5d 23
group-onsemi 0:098463de4c5d 24 ResultExporterType = construct_enum(HTML='Html_Exporter',
group-onsemi 0:098463de4c5d 25 JUNIT='JUnit_Exporter',
group-onsemi 0:098463de4c5d 26 JUNIT_OPER='JUnit_Exporter_Interoperability',
group-onsemi 0:098463de4c5d 27 BUILD='Build_Exporter',
group-onsemi 0:098463de4c5d 28 TEXT='Text_Exporter',
group-onsemi 0:098463de4c5d 29 PRINT='Print_Exporter')
group-onsemi 0:098463de4c5d 30
group-onsemi 0:098463de4c5d 31
group-onsemi 0:098463de4c5d 32 class ReportExporter():
group-onsemi 0:098463de4c5d 33 """ Class exports extended test result Python data structure to
group-onsemi 0:098463de4c5d 34 different formats like HTML, JUnit XML.
group-onsemi 0:098463de4c5d 35
group-onsemi 0:098463de4c5d 36 Parameter 'test_result_ext' format:
group-onsemi 0:098463de4c5d 37
group-onsemi 0:098463de4c5d 38 u'uARM': { u'LPC1768': { 'MBED_2': { 0: { 'copy_method': 'shutils.copy()',
group-onsemi 0:098463de4c5d 39 'duration': 20,
group-onsemi 0:098463de4c5d 40 'elapsed_time': 1.7929999828338623,
group-onsemi 0:098463de4c5d 41 'output': 'Host test instrumentation on ...\r\n',
group-onsemi 0:098463de4c5d 42 'result': 'OK',
group-onsemi 0:098463de4c5d 43 'target_name': u'LPC1768',
group-onsemi 0:098463de4c5d 44 'description': 'stdio',
group-onsemi 0:098463de4c5d 45 'id': u'MBED_2',
group-onsemi 0:098463de4c5d 46 'toolchain_name': u'uARM'}},
group-onsemi 0:098463de4c5d 47 """
group-onsemi 0:098463de4c5d 48 CSS_STYLE = """<style>
group-onsemi 0:098463de4c5d 49 .name{
group-onsemi 0:098463de4c5d 50 border: 1px solid;
group-onsemi 0:098463de4c5d 51 border-radius: 25px;
group-onsemi 0:098463de4c5d 52 width: 100px;
group-onsemi 0:098463de4c5d 53 }
group-onsemi 0:098463de4c5d 54 .tooltip{
group-onsemi 0:098463de4c5d 55 position:absolute;
group-onsemi 0:098463de4c5d 56 background-color: #F5DA81;
group-onsemi 0:098463de4c5d 57 display:none;
group-onsemi 0:098463de4c5d 58 }
group-onsemi 0:098463de4c5d 59 </style>
group-onsemi 0:098463de4c5d 60 """
group-onsemi 0:098463de4c5d 61
group-onsemi 0:098463de4c5d 62 JAVASCRIPT = """
group-onsemi 0:098463de4c5d 63 <script type="text/javascript">
group-onsemi 0:098463de4c5d 64 function show (elem) {
group-onsemi 0:098463de4c5d 65 elem.style.display = "block";
group-onsemi 0:098463de4c5d 66 }
group-onsemi 0:098463de4c5d 67 function hide (elem) {
group-onsemi 0:098463de4c5d 68 elem.style.display = "";
group-onsemi 0:098463de4c5d 69 }
group-onsemi 0:098463de4c5d 70 </script>
group-onsemi 0:098463de4c5d 71 """
group-onsemi 0:098463de4c5d 72
group-onsemi 0:098463de4c5d 73 def __init__(self, result_exporter_type, package="test"):
group-onsemi 0:098463de4c5d 74 self.result_exporter_type = result_exporter_type
group-onsemi 0:098463de4c5d 75 self.package = package
group-onsemi 0:098463de4c5d 76
group-onsemi 0:098463de4c5d 77 def report(self, test_summary_ext, test_suite_properties=None,
group-onsemi 0:098463de4c5d 78 print_log_for_failures=True):
group-onsemi 0:098463de4c5d 79 """ Invokes report depending on exporter_type set in constructor
group-onsemi 0:098463de4c5d 80 """
group-onsemi 0:098463de4c5d 81 if self.result_exporter_type == ResultExporterType.HTML:
group-onsemi 0:098463de4c5d 82 # HTML exporter
group-onsemi 0:098463de4c5d 83 return self.exporter_html(test_summary_ext, test_suite_properties)
group-onsemi 0:098463de4c5d 84 elif self.result_exporter_type == ResultExporterType.JUNIT:
group-onsemi 0:098463de4c5d 85 # JUNIT exporter for results from test suite
group-onsemi 0:098463de4c5d 86 return self.exporter_junit(test_summary_ext, test_suite_properties)
group-onsemi 0:098463de4c5d 87 elif self.result_exporter_type == ResultExporterType.JUNIT_OPER:
group-onsemi 0:098463de4c5d 88 # JUNIT exporter for interoperability test
group-onsemi 0:098463de4c5d 89 return self.exporter_junit_ioper(test_summary_ext, test_suite_properties)
group-onsemi 0:098463de4c5d 90 elif self.result_exporter_type == ResultExporterType.PRINT:
group-onsemi 0:098463de4c5d 91 # JUNIT exporter for interoperability test
group-onsemi 0:098463de4c5d 92 return self.exporter_print(test_summary_ext, print_log_for_failures=print_log_for_failures)
group-onsemi 0:098463de4c5d 93 elif self.result_exporter_type == ResultExporterType.TEXT:
group-onsemi 0:098463de4c5d 94 return self.exporter_text(test_summary_ext)
group-onsemi 0:098463de4c5d 95 return None
group-onsemi 0:098463de4c5d 96
group-onsemi 0:098463de4c5d 97 def report_to_file(self, test_summary_ext, file_name, test_suite_properties=None):
group-onsemi 0:098463de4c5d 98 """ Stores report to specified file
group-onsemi 0:098463de4c5d 99 """
group-onsemi 0:098463de4c5d 100 report = self.report(test_summary_ext, test_suite_properties=test_suite_properties)
group-onsemi 0:098463de4c5d 101 self.write_to_file(report, file_name)
group-onsemi 0:098463de4c5d 102
group-onsemi 0:098463de4c5d 103 def write_to_file(self, report, file_name):
group-onsemi 0:098463de4c5d 104 if report is not None:
group-onsemi 0:098463de4c5d 105 dirname = os.path.dirname(file_name)
group-onsemi 0:098463de4c5d 106 if dirname:
group-onsemi 0:098463de4c5d 107 mkdir(dirname)
group-onsemi 0:098463de4c5d 108 with open(file_name, 'w') as f:
group-onsemi 0:098463de4c5d 109 f.write(report)
group-onsemi 0:098463de4c5d 110
group-onsemi 0:098463de4c5d 111 def get_tooltip_name(self, toolchain, target, test_id, loop_no):
group-onsemi 0:098463de4c5d 112 """ Generate simple unique tool-tip name which can be used.
group-onsemi 0:098463de4c5d 113 For example as HTML <div> section id attribute.
group-onsemi 0:098463de4c5d 114 """
group-onsemi 0:098463de4c5d 115 return "target_test_%s_%s_%s_%s"% (toolchain.lower(), target.lower(), test_id.lower(), loop_no)
group-onsemi 0:098463de4c5d 116
group-onsemi 0:098463de4c5d 117 def get_result_div_sections(self, test, test_no):
group-onsemi 0:098463de4c5d 118 """ Generates separate <DIV> sections which contains test results output.
group-onsemi 0:098463de4c5d 119 """
group-onsemi 0:098463de4c5d 120
group-onsemi 0:098463de4c5d 121 RESULT_COLORS = {'OK': 'LimeGreen',
group-onsemi 0:098463de4c5d 122 'FAIL': 'Orange',
group-onsemi 0:098463de4c5d 123 'ERROR': 'LightCoral',
group-onsemi 0:098463de4c5d 124 'OTHER': 'LightGray',
group-onsemi 0:098463de4c5d 125 }
group-onsemi 0:098463de4c5d 126
group-onsemi 0:098463de4c5d 127 tooltip_name = self.get_tooltip_name(test['toolchain_name'], test['target_name'], test['id'], test_no)
group-onsemi 0:098463de4c5d 128 background_color = RESULT_COLORS[test['result'] if test['result'] in RESULT_COLORS else 'OTHER']
group-onsemi 0:098463de4c5d 129 result_div_style = "background-color: %s"% background_color
group-onsemi 0:098463de4c5d 130
group-onsemi 0:098463de4c5d 131 result = """<div class="name" style="%s" onmouseover="show(%s)" onmouseout="hide(%s)">
group-onsemi 0:098463de4c5d 132 <center>%s</center>
group-onsemi 0:098463de4c5d 133 <div class = "tooltip" id= "%s">
group-onsemi 0:098463de4c5d 134 <b>%s</b><br />
group-onsemi 0:098463de4c5d 135 <hr />
group-onsemi 0:098463de4c5d 136 <b>%s</b> in <b>%.2f sec</b><br />
group-onsemi 0:098463de4c5d 137 <hr />
group-onsemi 0:098463de4c5d 138 <small>
group-onsemi 0:098463de4c5d 139 %s
group-onsemi 0:098463de4c5d 140 </small>
group-onsemi 0:098463de4c5d 141 </div>
group-onsemi 0:098463de4c5d 142 </div>
group-onsemi 0:098463de4c5d 143 """% (result_div_style,
group-onsemi 0:098463de4c5d 144 tooltip_name,
group-onsemi 0:098463de4c5d 145 tooltip_name,
group-onsemi 0:098463de4c5d 146 test['result'],
group-onsemi 0:098463de4c5d 147 tooltip_name,
group-onsemi 0:098463de4c5d 148 test['target_name_unique'],
group-onsemi 0:098463de4c5d 149 test['description'],
group-onsemi 0:098463de4c5d 150 test['elapsed_time'],
group-onsemi 0:098463de4c5d 151 test['output'].replace('\n', '<br />'))
group-onsemi 0:098463de4c5d 152 return result
group-onsemi 0:098463de4c5d 153
group-onsemi 0:098463de4c5d 154 def get_result_tree(self, test_results):
group-onsemi 0:098463de4c5d 155 """ If test was run in a loop (we got few results from the same test)
group-onsemi 0:098463de4c5d 156 we will show it in a column to see all results.
group-onsemi 0:098463de4c5d 157 This function produces HTML table with corresponding results.
group-onsemi 0:098463de4c5d 158 """
group-onsemi 0:098463de4c5d 159 result = ''
group-onsemi 0:098463de4c5d 160 for i, test_result in enumerate(test_results):
group-onsemi 0:098463de4c5d 161 result += '<table>'
group-onsemi 0:098463de4c5d 162 test_ids = sorted(test_result.keys())
group-onsemi 0:098463de4c5d 163 for test_no in test_ids:
group-onsemi 0:098463de4c5d 164 test = test_result[test_no]
group-onsemi 0:098463de4c5d 165 result += """<tr>
group-onsemi 0:098463de4c5d 166 <td valign="top">%s</td>
group-onsemi 0:098463de4c5d 167 </tr>"""% self.get_result_div_sections(test, "%d_%d" % (test_no, i))
group-onsemi 0:098463de4c5d 168 result += '</table>'
group-onsemi 0:098463de4c5d 169 return result
group-onsemi 0:098463de4c5d 170
group-onsemi 0:098463de4c5d 171 def get_all_unique_test_ids(self, test_result_ext):
group-onsemi 0:098463de4c5d 172 """ Gets all unique test ids from all ran tests.
group-onsemi 0:098463de4c5d 173 We need this to create complete list of all test ran.
group-onsemi 0:098463de4c5d 174 """
group-onsemi 0:098463de4c5d 175 result = []
group-onsemi 0:098463de4c5d 176 targets = test_result_ext.keys()
group-onsemi 0:098463de4c5d 177 for target in targets:
group-onsemi 0:098463de4c5d 178 toolchains = test_result_ext[target].keys()
group-onsemi 0:098463de4c5d 179 for toolchain in toolchains:
group-onsemi 0:098463de4c5d 180 tests = test_result_ext[target][toolchain].keys()
group-onsemi 0:098463de4c5d 181 result.extend(tests)
group-onsemi 0:098463de4c5d 182 return sorted(list(set(result)))
group-onsemi 0:098463de4c5d 183
group-onsemi 0:098463de4c5d 184 #
group-onsemi 0:098463de4c5d 185 # Exporters functions
group-onsemi 0:098463de4c5d 186 #
group-onsemi 0:098463de4c5d 187
group-onsemi 0:098463de4c5d 188 def exporter_html(self, test_result_ext, test_suite_properties=None):
group-onsemi 0:098463de4c5d 189 """ Export test results in proprietary HTML format.
group-onsemi 0:098463de4c5d 190 """
group-onsemi 0:098463de4c5d 191 result = """<html>
group-onsemi 0:098463de4c5d 192 <head>
group-onsemi 0:098463de4c5d 193 <title>mbed SDK test suite test result report</title>
group-onsemi 0:098463de4c5d 194 %s
group-onsemi 0:098463de4c5d 195 %s
group-onsemi 0:098463de4c5d 196 </head>
group-onsemi 0:098463de4c5d 197 <body>
group-onsemi 0:098463de4c5d 198 """% (self.CSS_STYLE, self.JAVASCRIPT)
group-onsemi 0:098463de4c5d 199
group-onsemi 0:098463de4c5d 200 unique_test_ids = self.get_all_unique_test_ids(test_result_ext)
group-onsemi 0:098463de4c5d 201 targets = sorted(test_result_ext.keys())
group-onsemi 0:098463de4c5d 202 result += '<table>'
group-onsemi 0:098463de4c5d 203 for target in targets:
group-onsemi 0:098463de4c5d 204 toolchains = sorted(test_result_ext[target].keys())
group-onsemi 0:098463de4c5d 205 for toolchain in toolchains:
group-onsemi 0:098463de4c5d 206 result += '<tr>'
group-onsemi 0:098463de4c5d 207 result += '<td></td>'
group-onsemi 0:098463de4c5d 208 result += '<td></td>'
group-onsemi 0:098463de4c5d 209
group-onsemi 0:098463de4c5d 210 tests = sorted(test_result_ext[target][toolchain].keys())
group-onsemi 0:098463de4c5d 211 for test in unique_test_ids:
group-onsemi 0:098463de4c5d 212 result += """<td align="center">%s</td>"""% test
group-onsemi 0:098463de4c5d 213 result += """</tr>
group-onsemi 0:098463de4c5d 214 <tr>
group-onsemi 0:098463de4c5d 215 <td valign="center">%s</td>
group-onsemi 0:098463de4c5d 216 <td valign="center"><b>%s</b></td>
group-onsemi 0:098463de4c5d 217 """% (toolchain, target)
group-onsemi 0:098463de4c5d 218
group-onsemi 0:098463de4c5d 219 for test in unique_test_ids:
group-onsemi 0:098463de4c5d 220 test_result = self.get_result_tree(test_result_ext[target][toolchain][test]) if test in tests else ''
group-onsemi 0:098463de4c5d 221 result += '<td>%s</td>'% (test_result)
group-onsemi 0:098463de4c5d 222
group-onsemi 0:098463de4c5d 223 result += '</tr>'
group-onsemi 0:098463de4c5d 224 result += '</table>'
group-onsemi 0:098463de4c5d 225 result += '</body></html>'
group-onsemi 0:098463de4c5d 226 return result
group-onsemi 0:098463de4c5d 227
group-onsemi 0:098463de4c5d 228 def exporter_junit_ioper(self, test_result_ext, test_suite_properties=None):
group-onsemi 0:098463de4c5d 229 from junit_xml import TestSuite, TestCase
group-onsemi 0:098463de4c5d 230 test_suites = []
group-onsemi 0:098463de4c5d 231 test_cases = []
group-onsemi 0:098463de4c5d 232
group-onsemi 0:098463de4c5d 233 for platform in sorted(test_result_ext.keys()):
group-onsemi 0:098463de4c5d 234 # {platform : ['Platform', 'Result', 'Scope', 'Description'])
group-onsemi 0:098463de4c5d 235 test_cases = []
group-onsemi 0:098463de4c5d 236 for tr_result in test_result_ext[platform]:
group-onsemi 0:098463de4c5d 237 result, name, scope, description = tr_result
group-onsemi 0:098463de4c5d 238
group-onsemi 0:098463de4c5d 239 classname = 'test.ioper.%s.%s.%s' % (platform, name, scope)
group-onsemi 0:098463de4c5d 240 elapsed_sec = 0
group-onsemi 0:098463de4c5d 241 _stdout = description
group-onsemi 0:098463de4c5d 242 _stderr = ''
group-onsemi 0:098463de4c5d 243 # Test case
group-onsemi 0:098463de4c5d 244 tc = TestCase(name, classname, elapsed_sec, _stdout, _stderr)
group-onsemi 0:098463de4c5d 245 # Test case extra failure / error info
group-onsemi 0:098463de4c5d 246 if result == 'FAIL':
group-onsemi 0:098463de4c5d 247 tc.add_failure_info(description, _stdout)
group-onsemi 0:098463de4c5d 248 elif result == 'ERROR':
group-onsemi 0:098463de4c5d 249 tc.add_error_info(description, _stdout)
group-onsemi 0:098463de4c5d 250 elif result == 'SKIP' or result == 'NOT_SUPPORTED':
group-onsemi 0:098463de4c5d 251 tc.add_skipped_info(description, _stdout)
group-onsemi 0:098463de4c5d 252
group-onsemi 0:098463de4c5d 253 test_cases.append(tc)
group-onsemi 0:098463de4c5d 254 ts = TestSuite("test.suite.ioper.%s" % (platform), test_cases)
group-onsemi 0:098463de4c5d 255 test_suites.append(ts)
group-onsemi 0:098463de4c5d 256 return TestSuite.to_xml_string(test_suites)
group-onsemi 0:098463de4c5d 257
group-onsemi 0:098463de4c5d 258 def exporter_junit(self, test_result_ext, test_suite_properties=None):
group-onsemi 0:098463de4c5d 259 """ Export test results in JUnit XML compliant format
group-onsemi 0:098463de4c5d 260 """
group-onsemi 0:098463de4c5d 261 from junit_xml import TestSuite, TestCase
group-onsemi 0:098463de4c5d 262 test_suites = []
group-onsemi 0:098463de4c5d 263 test_cases = []
group-onsemi 0:098463de4c5d 264
group-onsemi 0:098463de4c5d 265 targets = sorted(test_result_ext.keys())
group-onsemi 0:098463de4c5d 266 for target in targets:
group-onsemi 0:098463de4c5d 267 toolchains = sorted(test_result_ext[target].keys())
group-onsemi 0:098463de4c5d 268 for toolchain in toolchains:
group-onsemi 0:098463de4c5d 269 test_cases = []
group-onsemi 0:098463de4c5d 270 tests = sorted(test_result_ext[target][toolchain].keys())
group-onsemi 0:098463de4c5d 271 for test in tests:
group-onsemi 0:098463de4c5d 272 test_results = test_result_ext[target][toolchain][test]
group-onsemi 0:098463de4c5d 273 for test_res in test_results:
group-onsemi 0:098463de4c5d 274 test_ids = sorted(test_res.keys())
group-onsemi 0:098463de4c5d 275 for test_no in test_ids:
group-onsemi 0:098463de4c5d 276 test_result = test_res[test_no]
group-onsemi 0:098463de4c5d 277 name = test_result['description']
group-onsemi 0:098463de4c5d 278 classname = '%s.%s.%s.%s'% (self.package, target, toolchain, test_result['id'])
group-onsemi 0:098463de4c5d 279 elapsed_sec = test_result['elapsed_time']
group-onsemi 0:098463de4c5d 280 _stdout = test_result['output']
group-onsemi 0:098463de4c5d 281
group-onsemi 0:098463de4c5d 282 if 'target_name_unique' in test_result:
group-onsemi 0:098463de4c5d 283 _stderr = test_result['target_name_unique']
group-onsemi 0:098463de4c5d 284 else:
group-onsemi 0:098463de4c5d 285 _stderr = test_result['target_name']
group-onsemi 0:098463de4c5d 286
group-onsemi 0:098463de4c5d 287 # Test case
group-onsemi 0:098463de4c5d 288 tc = TestCase(name, classname, elapsed_sec, _stdout, _stderr)
group-onsemi 0:098463de4c5d 289
group-onsemi 0:098463de4c5d 290 # Test case extra failure / error info
group-onsemi 0:098463de4c5d 291 message = test_result['result']
group-onsemi 0:098463de4c5d 292 if test_result['result'] == 'FAIL':
group-onsemi 0:098463de4c5d 293 tc.add_failure_info(message, _stdout)
group-onsemi 0:098463de4c5d 294 elif test_result['result'] == 'SKIP' or test_result["result"] == 'NOT_SUPPORTED':
group-onsemi 0:098463de4c5d 295 tc.add_skipped_info(message, _stdout)
group-onsemi 0:098463de4c5d 296 elif test_result['result'] != 'OK':
group-onsemi 0:098463de4c5d 297 tc.add_error_info(message, _stdout)
group-onsemi 0:098463de4c5d 298
group-onsemi 0:098463de4c5d 299 test_cases.append(tc)
group-onsemi 0:098463de4c5d 300
group-onsemi 0:098463de4c5d 301 ts = TestSuite("test.suite.%s.%s"% (target, toolchain), test_cases, properties=test_suite_properties[target][toolchain])
group-onsemi 0:098463de4c5d 302 test_suites.append(ts)
group-onsemi 0:098463de4c5d 303 return TestSuite.to_xml_string(test_suites)
group-onsemi 0:098463de4c5d 304
group-onsemi 0:098463de4c5d 305 def exporter_print_helper(self, array, print_log=False):
group-onsemi 0:098463de4c5d 306 for item in array:
group-onsemi 0:098463de4c5d 307 print " * %s::%s::%s" % (item["target_name"], item["toolchain_name"], item["id"])
group-onsemi 0:098463de4c5d 308 if print_log:
group-onsemi 0:098463de4c5d 309 log_lines = item["output"].split("\n")
group-onsemi 0:098463de4c5d 310 for log_line in log_lines:
group-onsemi 0:098463de4c5d 311 print " %s" % log_line
group-onsemi 0:098463de4c5d 312
group-onsemi 0:098463de4c5d 313 def exporter_print(self, test_result_ext, print_log_for_failures=False):
group-onsemi 0:098463de4c5d 314 """ Export test results in print format.
group-onsemi 0:098463de4c5d 315 """
group-onsemi 0:098463de4c5d 316 failures = []
group-onsemi 0:098463de4c5d 317 skips = []
group-onsemi 0:098463de4c5d 318 successes = []
group-onsemi 0:098463de4c5d 319
group-onsemi 0:098463de4c5d 320 unique_test_ids = self.get_all_unique_test_ids(test_result_ext)
group-onsemi 0:098463de4c5d 321 targets = sorted(test_result_ext.keys())
group-onsemi 0:098463de4c5d 322
group-onsemi 0:098463de4c5d 323 for target in targets:
group-onsemi 0:098463de4c5d 324 toolchains = sorted(test_result_ext[target].keys())
group-onsemi 0:098463de4c5d 325 for toolchain in toolchains:
group-onsemi 0:098463de4c5d 326 tests = sorted(test_result_ext[target][toolchain].keys())
group-onsemi 0:098463de4c5d 327 for test in tests:
group-onsemi 0:098463de4c5d 328 test_runs = test_result_ext[target][toolchain][test]
group-onsemi 0:098463de4c5d 329 for test_runner in test_runs:
group-onsemi 0:098463de4c5d 330 #test_run = test_result_ext[target][toolchain][test][test_run_number][0]
group-onsemi 0:098463de4c5d 331 test_run = test_runner[0]
group-onsemi 0:098463de4c5d 332
group-onsemi 0:098463de4c5d 333 if "result" in test_run:
group-onsemi 0:098463de4c5d 334 if test_run["result"] == "FAIL":
group-onsemi 0:098463de4c5d 335 failures.append(test_run)
group-onsemi 0:098463de4c5d 336 elif test_run["result"] == "SKIP" or test_run["result"] == "NOT_SUPPORTED":
group-onsemi 0:098463de4c5d 337 skips.append(test_run)
group-onsemi 0:098463de4c5d 338 elif test_run["result"] == "OK":
group-onsemi 0:098463de4c5d 339 successes.append(test_run)
group-onsemi 0:098463de4c5d 340 else:
group-onsemi 0:098463de4c5d 341 raise Exception("Unhandled result type: %s" % (test_run["result"]))
group-onsemi 0:098463de4c5d 342 else:
group-onsemi 0:098463de4c5d 343 raise Exception("'test_run' did not have a 'result' value")
group-onsemi 0:098463de4c5d 344
group-onsemi 0:098463de4c5d 345 if successes:
group-onsemi 0:098463de4c5d 346 print "\n\nBuild successes:"
group-onsemi 0:098463de4c5d 347 self.exporter_print_helper(successes)
group-onsemi 0:098463de4c5d 348
group-onsemi 0:098463de4c5d 349 if skips:
group-onsemi 0:098463de4c5d 350 print "\n\nBuild skips:"
group-onsemi 0:098463de4c5d 351 self.exporter_print_helper(skips)
group-onsemi 0:098463de4c5d 352
group-onsemi 0:098463de4c5d 353 if failures:
group-onsemi 0:098463de4c5d 354 print "\n\nBuild failures:"
group-onsemi 0:098463de4c5d 355 self.exporter_print_helper(failures, print_log=print_log_for_failures)
group-onsemi 0:098463de4c5d 356 return False
group-onsemi 0:098463de4c5d 357 else:
group-onsemi 0:098463de4c5d 358 return True
group-onsemi 0:098463de4c5d 359
group-onsemi 0:098463de4c5d 360 def exporter_text(self, test_result_ext):
group-onsemi 0:098463de4c5d 361 """ Prints well-formed summary with results (SQL table like)
group-onsemi 0:098463de4c5d 362 table shows target x test results matrix across
group-onsemi 0:098463de4c5d 363 """
group-onsemi 0:098463de4c5d 364 success_code = 0 # Success code that can be leter returned to
group-onsemi 0:098463de4c5d 365 # Pretty table package is used to print results
group-onsemi 0:098463de4c5d 366 pt = PrettyTable(["Result", "Target", "Toolchain", "Test ID", "Test Description",
group-onsemi 0:098463de4c5d 367 "Elapsed Time", "Timeout"])
group-onsemi 0:098463de4c5d 368 pt.align["Result"] = "l" # Left align
group-onsemi 0:098463de4c5d 369 pt.align["Target"] = "l" # Left align
group-onsemi 0:098463de4c5d 370 pt.align["Toolchain"] = "l" # Left align
group-onsemi 0:098463de4c5d 371 pt.align["Test ID"] = "l" # Left align
group-onsemi 0:098463de4c5d 372 pt.align["Test Description"] = "l" # Left align
group-onsemi 0:098463de4c5d 373 pt.padding_width = 1 # One space between column edges and contents (default)
group-onsemi 0:098463de4c5d 374
group-onsemi 0:098463de4c5d 375 result_dict = {"OK" : 0,
group-onsemi 0:098463de4c5d 376 "FAIL" : 0,
group-onsemi 0:098463de4c5d 377 "ERROR" : 0,
group-onsemi 0:098463de4c5d 378 "UNDEF" : 0,
group-onsemi 0:098463de4c5d 379 "IOERR_COPY" : 0,
group-onsemi 0:098463de4c5d 380 "IOERR_DISK" : 0,
group-onsemi 0:098463de4c5d 381 "IOERR_SERIAL" : 0,
group-onsemi 0:098463de4c5d 382 "TIMEOUT" : 0,
group-onsemi 0:098463de4c5d 383 "NO_IMAGE" : 0,
group-onsemi 0:098463de4c5d 384 "MBED_ASSERT" : 0,
group-onsemi 0:098463de4c5d 385 "BUILD_FAILED" : 0,
group-onsemi 0:098463de4c5d 386 "NOT_SUPPORTED" : 0
group-onsemi 0:098463de4c5d 387 }
group-onsemi 0:098463de4c5d 388 unique_test_ids = self.get_all_unique_test_ids(test_result_ext)
group-onsemi 0:098463de4c5d 389 targets = sorted(test_result_ext.keys())
group-onsemi 0:098463de4c5d 390 for target in targets:
group-onsemi 0:098463de4c5d 391 toolchains = sorted(test_result_ext[target].keys())
group-onsemi 0:098463de4c5d 392 for toolchain in toolchains:
group-onsemi 0:098463de4c5d 393 test_cases = []
group-onsemi 0:098463de4c5d 394 tests = sorted(test_result_ext[target][toolchain].keys())
group-onsemi 0:098463de4c5d 395 for test in tests:
group-onsemi 0:098463de4c5d 396 test_results = test_result_ext[target][toolchain][test]
group-onsemi 0:098463de4c5d 397 for test_res in test_results:
group-onsemi 0:098463de4c5d 398 test_ids = sorted(test_res.keys())
group-onsemi 0:098463de4c5d 399 for test_no in test_ids:
group-onsemi 0:098463de4c5d 400 test_result = test_res[test_no]
group-onsemi 0:098463de4c5d 401 result_dict[test_result['result']] += 1
group-onsemi 0:098463de4c5d 402 pt.add_row([test_result['result'],
group-onsemi 0:098463de4c5d 403 test_result['target_name'],
group-onsemi 0:098463de4c5d 404 test_result['toolchain_name'],
group-onsemi 0:098463de4c5d 405 test_result['id'],
group-onsemi 0:098463de4c5d 406 test_result['description'],
group-onsemi 0:098463de4c5d 407 test_result['elapsed_time'],
group-onsemi 0:098463de4c5d 408 test_result['duration']])
group-onsemi 0:098463de4c5d 409 result = pt.get_string()
group-onsemi 0:098463de4c5d 410 result += "\n"
group-onsemi 0:098463de4c5d 411
group-onsemi 0:098463de4c5d 412 # Print result count
group-onsemi 0:098463de4c5d 413 result += "Result: " + ' / '.join(['%s %s' % (value, key) for (key, value) in {k: v for k, v in result_dict.items() if v != 0}.iteritems()])
group-onsemi 0:098463de4c5d 414 return result