benchmark: clean up legacy url benchmarks
PR-URL: https://github.com/nodejs/node/pull/11264 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Brian White <mscdex@mscdex.net>
This commit is contained in:
parent
d8ac08a62a
commit
7ee95045dd
@ -2,20 +2,7 @@
|
|||||||
var common = require('../common.js');
|
var common = require('../common.js');
|
||||||
var querystring = require('querystring');
|
var querystring = require('querystring');
|
||||||
var v8 = require('v8');
|
var v8 = require('v8');
|
||||||
|
var inputs = require('../fixtures/url-inputs.js').searchParams;
|
||||||
var inputs = {
|
|
||||||
noencode: 'foo=bar&baz=quux&xyzzy=thud',
|
|
||||||
multicharsep: 'foo=bar&&&&&&&&&&baz=quux&&&&&&&&&&xyzzy=thud',
|
|
||||||
encodefake: 'foo=%©ar&baz=%A©uux&xyzzy=%©ud',
|
|
||||||
encodemany: '%66%6F%6F=bar&%62%61%7A=quux&xyzzy=%74h%75d',
|
|
||||||
encodelast: 'foo=bar&baz=quux&xyzzy=thu%64',
|
|
||||||
multivalue: 'foo=bar&foo=baz&foo=quux&quuy=quuz',
|
|
||||||
multivaluemany: 'foo=bar&foo=baz&foo=quux&quuy=quuz&foo=abc&foo=def&' +
|
|
||||||
'foo=ghi&foo=jkl&foo=mno&foo=pqr&foo=stu&foo=vwxyz',
|
|
||||||
manypairs: 'a&b&c&d&e&f&g&h&i&j&k&l&m&n&o&p&q&r&s&t&u&v&w&x&y&z',
|
|
||||||
manyblankpairs: '&&&&&&&&&&&&&&&&&&&&&&&&',
|
|
||||||
altspaces: 'foo+bar=baz+quux&xyzzy+thud=quuy+quuz&abc=def+ghi'
|
|
||||||
};
|
|
||||||
|
|
||||||
var bench = common.createBenchmark(main, {
|
var bench = common.createBenchmark(main, {
|
||||||
type: Object.keys(inputs),
|
type: Object.keys(inputs),
|
||||||
|
@ -3,8 +3,13 @@ const common = require('../common.js');
|
|||||||
const url = require('url');
|
const url = require('url');
|
||||||
const v8 = require('v8');
|
const v8 = require('v8');
|
||||||
|
|
||||||
|
const inputs = {
|
||||||
|
slashes: {slashes: true, host: 'localhost'},
|
||||||
|
file: {protocol: 'file:', pathname: '/foo'},
|
||||||
|
};
|
||||||
|
|
||||||
const bench = common.createBenchmark(main, {
|
const bench = common.createBenchmark(main, {
|
||||||
type: 'one two'.split(' '),
|
type: Object.keys(inputs),
|
||||||
n: [25e6]
|
n: [25e6]
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -12,10 +17,6 @@ function main(conf) {
|
|||||||
const type = conf.type;
|
const type = conf.type;
|
||||||
const n = conf.n | 0;
|
const n = conf.n | 0;
|
||||||
|
|
||||||
const inputs = {
|
|
||||||
one: {slashes: true, host: 'localhost'},
|
|
||||||
two: {protocol: 'file:', pathname: '/foo'},
|
|
||||||
};
|
|
||||||
const input = inputs[type] || '';
|
const input = inputs[type] || '';
|
||||||
|
|
||||||
// Force-optimize url.format() so that the benchmark doesn't get
|
// Force-optimize url.format() so that the benchmark doesn't get
|
||||||
|
@ -1,37 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
var common = require('../common.js');
|
|
||||||
var url = require('url');
|
|
||||||
var v8 = require('v8');
|
|
||||||
|
|
||||||
var bench = common.createBenchmark(main, {
|
|
||||||
type: 'one two three four five six'.split(' '),
|
|
||||||
n: [25e4]
|
|
||||||
});
|
|
||||||
|
|
||||||
function main(conf) {
|
|
||||||
var type = conf.type;
|
|
||||||
var n = conf.n | 0;
|
|
||||||
|
|
||||||
var inputs = {
|
|
||||||
one: 'http://nodejs.org/docs/latest/api/url.html#url_url_format_urlobj',
|
|
||||||
two: 'http://blog.nodejs.org/',
|
|
||||||
three: 'https://encrypted.google.com/search?q=url&q=site:npmjs.org&hl=en',
|
|
||||||
four: 'javascript:alert("node is awesome");',
|
|
||||||
five: 'some.ran/dom/url.thing?oh=yes#whoo',
|
|
||||||
six: 'https://user:pass@example.com/',
|
|
||||||
};
|
|
||||||
var input = inputs[type] || '';
|
|
||||||
|
|
||||||
// Force-optimize url.parse() so that the benchmark doesn't get
|
|
||||||
// disrupted by the optimizer kicking in halfway through.
|
|
||||||
for (var name in inputs)
|
|
||||||
url.parse(inputs[name]);
|
|
||||||
|
|
||||||
v8.setFlagsFromString('--allow_natives_syntax');
|
|
||||||
eval('%OptimizeFunctionOnNextCall(url.parse)');
|
|
||||||
|
|
||||||
bench.start();
|
|
||||||
for (var i = 0; i < n; i += 1)
|
|
||||||
url.parse(input);
|
|
||||||
bench.end(n);
|
|
||||||
}
|
|
@ -1,36 +1,28 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
var common = require('../common.js');
|
const common = require('../common.js');
|
||||||
var url = require('url');
|
const url = require('url');
|
||||||
var v8 = require('v8');
|
const v8 = require('v8');
|
||||||
|
const hrefs = require('../fixtures/url-inputs.js').urls;
|
||||||
|
hrefs.noscheme = 'some.ran/dom/url.thing?oh=yes#whoo';
|
||||||
|
|
||||||
var hrefs = [
|
const paths = {
|
||||||
'http://example.com/',
|
'up': '../../../../../etc/passwd',
|
||||||
'http://nodejs.org/docs/latest/api/url.html#url_url_format_urlobj',
|
'sibling': '../foo/bar?baz=boom',
|
||||||
'http://blog.nodejs.org/',
|
'foo/bar': 'foo/bar',
|
||||||
'https://encrypted.google.com/search?q=url&q=site:npmjs.org&hl=en',
|
'withscheme': 'http://nodejs.org',
|
||||||
'javascript:alert("node is awesome");',
|
'down': './foo/bar?baz'
|
||||||
'some.ran/dom/url.thing?oh=yes#whoo'
|
};
|
||||||
];
|
|
||||||
|
|
||||||
|
const bench = common.createBenchmark(main, {
|
||||||
var paths = [
|
|
||||||
'../../../../../etc/passwd',
|
|
||||||
'../foo/bar?baz=boom',
|
|
||||||
'foo/bar',
|
|
||||||
'http://nodejs.org',
|
|
||||||
'./foo/bar?baz'
|
|
||||||
];
|
|
||||||
|
|
||||||
var bench = common.createBenchmark(main, {
|
|
||||||
href: Object.keys(hrefs),
|
href: Object.keys(hrefs),
|
||||||
path: Object.keys(paths),
|
path: Object.keys(paths),
|
||||||
n: [1e5]
|
n: [1e5]
|
||||||
});
|
});
|
||||||
|
|
||||||
function main(conf) {
|
function main(conf) {
|
||||||
var n = conf.n | 0;
|
const n = conf.n | 0;
|
||||||
var href = hrefs[conf.href];
|
const href = hrefs[conf.href];
|
||||||
var path = paths[conf.path];
|
const path = paths[conf.path];
|
||||||
|
|
||||||
// Force-optimize url.resolve() so that the benchmark doesn't get
|
// Force-optimize url.resolve() so that the benchmark doesn't get
|
||||||
// disrupted by the optimizer kicking in halfway through.
|
// disrupted by the optimizer kicking in halfway through.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user