mirror of https://github.com/ARMmbed/mbed-os.git
112 lines
3.2 KiB
Python
112 lines
3.2 KiB
Python
#!/usr/bin/env python
|
|
|
|
import os
|
|
import sys
|
|
import signal
|
|
import argparse
|
|
import ast
|
|
import urllib2
|
|
import urllib
|
|
import time
|
|
import datetime
|
|
import xml.etree.ElementTree as ET
|
|
import pymysql
|
|
|
|
import pprint
|
|
|
|
pp = pprint.PrettyPrinter(indent=4)
|
|
|
|
def signal_handler(signal, frame):
|
|
# Whenever a keyboard interrupt is received, cancel build
|
|
print '\nKeyboard Interrupt received. Canceled build.'
|
|
sys.exit(0)
|
|
|
|
def main(arguments):
|
|
# Register keyboard interrupt handler
|
|
signal.signal(signal.SIGINT, signal_handler)
|
|
|
|
# Register and parse command line arguments
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument('-H', '--host', help='mysql host url')
|
|
parser.add_argument('-u', '--user', help='mysql username')
|
|
parser.add_argument('-p', '--password', help='mysql password')
|
|
parser.add_argument('-P', '--port', help='mysql port')
|
|
parser.add_argument('-D', '--database', help='mysql database')
|
|
parser.add_argument('-t', '--test-report', help='path to junit xml test report')
|
|
parser.add_argument('-o', '--host-os', help='host os on which test was run')
|
|
args = parser.parse_args(arguments)
|
|
|
|
tree = None
|
|
|
|
try:
|
|
tree = ET.parse(args.test_report)
|
|
except:
|
|
print(sys.exc_info()[0])
|
|
print('Invalid path to test report.')
|
|
sys.exit(1)
|
|
|
|
|
|
test_suites = tree.getroot()
|
|
|
|
ts_data = {}
|
|
ts_data['testSuites'] = []
|
|
|
|
platforms_set = set()
|
|
toolchains_set = set()
|
|
testIds_set = set()
|
|
|
|
|
|
for test_suite in test_suites:
|
|
ts = {}
|
|
ts['test_cases'] = []
|
|
for properties in test_suite.findall('properties'):
|
|
for property in properties.findall('property'):
|
|
if property.attrib['name'] == 'target':
|
|
ts['platform'] = property.attrib['value']
|
|
platforms_set.add(ts['platform'])
|
|
elif property.attrib['name'] == 'toolchain':
|
|
ts['toolchain'] = property.attrib['value']
|
|
toolchains_set.add(ts['toolchain'])
|
|
|
|
for test_case in test_suite.findall('testcase'):
|
|
tc = {}
|
|
tc['hostOs'] = args.host_os
|
|
tc['name'] = test_case.attrib['name']
|
|
|
|
tc['testId'] = test_case.attrib['classname'].split('.')[-1]
|
|
testIds_set.add(tc['testId'])
|
|
|
|
system_outs = test_case.findall('system-out')
|
|
|
|
tc['output'] = system_outs[0].text
|
|
|
|
errors = test_case.findall('error')
|
|
|
|
if errors:
|
|
tc['pass'] = False
|
|
tc['result'] = errors[0].attrib['message']
|
|
else:
|
|
tc['pass'] = True
|
|
tc['result'] = 'OK'
|
|
|
|
ts['test_cases'].append(tc)
|
|
|
|
ts_data['testSuites'].append(ts)
|
|
|
|
ts_data['platforms'] = platforms_set
|
|
ts_data['toolchains'] = toolchains_set
|
|
ts_data['testIds'] = testIds_set
|
|
|
|
pp.pprint(ts_data)
|
|
|
|
'''
|
|
# Open database connection
|
|
db = MySQLdb.connect(host=args.host, user=args.user, password=args.password, db=args.database,cursorclass=pymysql.cursors.DictCursor)
|
|
|
|
# prepare a cursor object using cursor() method
|
|
cursor = db.cursor()
|
|
'''
|
|
|
|
if __name__ == '__main__':
|
|
main(sys.argv[1:])
|