2009-11-01 03:06:46 +08:00
|
|
|
var path = require("path");
|
2010-10-12 05:04:09 +08:00
|
|
|
var util = require("util");
|
2010-03-23 09:47:04 +08:00
|
|
|
var childProcess = require("child_process");
|
|
|
|
var benchmarks = [ "timers.js"
|
2009-07-13 18:48:59 +08:00
|
|
|
, "process_loop.js"
|
2010-03-23 09:47:04 +08:00
|
|
|
, "static_http_server.js"
|
2009-07-13 18:48:59 +08:00
|
|
|
];
|
|
|
|
|
2010-03-09 11:06:25 +08:00
|
|
|
var benchmarkDir = path.dirname(__filename);
|
2009-07-13 18:48:59 +08:00
|
|
|
|
|
|
|
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)]);
|
2009-08-27 04:11:51 +08:00
|
|
|
child.addListener("exit", function (code) {
|
2009-07-13 18:48:59 +08:00
|
|
|
var elapsed = new Date() - start;
|
|
|
|
callback(elapsed, code);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function runNext (i) {
|
|
|
|
if (i >= benchmarks.length) return;
|
2010-10-12 05:04:09 +08:00
|
|
|
util.print(benchmarks[i] + ": ");
|
2009-07-13 18:48:59 +08:00
|
|
|
exec(benchmarks[i], function (elapsed, code) {
|
|
|
|
if (code != 0) {
|
2010-06-24 08:40:51 +08:00
|
|
|
console.log("ERROR ");
|
2009-07-13 18:48:59 +08:00
|
|
|
}
|
2010-06-24 08:40:51 +08:00
|
|
|
console.log(elapsed);
|
2009-07-13 18:48:59 +08:00
|
|
|
runNext(i+1);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
runNext(0);
|