summaryrefslogtreecommitdiff
path: root/benchmark/fs
diff options
context:
space:
mode:
authorBrian White <mscdex@mscdex.net>2017-03-11 19:41:20 -0500
committerJames M Snell <jasnell@gmail.com>2017-03-14 21:54:40 -0700
commit6a5ab5d550719f416683ec0d588461b8bc9a8787 (patch)
treed76b6d99dfa477021a8bcf8e7d0dbbc90fb3e23f /benchmark/fs
parent3d7245c0989878dc708df06151fa2426c251a03a (diff)
downloadandroid-node-v8-6a5ab5d550719f416683ec0d588461b8bc9a8787.tar.gz
android-node-v8-6a5ab5d550719f416683ec0d588461b8bc9a8787.tar.bz2
android-node-v8-6a5ab5d550719f416683ec0d588461b8bc9a8787.zip
fs: include more fs.stat*() optimizations
Including: * Move async *stat() functions to FillStatsArray() now used by the sync *stat() functions * Avoid creating fs.Stats instances for implicit async/sync *stat() calls used in various fs functions * Store reference to Float64Array data on C++ side for easier/faster access, instead of passing from JS to C++ on every async/sync *stat() call PR-URL: https://github.com/nodejs/node/pull/11665 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Diffstat (limited to 'benchmark/fs')
-rw-r--r--benchmark/fs/bench-stat.js22
-rw-r--r--benchmark/fs/bench-statSync.js37
-rw-r--r--benchmark/fs/readFileSync.js17
3 files changed, 45 insertions, 31 deletions
diff --git a/benchmark/fs/bench-stat.js b/benchmark/fs/bench-stat.js
index c0db00e27d..149b4f3d3b 100644
--- a/benchmark/fs/bench-stat.js
+++ b/benchmark/fs/bench-stat.js
@@ -4,20 +4,30 @@ const common = require('../common');
const fs = require('fs');
const bench = common.createBenchmark(main, {
- n: [1e4],
- kind: ['lstat', 'stat']
+ n: [20e4],
+ kind: ['fstat', 'lstat', 'stat']
});
function main(conf) {
const n = conf.n >>> 0;
+ const kind = conf.kind;
+ var arg;
+ if (kind === 'fstat')
+ arg = fs.openSync(__filename, 'r');
+ else
+ arg = __filename;
bench.start();
(function r(cntr, fn) {
- if (cntr-- <= 0)
- return bench.end(n);
- fn(__filename, function() {
+ if (cntr-- <= 0) {
+ bench.end(n);
+ if (kind === 'fstat')
+ fs.closeSync(arg);
+ return;
+ }
+ fn(arg, function() {
r(cntr, fn);
});
- }(n, fs[conf.kind]));
+ }(n, fs[kind]));
}
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);
}
diff --git a/benchmark/fs/readFileSync.js b/benchmark/fs/readFileSync.js
new file mode 100644
index 0000000000..7c8f5d240d
--- /dev/null
+++ b/benchmark/fs/readFileSync.js
@@ -0,0 +1,17 @@
+'use strict';
+
+var common = require('../common.js');
+var fs = require('fs');
+
+var bench = common.createBenchmark(main, {
+ n: [60e4]
+});
+
+function main(conf) {
+ var n = +conf.n;
+
+ bench.start();
+ for (var i = 0; i < n; ++i)
+ fs.readFileSync(__filename);
+ bench.end(n);
+}