summaryrefslogtreecommitdiff
path: root/benchmark/fs/bench-statSync.js
diff options
context:
space:
mode:
Diffstat (limited to 'benchmark/fs/bench-statSync.js')
-rw-r--r--benchmark/fs/bench-statSync.js37
1 files changed, 12 insertions, 25 deletions
diff --git a/benchmark/fs/bench-statSync.js b/benchmark/fs/bench-statSync.js
index 4bc2ecd65a..57e03df3b0 100644
--- a/benchmark/fs/bench-statSync.js
+++ b/benchmark/fs/bench-statSync.js
@@ -4,36 +4,23 @@ const common = require('../common');
const fs = require('fs');
const bench = common.createBenchmark(main, {
- n: [1e4],
+ n: [1e6],
kind: ['fstatSync', 'lstatSync', 'statSync']
});
function main(conf) {
const n = conf.n >>> 0;
- var fn;
- var i;
- switch (conf.kind) {
- case 'statSync':
- case 'lstatSync':
- fn = fs[conf.kind];
- bench.start();
- for (i = 0; i < n; i++) {
- fn(__filename);
- }
- bench.end(n);
- break;
- case 'fstatSync':
- fn = fs.fstatSync;
- const fd = fs.openSync(__filename, 'r');
- bench.start();
- for (i = 0; i < n; i++) {
- fn(fd);
- }
- bench.end(n);
- fs.closeSync(fd);
- break;
- default:
- throw new Error('Invalid kind argument');
+ const kind = conf.kind;
+ const arg = (kind === 'fstatSync' ? fs.openSync(__filename, 'r') : __dirname);
+ const fn = fs[conf.kind];
+
+ bench.start();
+ for (var i = 0; i < n; i++) {
+ fn(arg);
}
+ bench.end(n);
+
+ if (kind === 'fstat')
+ fs.closeSync(arg);
}