From 476c36b9c898e31a8a188a271333b706c86a9352 Mon Sep 17 00:00:00 2001 From: Arvid Norberg Date: Sun, 30 Mar 2014 09:11:38 +0000 Subject: [PATCH] improve regression test output --- tools/run_tests.py | 74 ++++++++++++++++++++-------------------------- 1 file changed, 32 insertions(+), 42 deletions(-) diff --git a/tools/run_tests.py b/tools/run_tests.py index dd38a0367..69dab5339 100755 --- a/tools/run_tests.py +++ b/tools/run_tests.py @@ -43,7 +43,6 @@ from datetime import datetime import json import sys import yaml -from multiprocessing import Pool import glob import shutil import traceback @@ -90,12 +89,14 @@ def run_tests(toolset, tests, features, options, test_dir, time_limit): try: results = {} - toolset_found = False feature_list = features.split(' ') os.chdir(test_dir) + c = 0 for t in tests: + c = c + 1 + options_copy = options[:] if t != '': options_copy.append(t) if t == '': @@ -113,6 +114,8 @@ def run_tests(toolset, tests, features, options, test_dir, time_limit): output = '' for l in p.stdout: output += l.decode('latin-1') + sys.stdout.write('.') + sys.stdout.flush() p.wait() # parse out the toolset version from the xml file @@ -144,11 +147,11 @@ def run_tests(toolset, tests, features, options, test_dir, time_limit): r = { 'status': p.returncode, 'output': output, 'command': command } results[t + '|' + features] = r - if p.returncode == 0: - sys.stdout.write('.') - else: + if p.returncode != 0: + sys.stdout.write('\n') sys.stdout.write(output) - sys.stdout.flush() + + print '\n%s - %d / %d' % (toolset, c, len(tests)) except Exception, e: # need this to make child processes exit @@ -173,7 +176,6 @@ def main(argv): toolsets = [] - num_processes = 2 incremental = False test_dirs = [] @@ -186,6 +188,7 @@ def main(argv): if arg[0] == '-': if arg[1] == 'j': num_processes = int(arg[2:]) + options.append('-j%d' % num_processes) elif arg[1] == 'h': print_usage() sys.exit(1) @@ -265,8 +268,6 @@ def main(argv): timestamp = datetime.now() - tester_pool = Pool(processes=num_processes) - print '%s-%d - %s - %s' % (branch_name, revision, author, timestamp) print 'toolsets: %s' % ' '.join(toolsets) @@ -282,30 +283,27 @@ def main(argv): try: os.mkdir(rev_dir) except: pass - results = {} - for test_dir in test_dirs: - print 'running tests from "%s" in %s' % (test_dir, branch_name) - os.chdir(test_dir) - test_dir = os.getcwd() + for toolset in toolsets: + results = {} + for test_dir in test_dirs: + print 'running tests from "%s" in %s' % (test_dir, branch_name) + os.chdir(test_dir) + test_dir = os.getcwd() - # figure out which tests are exported by this Jamfile - p = subprocess.Popen(['bjam', '--dump-tests', 'non-existing-target'], stdout=subprocess.PIPE, cwd=test_dir) + # figure out which tests are exported by this Jamfile + p = subprocess.Popen(['bjam', '--dump-tests', 'non-existing-target'], stdout=subprocess.PIPE, cwd=test_dir) - tests = [] + tests = [] - output = '' - for l in p.stdout: - output += l - if not 'boost-test(RUN)' in l: continue - test_name = os.path.split(l.split(' ')[1][1:-1])[1] - tests.append(test_name) - print 'found %d tests' % len(tests) - if len(tests) == 0: - tests = [''] - - for toolset in toolsets: - if not toolset in results: results[toolset] = {} - toolset_found = False + output = '' + for l in p.stdout: + output += l + if not 'boost-test(RUN)' in l: continue + test_name = os.path.split(l.split(' ')[1][1:-1])[1] + tests.append(test_name) + print 'found %d tests' % len(tests) + if len(tests) == 0: + tests = [''] additional_configs = [] if test_dir in build_dirs: @@ -313,22 +311,15 @@ def main(argv): futures = [] for features in configs + additional_configs: - futures.append(tester_pool.apply_async(run_tests, [toolset, tests, features, options, test_dir, time_limit])) - - for future in futures: - (compiler, r) = future.get() - results[toolset].update(r) - -# for features in configs + additional_configs: -# (compiler, r) = run_tests(toolset, tests, features, options, test_dir, time_limit) -# results[toolset].update(r) + (compiler, r) = run_tests(toolset, tests, features, options, test_dir, time_limit) + results.update(r) print '' if len(clean_files) > 0: print 'deleting ', for filt in clean_files: - for f in glob.glob(filt): + for f in glob.glob(os.path.join(test_dir, filt)): # a precaution to make sure a malicious repo # won't clean things outside of the test directory if not os.path.abspath(f).startswith(test_dir): continue @@ -337,7 +328,6 @@ def main(argv): except: pass print '' - for toolset in toolsets: # each file contains a full set of tests for one speific toolset and platform try: f = open(os.path.join(rev_dir, build_platform + '#' + toolset + '.json'), 'w+') @@ -350,7 +340,7 @@ def main(argv): except: pass f = open(os.path.join(rev_dir, build_platform + '#' + toolset + '.json'), 'w+') - print >>f, json.dumps(results[toolset]) + print >>f, json.dumps(results) f.close()