tests: Optimize run-tests.py --prefill-tests startup time

It took significant part of the startup latency to prefill the database
with test cases due to the SQL COMMIT operation between each added row.
Move COMMIT to outside the loop to speed startup significantly.

Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com>
This commit is contained in:
Jouni Malinen 2014-11-27 20:08:15 +02:00 committed by Jouni Malinen
parent b925506a91
commit 9363f5e065

View File

@ -76,7 +76,8 @@ def add_log_file(conn, test, run, type, path):
print "sqlite: " + str(e) print "sqlite: " + str(e)
print "sql: %r" % (params, ) print "sql: %r" % (params, )
def report(conn, prefill, build, commit, run, test, result, duration, logdir): def report(conn, prefill, build, commit, run, test, result, duration, logdir,
sql_commit=True):
if conn: if conn:
if not build: if not build:
build = '' build = ''
@ -88,6 +89,7 @@ def report(conn, prefill, build, commit, run, test, result, duration, logdir):
params = (test, result, run, time.time(), duration, build, commit) params = (test, result, run, time.time(), duration, build, commit)
try: try:
conn.execute(sql, params) conn.execute(sql, params)
if sql_commit:
conn.commit() conn.commit()
except Exception, e: except Exception, e:
print "sqlite: " + str(e) print "sqlite: " + str(e)
@ -329,7 +331,8 @@ def main():
for t in tests_to_run: for t in tests_to_run:
name = t.__name__.replace('test_', '', 1) name = t.__name__.replace('test_', '', 1)
report(conn, False, args.build, args.commit, run, name, 'NOTRUN', 0, report(conn, False, args.build, args.commit, run, name, 'NOTRUN', 0,
args.logdir) args.logdir, sql_commit=False)
conn.commit()
if args.split: if args.split:
vals = args.split.split('/') vals = args.split.split('/')