3d7f88fb31
Reviewed-by: sundar, attila
288 lines
8.1 KiB
JavaScript
288 lines
8.1 KiB
JavaScript
/*
|
|
* Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
* accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU General Public License version
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
* questions.
|
|
*/
|
|
|
|
/**
|
|
* @subtest
|
|
*/
|
|
|
|
var read;
|
|
try {
|
|
read = readFully;
|
|
} catch (e) {
|
|
print("ABORTING: Cannot find 'readFully'. You must have scripting enabled to use this test harness. (-scripting)");
|
|
throw e;
|
|
}
|
|
|
|
function initZlib() {
|
|
zlib = new BenchmarkSuite('zlib', [152815148], [
|
|
new Benchmark('zlib', false, true, 10,
|
|
runZlib, undefined, tearDownZlib, null, 3)]);
|
|
}
|
|
|
|
var tests = [
|
|
{name:"box2d", files:["box2d.js"], suite:"Box2DBenchmark"},
|
|
{name:"code-load", files:["code-load.js"], suite:"CodeLoad"},
|
|
{name:"crypto", files:["crypto.js"], suite:"Crypto"},
|
|
{name:"deltablue", files:["deltablue.js"], suite:"DeltaBlue"},
|
|
{name:"earley-boyer", files:["earley-boyer.js"], suite:"EarleyBoyer"},
|
|
{name:"gbemu", files:["gbemu-part1.js", "gbemu-part2.js"], suite:"GameboyBenchmark"},
|
|
{name:"mandreel", files:["mandreel.js"], suite:"MandreelBenchmark"},
|
|
{name:"navier-stokes", files:["navier-stokes.js"], suite:"NavierStokes"},
|
|
{name:"pdfjs", files:["pdfjs.js"], suite:"PdfJS"},
|
|
{name:"raytrace", files:["raytrace.js"], suite:"RayTrace"},
|
|
{name:"regexp", files:["regexp.js"], suite:"RegExpSuite"},
|
|
{name:"richards", files:["richards.js"], suite:"Richards"},
|
|
{name:"splay", files:["splay.js"], suite:"Splay"},
|
|
{name:"typescript", files:["typescript.js", "typescript-input.js", "typescript-compiler.js"], suite:"typescript"},
|
|
//zlib currently disabled - requires read
|
|
{name:"zlib", files:["zlib.js", "zlib-data.js"], suite:"zlib", before:initZlib}
|
|
];
|
|
var dir = (typeof(__DIR__) == 'undefined') ? "test/script/basic/" : __DIR__;
|
|
|
|
// TODO: why is this path hard coded when it's defined in project properties?
|
|
var path = dir + "../external/octane/";
|
|
|
|
var runtime = "";
|
|
var verbose = false;
|
|
|
|
var numberOfIterations = 5;
|
|
|
|
function endsWith(str, suffix) {
|
|
return str.indexOf(suffix, str.length - suffix.length) !== -1;
|
|
}
|
|
|
|
function should_compile_only(name) {
|
|
return (typeof compile_only !== 'undefined')
|
|
}
|
|
|
|
function load_bench(arg) {
|
|
|
|
for (var idx = 0; idx < arg.files.length; idx++) {
|
|
var f = arg.files[idx];
|
|
var file = f.split('/');
|
|
var file_name = path + file[file.length - 1];
|
|
|
|
var compile_and_return = should_compile_only(file_name);
|
|
if (compile_and_return) {
|
|
if (typeof compile_only === 'undefined') { //for a run, skip compile onlies, don't even compile them
|
|
return true;
|
|
}
|
|
}
|
|
|
|
print_verbose(arg, "loading '" + arg.name + "' [" + f + "]...");
|
|
load(file_name);
|
|
}
|
|
|
|
if (typeof arg.before !== 'undefined') {
|
|
arg.before();
|
|
}
|
|
|
|
if (compile_and_return) {
|
|
print_always(arg, "Compiled OK");
|
|
}
|
|
return !compile_and_return;
|
|
|
|
}
|
|
|
|
|
|
function run_one_benchmark(arg, iters) {
|
|
|
|
if (!load_bench(arg)) {
|
|
return;
|
|
}
|
|
|
|
var success = true;
|
|
var current_name;
|
|
|
|
if (iters == undefined) {
|
|
iters = numberOfIterations;
|
|
} else {
|
|
numberOfIterations = iters;
|
|
}
|
|
|
|
var benchmarks = eval(arg.suite + ".benchmarks");
|
|
var min_score = 1e9;
|
|
var max_score = 0;
|
|
var mean_score = 0;
|
|
|
|
try {
|
|
for (var x = 0; x < benchmarks.length ; x++) {
|
|
//do warmup run
|
|
//reset random number generator needed as of octane 9 before each run
|
|
BenchmarkSuite.ResetRNG();
|
|
benchmarks[x].Setup();
|
|
}
|
|
BenchmarkSuite.ResetRNG();
|
|
print_verbose(arg, "running '" + arg.name + "' for " + iters + " iterations of no less than " + min_time + " seconds (" + runtime + ")");
|
|
|
|
var scores = [];
|
|
|
|
var min_time_ms = min_time * 1000;
|
|
var len = benchmarks.length;
|
|
|
|
for (var it = 0; it < iters + 1; it++) {
|
|
//every iteration must take a minimum of 10 secs
|
|
var ops = 0;
|
|
var elapsed = 0;
|
|
var start = new Date;
|
|
do {
|
|
for (var i = 0; i < len; i++) {
|
|
benchmarks[i].run();
|
|
//important - no timing here like elapsed = new Date() - start, as in the
|
|
//original harness. This will make timing very non-deterministic.
|
|
//NOTHING else must live in this loop
|
|
}
|
|
ops += len;
|
|
elapsed = new Date - start;
|
|
} while (elapsed < min_time * 1000);
|
|
|
|
var score = ops / elapsed * 1000 * 60;
|
|
scores.push(score);
|
|
var name = it == 0 ? "warmup" : "iteration " + it;
|
|
print_verbose(arg, name + " finished " + score.toFixed(0) + " ops/minute");
|
|
}
|
|
|
|
for (var x = 0; x < benchmarks.length ; x++) {
|
|
benchmarks[x].TearDown();
|
|
}
|
|
|
|
for (var x = 1; x < iters + 1 ; x++) {
|
|
mean_score += scores[x];
|
|
min_score = Math.min(min_score, scores[x]);
|
|
max_score = Math.max(max_score, scores[x]);
|
|
}
|
|
mean_score /= iters;
|
|
} catch (e) {
|
|
print_always(arg, "*** Aborted and setting score to zero. Reason: " + e);
|
|
if (e instanceof java.lang.Throwable) {
|
|
e.printStackTrace();
|
|
}
|
|
mean_score = min_score = max_score = 0;
|
|
scores = [0];
|
|
}
|
|
|
|
var res = mean_score.toFixed(0);
|
|
if (verbose) {
|
|
res += " ops/minute (" + min_score.toFixed(0) + "-" + max_score.toFixed(0) + "), warmup=" + scores[0].toFixed(0);
|
|
}
|
|
print_always(arg, res);
|
|
}
|
|
|
|
function print_always(arg, x) {
|
|
print("[" + arg.name + "] " + x);
|
|
}
|
|
|
|
function print_verbose(arg, x) {
|
|
if (verbose) {
|
|
print_always(arg, x)
|
|
}
|
|
}
|
|
|
|
function run_suite(tests, iters) {
|
|
for (var idx = 0; idx < tests.length; idx++) {
|
|
run_one_benchmark(tests[idx], iters);
|
|
}
|
|
}
|
|
|
|
runtime = "command line";
|
|
|
|
var args = [];
|
|
|
|
if (typeof $ARGS !== 'undefined') {
|
|
args = $ARGS;
|
|
} else if (typeof arguments !== 'undefined' && arguments.length != 0) {
|
|
args = arguments;
|
|
}
|
|
|
|
var new_args = [];
|
|
for (i in args) {
|
|
if (args[i].toString().indexOf(' ') != -1) {
|
|
args[i] = args[i].replace(/\/$/, '');
|
|
var s = args[i].split(' ');
|
|
for (j in s) {
|
|
new_args.push(s[j]);
|
|
}
|
|
} else {
|
|
new_args.push(args[i]);
|
|
}
|
|
}
|
|
|
|
if (new_args.length != 0) {
|
|
args = new_args;
|
|
}
|
|
|
|
var tests_found = [];
|
|
var iters = undefined;
|
|
var min_time = 5;
|
|
|
|
for (var i = 0; i < args.length; i++) {
|
|
arg = args[i];
|
|
if (arg == "--iterations") {
|
|
iters = +args[++i];
|
|
if (isNaN(iters)) {
|
|
throw "'--iterations' must be followed by integer";
|
|
}
|
|
} else if (arg == "--runtime") {
|
|
runtime = args[++i];
|
|
} else if (arg == "--verbose") {
|
|
verbose = true;
|
|
} else if (arg == "--min-time") {
|
|
min_time = +args[++i];
|
|
if (isNaN(iters)) {
|
|
throw "'--min-time' must be followed by integer";
|
|
}
|
|
} else if (arg == "") {
|
|
continue; //skip
|
|
} else {
|
|
var found = false;
|
|
for (j in tests) {
|
|
if (tests[j].name === arg) {
|
|
tests_found.push(tests[j]);
|
|
found = true;
|
|
break;
|
|
}
|
|
}
|
|
if (!found) {
|
|
var str = "unknown test name: '" + arg + "' -- valid names are: ";
|
|
for (j in tests) {
|
|
if (j != 0) {
|
|
str += ", ";
|
|
}
|
|
str += "'" + tests[j].name + "'";
|
|
}
|
|
throw str;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (tests_found.length == 0) {
|
|
for (i in tests) {
|
|
tests_found.push(tests[i]);
|
|
}
|
|
}
|
|
|
|
tests_found.sort();
|
|
|
|
load(path + 'base.js');
|
|
run_suite(tests_found, iters);
|