From 5e124d7ff33195bd5ed64891b34cd8f56809b3fc Mon Sep 17 00:00:00 2001 From: Sergey Chernyshev Date: Thu, 25 Apr 2024 01:53:31 +0200 Subject: [PATCH] benchmark: differentiate whatwg and legacy url PR-URL: /~https://github.com/nodejs/node/pull/47377 Reviewed-By: Benjamin Gruenbaum Reviewed-By: Tiancheng "Timothy" Gu Reviewed-By: Matthew Aitken --- .../benchmark/url/legacy-url-get-prop.js | 41 +++++++++ .../benchmark/url/legacy-url-parse.js | 22 +++++ .../url/legacy-vs-whatwg-url-get-prop.js | 90 ------------------- ...url-canParse.js => whatwg-url-canParse.js} | 0 .../benchmark/url/whatwg-url-get-prop.js | 40 +++++++++ ...hatwg-url-parse.js => whatwg-url-parse.js} | 30 +------ ...path.js => whatwg-url-to-and-from-path.js} | 0 7 files changed, 106 insertions(+), 117 deletions(-) create mode 100644 graal-nodejs/benchmark/url/legacy-url-get-prop.js create mode 100644 graal-nodejs/benchmark/url/legacy-url-parse.js delete mode 100644 graal-nodejs/benchmark/url/legacy-vs-whatwg-url-get-prop.js rename graal-nodejs/benchmark/url/{whatwgurl-canParse.js => whatwg-url-canParse.js} (100%) create mode 100644 graal-nodejs/benchmark/url/whatwg-url-get-prop.js rename graal-nodejs/benchmark/url/{legacy-vs-whatwg-url-parse.js => whatwg-url-parse.js} (53%) rename graal-nodejs/benchmark/url/{whatwgurl-to-and-from-path.js => whatwg-url-to-and-from-path.js} (100%) diff --git a/graal-nodejs/benchmark/url/legacy-url-get-prop.js b/graal-nodejs/benchmark/url/legacy-url-get-prop.js new file mode 100644 index 00000000000..09be863e963 --- /dev/null +++ b/graal-nodejs/benchmark/url/legacy-url-get-prop.js @@ -0,0 +1,41 @@ +'use strict'; +const common = require('../common.js'); +const url = require('url'); +const assert = require('assert'); + +const bench = common.createBenchmark(main, { + type: common.urlDataTypes, + e: [1], +}); + +function main({ type, e }) { + const data = common.bakeUrlData(type, e, false, false).map((i) => url.parse(i)); + const obj = url.parse(data[0]); + const noDead = { + protocol: obj.protocol, + auth: obj.auth, + host: obj.host, + hostname: obj.hostname, + port: obj.port, + pathname: obj.pathname, + search: obj.search, + hash: obj.hash, + }; + const len = data.length; + // It's necessary to assign the values to an object + // to avoid loop invariant code motion. + bench.start(); + for (let i = 0; i < len; i++) { + const obj = data[i]; + noDead.protocol = obj.protocol; + noDead.auth = obj.auth; + noDead.host = obj.host; + noDead.hostname = obj.hostname; + noDead.port = obj.port; + noDead.pathname = obj.pathname; + noDead.search = obj.search; + noDead.hash = obj.hash; + } + bench.end(len); + assert.ok(noDead); +} diff --git a/graal-nodejs/benchmark/url/legacy-url-parse.js b/graal-nodejs/benchmark/url/legacy-url-parse.js new file mode 100644 index 00000000000..ac893ebf8ad --- /dev/null +++ b/graal-nodejs/benchmark/url/legacy-url-parse.js @@ -0,0 +1,22 @@ +'use strict'; +const common = require('../common.js'); +const url = require('url'); +const assert = require('assert'); + +const bench = common.createBenchmark(main, { + type: common.urlDataTypes, + e: [1], +}); + +function main({ e, type }) { + const data = common.bakeUrlData(type, e, false, false); + let result = url.parse(data[0]); // Avoid dead code elimination + + bench.start(); + for (let i = 0; i < data.length; ++i) { + result = url.parse(data[i]); + } + bench.end(data.length); + + assert.ok(result); +} diff --git a/graal-nodejs/benchmark/url/legacy-vs-whatwg-url-get-prop.js b/graal-nodejs/benchmark/url/legacy-vs-whatwg-url-get-prop.js deleted file mode 100644 index df888f13b98..00000000000 --- a/graal-nodejs/benchmark/url/legacy-vs-whatwg-url-get-prop.js +++ /dev/null @@ -1,90 +0,0 @@ -'use strict'; -const common = require('../common.js'); -const url = require('url'); -const URL = url.URL; -const assert = require('assert'); - -const bench = common.createBenchmark(main, { - type: common.urlDataTypes, - method: ['legacy', 'whatwg'], - e: [1], -}); - -function useLegacy(data) { - const obj = url.parse(data[0]); - const noDead = { - protocol: obj.protocol, - auth: obj.auth, - host: obj.host, - hostname: obj.hostname, - port: obj.port, - pathname: obj.pathname, - search: obj.search, - hash: obj.hash, - }; - const len = data.length; - // It's necessary to assign the values to an object - // to avoid loop invariant code motion. - bench.start(); - for (let i = 0; i < len; i++) { - const obj = data[i]; - noDead.protocol = obj.protocol; - noDead.auth = obj.auth; - noDead.host = obj.host; - noDead.hostname = obj.hostname; - noDead.port = obj.port; - noDead.pathname = obj.pathname; - noDead.search = obj.search; - noDead.hash = obj.hash; - } - bench.end(len); - return noDead; -} - -function useWHATWG(data) { - const obj = new URL(data[0]); - const noDead = { - protocol: obj.protocol, - auth: `${obj.username}:${obj.password}`, - host: obj.host, - hostname: obj.hostname, - port: obj.port, - pathname: obj.pathname, - search: obj.search, - hash: obj.hash, - }; - const len = data.length; - bench.start(); - for (let i = 0; i < len; i++) { - const obj = data[i]; - noDead.protocol = obj.protocol; - noDead.auth = `${obj.username}:${obj.password}`; - noDead.host = obj.host; - noDead.hostname = obj.hostname; - noDead.port = obj.port; - noDead.pathname = obj.pathname; - noDead.search = obj.search; - noDead.hash = obj.hash; - } - bench.end(len); - return noDead; -} - -function main({ type, method, e }) { - let data; - let noDead; // Avoid dead code elimination. - switch (method) { - case 'legacy': - data = common.bakeUrlData(type, e, false, false); - noDead = useLegacy(data.map((i) => url.parse(i))); - break; - case 'whatwg': - data = common.bakeUrlData(type, e, false, true); - noDead = useWHATWG(data); - break; - default: - throw new Error(`Unknown method "${method}"`); - } - - assert.ok(noDead); -} diff --git a/graal-nodejs/benchmark/url/whatwgurl-canParse.js b/graal-nodejs/benchmark/url/whatwg-url-canParse.js similarity index 100% rename from graal-nodejs/benchmark/url/whatwgurl-canParse.js rename to graal-nodejs/benchmark/url/whatwg-url-canParse.js diff --git a/graal-nodejs/benchmark/url/whatwg-url-get-prop.js b/graal-nodejs/benchmark/url/whatwg-url-get-prop.js new file mode 100644 index 00000000000..3a88dd1da6f --- /dev/null +++ b/graal-nodejs/benchmark/url/whatwg-url-get-prop.js @@ -0,0 +1,40 @@ +'use strict'; +const common = require('../common.js'); +const url = require('url'); +const URL = url.URL; +const assert = require('assert'); + +const bench = common.createBenchmark(main, { + type: common.urlDataTypes, + e: [1], +}); + +function main({ type, e }) { + const data = common.bakeUrlData(type, e, false, true); + const obj = new URL(data[0]); + const noDead = { + protocol: obj.protocol, + auth: `${obj.username}:${obj.password}`, + host: obj.host, + hostname: obj.hostname, + port: obj.port, + pathname: obj.pathname, + search: obj.search, + hash: obj.hash, + }; + const len = data.length; + bench.start(); + for (let i = 0; i < len; i++) { + const obj = data[i]; + noDead.protocol = obj.protocol; + noDead.auth = `${obj.username}:${obj.password}`; + noDead.host = obj.host; + noDead.hostname = obj.hostname; + noDead.port = obj.port; + noDead.pathname = obj.pathname; + noDead.search = obj.search; + noDead.hash = obj.hash; + } + bench.end(len); + assert.ok(noDead); +} diff --git a/graal-nodejs/benchmark/url/legacy-vs-whatwg-url-parse.js b/graal-nodejs/benchmark/url/whatwg-url-parse.js similarity index 53% rename from graal-nodejs/benchmark/url/legacy-vs-whatwg-url-parse.js rename to graal-nodejs/benchmark/url/whatwg-url-parse.js index a54d81e15fd..0c10b12587a 100644 --- a/graal-nodejs/benchmark/url/legacy-vs-whatwg-url-parse.js +++ b/graal-nodejs/benchmark/url/whatwg-url-parse.js @@ -8,20 +8,8 @@ const bench = common.createBenchmark(main, { withBase: ['true', 'false'], type: common.urlDataTypes, e: [1], - method: ['legacy', 'whatwg'], }); -function useLegacy(data) { - const len = data.length; - let result = url.parse(data[0]); // Avoid dead code elimination - bench.start(); - for (let i = 0; i < len; ++i) { - result = url.parse(data[i]); - } - bench.end(len); - return result; -} - function useWHATWGWithBase(data) { const len = data.length; let result = new URL(data[0][0], data[0][1]); // Avoid dead code elimination @@ -45,22 +33,10 @@ function useWHATWGWithoutBase(data) { return result; } -function main({ e, method, type, withBase }) { +function main({ e, type, withBase }) { withBase = withBase === 'true'; - let noDead; // Avoid dead code elimination. - let data; - switch (method) { - case 'legacy': - data = common.bakeUrlData(type, e, false, false); - noDead = useLegacy(data); - break; - case 'whatwg': - data = common.bakeUrlData(type, e, withBase, false); - noDead = withBase ? useWHATWGWithBase(data) : useWHATWGWithoutBase(data); - break; - default: - throw new Error(`Unknown method ${method}`); - } + const data = common.bakeUrlData(type, e, withBase, false); + const noDead = withBase ? useWHATWGWithBase(data) : useWHATWGWithoutBase(data); assert.ok(noDead); } diff --git a/graal-nodejs/benchmark/url/whatwgurl-to-and-from-path.js b/graal-nodejs/benchmark/url/whatwg-url-to-and-from-path.js similarity index 100% rename from graal-nodejs/benchmark/url/whatwgurl-to-and-from-path.js rename to graal-nodejs/benchmark/url/whatwg-url-to-and-from-path.js