mirror of
https://github.com/nodejs/node.git
synced 2024-12-01 16:10:02 +01:00
9858e331e3
This patch: - Creates a new test suite `wpt` that can be used to run a subset of Web Platform Tests - Adds a `WPTRunner` in `test/common/wpt.js` that can run the WPT subset in `test/fixtures/wpt` with a vm and the WPT harness while taking the status file in `test/wpt/status` into account. Here we use a new format of status file (in JSON) to handle specific requirements (like ICU requirements) in the tests and to handle expected failures and TODOs. - Adds documentation on how the runner and the update automation works - Runs the WHATWG URL tests and the console tests with the new test runner. With this patch we eliminates the need of copy-pasting with manual modifications to update a large chunk of our WPT subset previously maintained in `test/parallel`. Now the tests run in `test/wpt` can be automatically updated with `git node wpt` without modifications by the actual WPT harness instead of our home-grown mock. There are still a few URL tests left that need to be migrated in the upstream to be placed in .js instead of .html - we currently still use the legacy harness mock in the test files. PR-URL: https://github.com/nodejs/node/pull/24035 Refs: https://github.com/nodejs/node/issues/23192 Reviewed-By: Daijiro Wachi <daijiro.wachi@gmail.com>
53 lines
1.4 KiB
JavaScript
53 lines
1.4 KiB
JavaScript
'use strict';
|
|
|
|
// Tests below are not from WPT.
|
|
|
|
require('../common');
|
|
const { URL, URLSearchParams } = require('url');
|
|
const { test, assert_array_equals } = require('../common/wpt').harness;
|
|
|
|
// TODO(joyeecheung): upstream this to WPT, if possible - even
|
|
// just as a test for large inputs. Other implementations may
|
|
// have a similar cutoff anyway.
|
|
|
|
// Test bottom-up iterative stable merge sort because we only use that
|
|
// algorithm to sort > 100 search params.
|
|
const tests = [{ input: '', output: [] }];
|
|
const pairs = [];
|
|
for (let i = 10; i < 100; i++) {
|
|
pairs.push([`a${i}`, 'b']);
|
|
tests[0].output.push([`a${i}`, 'b']);
|
|
}
|
|
tests[0].input = pairs.sort(() => Math.random() > 0.5)
|
|
.map((pair) => pair.join('=')).join('&');
|
|
|
|
tests.push(
|
|
{
|
|
'input': 'z=a&=b&c=d',
|
|
'output': [['', 'b'], ['c', 'd'], ['z', 'a']]
|
|
}
|
|
);
|
|
|
|
tests.forEach((val) => {
|
|
test(() => {
|
|
const params = new URLSearchParams(val.input);
|
|
let i = 0;
|
|
params.sort();
|
|
for (const param of params) {
|
|
assert_array_equals(param, val.output[i]);
|
|
i++;
|
|
}
|
|
}, `Parse and sort: ${val.input}`);
|
|
|
|
test(() => {
|
|
const url = new URL(`?${val.input}`, 'https://example/');
|
|
url.searchParams.sort();
|
|
const params = new URLSearchParams(url.search);
|
|
let i = 0;
|
|
for (const param of params) {
|
|
assert_array_equals(param, val.output[i]);
|
|
i++;
|
|
}
|
|
}, `URL parse and sort: ${val.input}`);
|
|
});
|