From 35ed79932c0d5adccb80ff7e734da41691a3cd00 Mon Sep 17 00:00:00 2001 From: Brian White Date: Sat, 14 Feb 2015 23:26:50 -0500 Subject: benchmark: add a few querystring benchmarks PR-URL: https://github.com/iojs/io.js/pull/847 Reviewed-By: Brendan Ashworth --- benchmark/querystring/querystring-parse.js | 33 ++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 benchmark/querystring/querystring-parse.js (limited to 'benchmark/querystring/querystring-parse.js') diff --git a/benchmark/querystring/querystring-parse.js b/benchmark/querystring/querystring-parse.js new file mode 100644 index 0000000000..3d88bed07d --- /dev/null +++ b/benchmark/querystring/querystring-parse.js @@ -0,0 +1,33 @@ +var common = require('../common.js'); +var querystring = require('querystring'); +var v8 = require('v8'); + +var bench = common.createBenchmark(main, { + type: ['noencode', 'encodemany', 'encodelast'], + n: [1e6], +}); + +function main(conf) { + var type = conf.type; + var n = conf.n | 0; + + var inputs = { + noencode: 'foo=bar&baz=quux&xyzzy=thud', + encodemany: '%66%6F%6F=bar&%62%61%7A=quux&xyzzy=%74h%75d', + encodelast: 'foo=bar&baz=quux&xyzzy=thu%64' + }; + var input = inputs[type]; + + // Force-optimize querystring.parse() so that the benchmark doesn't get + // disrupted by the optimizer kicking in halfway through. + for (var name in inputs) + querystring.parse(inputs[name]); + + v8.setFlagsFromString('--allow_natives_syntax'); + eval('%OptimizeFunctionOnNextCall(querystring.parse)'); + + bench.start(); + for (var i = 0; i < n; i += 1) + querystring.parse(input); + bench.end(n); +} -- cgit v1.2.3