benchmark: add remaining path benchmarks & optimize
As a follow-up to 0d15161, this commit adds benchmarks for the rest of the path functions and also forces V8 to optimize the functions before starting the benchmark test. PR-URL: https://github.com/nodejs/io.js/pull/2103 Reviewed-By: Brendan Ashworth <brendan.ashworth@me.com>
This commit is contained in:
parent
ac70bc8240
commit
99d9d7e716
26
benchmark/path/basename.js
Normal file
26
benchmark/path/basename.js
Normal file
@ -0,0 +1,26 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
n: [1e6],
|
||||
});
|
||||
|
||||
function main(conf) {
|
||||
var n = +conf.n;
|
||||
var p = path[conf.type];
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.basename('/foo/bar/baz/asdf/quux.html');
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.basename)');
|
||||
p.basename('/foo/bar/baz/asdf/quux.html');
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
p.basename('/foo/bar/baz/asdf/quux.html');
|
||||
p.basename('/foo/bar/baz/asdf/quux.html', '.html');
|
||||
}
|
||||
bench.end(n);
|
||||
}
|
25
benchmark/path/dirname.js
Normal file
25
benchmark/path/dirname.js
Normal file
@ -0,0 +1,25 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
n: [1e6],
|
||||
});
|
||||
|
||||
function main(conf) {
|
||||
var n = +conf.n;
|
||||
var p = path[conf.type];
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.dirname('/foo/bar/baz/asdf/quux');
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.dirname)');
|
||||
p.dirname('/foo/bar/baz/asdf/quux');
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
p.dirname('/foo/bar/baz/asdf/quux');
|
||||
}
|
||||
bench.end(n);
|
||||
}
|
26
benchmark/path/extname.js
Normal file
26
benchmark/path/extname.js
Normal file
@ -0,0 +1,26 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
n: [1e6],
|
||||
});
|
||||
|
||||
function main(conf) {
|
||||
var n = +conf.n;
|
||||
var p = path[conf.type];
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.extname('index.html');
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.extname)');
|
||||
p.extname('index.html');
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
p.extname('index.html');
|
||||
p.extname('index');
|
||||
}
|
||||
bench.end(n);
|
||||
}
|
@ -1,5 +1,6 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
@ -23,6 +24,12 @@ function main(conf) {
|
||||
name : 'index'
|
||||
};
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.format(test);
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.format)');
|
||||
p.format(test);
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
p.format(test);
|
||||
|
@ -1,5 +1,6 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
@ -13,6 +14,12 @@ function main(conf) {
|
||||
? ['//server', 'C:\\baz\\..', 'bar\\baz', '.']
|
||||
: ['/foo/bar', '/baz/..', 'bar/baz', '.'];
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.isAbsolute(tests[0]);
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.isAbsolute)');
|
||||
p.isAbsolute(tests[0]);
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
runTests(p, tests);
|
||||
|
@ -1,5 +1,6 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
@ -10,6 +11,12 @@ function main(conf) {
|
||||
var n = +conf.n;
|
||||
var p = path[conf.type];
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.join('/foo', 'bar', '', 'baz/asdf', 'quux', '..');
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.join)');
|
||||
p.join('/foo', 'bar', '', 'baz/asdf', 'quux', '..');
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
p.join('/foo', 'bar', '', 'baz/asdf', 'quux', '..');
|
||||
|
@ -1,5 +1,6 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
@ -10,6 +11,12 @@ function main(conf) {
|
||||
var n = +conf.n;
|
||||
var p = path[conf.type];
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.normalize('/foo/bar//baz/asdf/quux/..');
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.normalize)');
|
||||
p.normalize('/foo/bar//baz/asdf/quux/..');
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
p.normalize('/foo/bar//baz/asdf/quux/..');
|
||||
|
28
benchmark/path/parse.js
Normal file
28
benchmark/path/parse.js
Normal file
@ -0,0 +1,28 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
n: [1e6],
|
||||
});
|
||||
|
||||
function main(conf) {
|
||||
var n = +conf.n;
|
||||
var p = path[conf.type];
|
||||
var test = conf.type === 'win32'
|
||||
? 'C:\\path\\dir\\index.html'
|
||||
: '/home/user/dir/index.html';
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.parse(test);
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.parse)');
|
||||
p.parse(test);
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
p.parse(test);
|
||||
}
|
||||
bench.end(n);
|
||||
}
|
@ -1,5 +1,6 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
@ -10,6 +11,12 @@ function main(conf) {
|
||||
var n = +conf.n;
|
||||
var runTest = conf.type === 'win32' ? runWin32Test : runPosixTest;
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
runTest();
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(path[conf.type].relative)');
|
||||
runTest();
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
runTest();
|
||||
|
@ -1,5 +1,6 @@
|
||||
var common = require('../common.js');
|
||||
var path = require('path');
|
||||
var v8 = require('v8');
|
||||
|
||||
var bench = common.createBenchmark(main, {
|
||||
type: ['win32', 'posix'],
|
||||
@ -10,6 +11,12 @@ function main(conf) {
|
||||
var n = +conf.n;
|
||||
var p = path[conf.type];
|
||||
|
||||
// Force optimization before starting the benchmark
|
||||
p.resolve('foo/bar', '/tmp/file/', '..', 'a/../subfile');
|
||||
v8.setFlagsFromString('--allow_natives_syntax');
|
||||
eval('%OptimizeFunctionOnNextCall(p.resolve)');
|
||||
p.resolve('foo/bar', '/tmp/file/', '..', 'a/../subfile');
|
||||
|
||||
bench.start();
|
||||
for (var i = 0; i < n; i++) {
|
||||
p.resolve('foo/bar', '/tmp/file/', '..', 'a/../subfile');
|
||||
|
Loading…
x
Reference in New Issue
Block a user