#!/usr/bin/env python # Copyright 2014 the V8 project authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. # for py2/py3 compatibility from __future__ import print_function import argparse import os import subprocess import sys BOTS = { '--chromebook': 'v8_chromebook_perf_try', '--linux32': 'v8_linux32_perf_try', '--linux64': 'v8_linux64_perf_try', '--linux64_atom': 'v8_linux64_atom_perf_try', '--nexus5': 'v8_nexus5_perf_try', '--nexus7': 'v8_nexus7_perf_try', '--nokia1': 'v8_nokia1_perf_try', '--odroid32': 'v8_odroid32_perf_try', '--pixel2': 'v8_pixel2_perf_try', } DEFAULT_BOTS = [ 'v8_chromebook_perf_try', 'v8_linux32_perf_try', 'v8_linux64_perf_try', ] PUBLIC_BENCHMARKS = [ 'arewefastyet', 'ares6', 'blazor', 'compile', 'embenchen', 'emscripten', 'jetstream', 'jsbench', 'jstests', 'kraken_orig', 'massive', 'memory', 'octane', 'octane-noopt', 'octane-pr', 'octane-tf', 'octane-tf-pr', 'sunspider', 'unity', 'wasm', 'web-tooling-benchmark', ] V8_BASE = os.path.abspath(os.path.dirname(os.path.dirname(__file__))) def main(): parser = argparse.ArgumentParser(description='') parser.add_argument('benchmarks', nargs='+', help='The benchmarks to run.') parser.add_argument('--extra-flags', default='', help='Extra flags to be passed to the executable.') parser.add_argument('-r', '--revision', type=str, default=None, help='Revision (use full hash!) to use for the try job; ' 'default: the revision will be determined by the ' 'try server; see its waterfall for more info') parser.add_argument('-v', '--verbose', action='store_true', help='Print debug information') parser.add_argument('-c', '--confidence-level', type=float, help='Repeatedly runs each benchmark until specified ' 'confidence level is reached. The value is interpreted ' 'as the number of standard deviations from the mean that ' 'all values must lie within. Typical values are 1, 2 and ' '3 and correspond to 68%%, 95%% and 99.7%% probability ' 'that the measured value is within 0.1%% of the true ' 'value. Larger values result in more retries and thus ' 'longer runtime, but also provide more reliable results.') for option in sorted(BOTS): parser.add_argument( option, dest='bots', action='append_const', const=BOTS[option], help='Add %s trybot.' % BOTS[option]) options = parser.parse_args() if not options.bots: print('No trybots specified. Using default %s.' % ','.join(DEFAULT_BOTS)) options.bots = DEFAULT_BOTS if not options.benchmarks: print('Please specify the benchmarks to run as arguments.') return 1 for benchmark in options.benchmarks: if benchmark not in PUBLIC_BENCHMARKS: print ('%s not found in our benchmark list. The respective trybot might ' 'fail, unless you run something this script isn\'t aware of. ' 'Available public benchmarks: %s' % (benchmark, PUBLIC_BENCHMARKS)) print('Proceed anyways? [Y/n] ', end=' ') answer = sys.stdin.readline().strip() if answer != "" and answer != "Y" and answer != "y": return 1 assert '"' not in options.extra_flags and '\'' not in options.extra_flags, ( 'Invalid flag specification.') # Ensure depot_tools are updated. subprocess.check_output( 'update_depot_tools', shell=True, stderr=subprocess.STDOUT, cwd=V8_BASE) cmd = ['git cl try', '-B', 'luci.v8-internal.try'] cmd += ['-b %s' % bot for bot in options.bots] if options.revision: cmd.append('-r %s' % options.revision) benchmarks = ['"%s"' % benchmark for benchmark in options.benchmarks] cmd.append('-p \'testfilter=[%s]\'' % ','.join(benchmarks)) if options.extra_flags: cmd.append('-p \'extra_flags="%s"\'' % options.extra_flags) if options.confidence_level: cmd.append('-p confidence_level=%f' % options.confidence_level) if options.verbose: cmd.append('-vv') print('Running %s' % ' '.join(cmd)) subprocess.check_call(' '.join(cmd), shell=True, cwd=V8_BASE) if __name__ == '__main__': # pragma: no cover sys.exit(main())