node/benchmark/run.js

32 lines
813 B
JavaScript
Raw Normal View History

var path = require("path");
2010-03-23 09:47:04 +08:00
var sys = require("sys");
var childProcess = require("child_process");
var benchmarks = [ "timers.js"
, "process_loop.js"
2010-03-23 09:47:04 +08:00
, "static_http_server.js"
];
2010-03-09 11:06:25 +08:00
var benchmarkDir = path.dirname(__filename);
function exec (script, callback) {
var start = new Date();
2010-03-23 09:47:04 +08:00
var child = childProcess.spawn(process.argv[0], [path.join(benchmarkDir, script)]);
child.addListener("exit", function (code) {
var elapsed = new Date() - start;
callback(elapsed, code);
});
}
function runNext (i) {
if (i >= benchmarks.length) return;
2010-03-09 11:06:25 +08:00
sys.print(benchmarks[i] + ": ");
exec(benchmarks[i], function (elapsed, code) {
if (code != 0) {
console.log("ERROR ");
}
console.log(elapsed);
runNext(i+1);
});
};
runNext(0);