opencv/modules/ts/misc/perf_tests_timing.py

129 lines
4.3 KiB
Python
Raw Normal View History

2012-12-24 19:29:49 +08:00
#!/usr/bin/env python
import testlog_parser, sys, os, xml, glob, re
from table_formatter import *
from optparse import OptionParser
from operator import itemgetter, attrgetter
from summary import getSetName, alphanum_keyselector
2013-01-10 17:19:59 +08:00
import re
2012-12-24 19:29:49 +08:00
if __name__ == "__main__":
2012-12-24 20:47:30 +08:00
usage = "%prog <log_name>.xml [...]"
2012-12-24 19:29:49 +08:00
parser = OptionParser(usage = usage)
2012-12-24 20:47:30 +08:00
parser.add_option("-o", "--output", dest = "format",
help = "output results in text format (can be 'txt', 'html' or 'auto' - default)",
metavar = 'FMT', default = 'auto')
2012-12-24 19:29:49 +08:00
(options, args) = parser.parse_args()
if 1 != len(args):
parser.print_help()
exit(0)
2012-12-24 20:47:30 +08:00
options.generateHtml = detectHtmlOutputType(options.format)
2013-01-10 17:19:59 +08:00
input_file = args[0]
file = os.path.abspath(input_file)
2012-12-24 19:29:49 +08:00
if not os.path.isfile(file):
2012-12-24 20:47:30 +08:00
sys.stderr.write("IOError reading \"" + file + "\" - " + str(err) + os.linesep)
2012-12-24 19:29:49 +08:00
parser.print_help()
exit(0)
test_sets = []
try:
tests = testlog_parser.parseLogFile(file)
if tests:
test_sets.append((os.path.basename(file), tests))
except IOError as err:
sys.stderr.write("IOError reading \"" + file + "\" - " + str(err) + os.linesep)
except xml.parsers.expat.ExpatError as err:
sys.stderr.write("ExpatError reading \"" + file + "\" - " + str(err) + os.linesep)
if not test_sets:
sys.stderr.write("Error: no test data found" + os.linesep)
2013-01-10 17:18:26 +08:00
exit(0)
2012-12-24 19:29:49 +08:00
# find matches
setsCount = len(test_sets)
test_cases = {}
name_extractor = lambda name: str(name)
for i in range(setsCount):
for case in test_sets[i][1]:
name = name_extractor(case)
if name not in test_cases:
test_cases[name] = [None] * setsCount
test_cases[name][i] = case
testsuits = [] # testsuit name, time, num, flag for failed tests
2012-12-24 19:29:49 +08:00
overall_time = 0
2012-12-24 19:29:49 +08:00
prevGroupName = None
suit_time = 0
suit_num = 0
fails_num = 0
2012-12-24 19:29:49 +08:00
for name in sorted(test_cases.iterkeys(), key=alphanum_keyselector):
cases = test_cases[name]
groupName = next(c for c in cases if c).shortName()
if groupName != prevGroupName:
if prevGroupName != None:
2013-01-15 19:32:22 +08:00
suit_time = suit_time/60 #from seconds to minutes
2012-12-24 20:47:30 +08:00
testsuits.append({'name': prevGroupName, 'time': suit_time, \
'num': suit_num, 'failed': fails_num})
overall_time += suit_time
2012-12-24 19:29:49 +08:00
suit_time = 0
suit_num = 0
fails_num = 0
2012-12-24 19:29:49 +08:00
prevGroupName = groupName
for i in range(setsCount):
case = cases[i]
if not case is None:
suit_num += 1
2012-12-24 20:47:30 +08:00
if case.get('status') == 'run':
suit_time += case.get('time')
if case.get('status') == 'failed':
fails_num += 1
2012-12-24 19:29:49 +08:00
2013-01-10 17:16:46 +08:00
testsuits.append({'name': prevGroupName, 'time': suit_time, \
'num': suit_num, 'failed': fails_num})
2013-01-10 17:16:46 +08:00
2013-01-10 17:18:26 +08:00
if len(testsuits)==0:
print 'No testsuits found'
exit(0)
2012-12-24 19:29:49 +08:00
tbl = table()
# header
tbl.newColumn('name', 'Testsuit', align = 'left', cssclass = 'col_name')
2013-01-15 19:32:22 +08:00
tbl.newColumn('time', 'Time (min)', align = 'center', cssclass = 'col_name')
tbl.newColumn('num', 'Num of tests', align = 'center', cssclass = 'col_name')
tbl.newColumn('failed', 'Failed', align = 'center', cssclass = 'col_name')
2012-12-24 19:29:49 +08:00
# rows
2012-12-24 20:47:30 +08:00
for suit in sorted(testsuits, key = lambda suit: suit['time'], reverse = True):
2012-12-24 19:29:49 +08:00
tbl.newRow()
2012-12-24 20:47:30 +08:00
tbl.newCell('name', suit['name'])
tbl.newCell('time', formatValue(suit['time'], '', ''), suit['time'])
tbl.newCell('num', suit['num'])
if (suit['failed'] != 0):
tbl.newCell('failed', suit['failed'])
2012-12-24 20:47:30 +08:00
else:
tbl.newCell('failed', ' ')
2012-12-24 19:29:49 +08:00
# output table
if options.generateHtml:
tbl.htmlPrintTable(sys.stdout)
htmlPrintFooter(sys.stdout)
else:
2013-01-10 17:19:59 +08:00
input_file = re.sub(r'^[\.\/]*', '', input_file)
find_module_name = re.search(r'([^_]*)', input_file)
module_name = find_module_name.group(0)
splitter = 15 * '*'
print '\n%s\n %s\n%s\n' % (splitter, module_name, splitter)
2013-01-15 19:32:22 +08:00
print 'Overall time: %.2f min\n' % overall_time
2013-01-10 17:19:59 +08:00
tbl.consolePrintTable(sys.stdout)
print 4 * '\n'