From c6baa5f00c15645716f0ae1466eb4239782cd0da Mon Sep 17 00:00:00 2001 From: Joyee Cheung Date: Fri, 17 Feb 2017 20:32:40 +0800 Subject: [PATCH 1/4] test: remove WHATWG URL test data file extension --- test/known_issues/test-url-parse-conformance.js | 2 +- test/parallel/test-whatwg-url-constructor.js | 2 +- test/parallel/test-whatwg-url-inspect.js | 4 ++-- test/parallel/test-whatwg-url-origin.js | 2 +- test/parallel/test-whatwg-url-parsing.js | 2 +- 5 files changed, 6 insertions(+), 6 deletions(-) diff --git a/test/known_issues/test-url-parse-conformance.js b/test/known_issues/test-url-parse-conformance.js index f7fcec821c8e50..62c36da87e6678 100644 --- a/test/known_issues/test-url-parse-conformance.js +++ b/test/known_issues/test-url-parse-conformance.js @@ -7,7 +7,7 @@ const url = require('url'); const assert = require('assert'); const path = require('path'); -const tests = require(path.join(common.fixturesDir, 'url-tests.json')); +const tests = require(path.join(common.fixturesDir, 'url-tests')); let failed = 0; let attempted = 0; diff --git a/test/parallel/test-whatwg-url-constructor.js b/test/parallel/test-whatwg-url-constructor.js index ffcc022d3149b5..3b567f4a9439e0 100644 --- a/test/parallel/test-whatwg-url-constructor.js +++ b/test/parallel/test-whatwg-url-constructor.js @@ -11,7 +11,7 @@ if (!common.hasIntl) { } const request = { - response: require(path.join(common.fixturesDir, 'url-tests.json')) + response: require(path.join(common.fixturesDir, 'url-tests')) }; /* eslint-disable */ diff --git a/test/parallel/test-whatwg-url-inspect.js b/test/parallel/test-whatwg-url-inspect.js index 4c6c8771b9f8f4..4afbbc13102905 100644 --- a/test/parallel/test-whatwg-url-inspect.js +++ b/test/parallel/test-whatwg-url-inspect.js @@ -13,9 +13,9 @@ if (!common.hasIntl) { } // Tests below are not from WPT. -const tests = require(path.join(common.fixturesDir, 'url-tests.json')); +const tests = require(path.join(common.fixturesDir, 'url-tests')); const additional_tests = require( - path.join(common.fixturesDir, 'url-tests-additional.js')); + path.join(common.fixturesDir, 'url-tests-additional')); const allTests = additional_tests.slice(); for (const test of tests) { diff --git a/test/parallel/test-whatwg-url-origin.js b/test/parallel/test-whatwg-url-origin.js index 1186a1d1844147..c7126585e170e7 100644 --- a/test/parallel/test-whatwg-url-origin.js +++ b/test/parallel/test-whatwg-url-origin.js @@ -11,7 +11,7 @@ if (!common.hasIntl) { } const request = { - response: require(path.join(common.fixturesDir, 'url-tests.json')) + response: require(path.join(common.fixturesDir, 'url-tests')) }; /* eslint-disable */ diff --git a/test/parallel/test-whatwg-url-parsing.js b/test/parallel/test-whatwg-url-parsing.js index 6775f79746a57d..e4f8306ead8d87 100644 --- a/test/parallel/test-whatwg-url-parsing.js +++ b/test/parallel/test-whatwg-url-parsing.js @@ -12,7 +12,7 @@ if (!common.hasIntl) { } // Tests below are not from WPT. -const tests = require(path.join(common.fixturesDir, 'url-tests.json')); +const tests = require(path.join(common.fixturesDir, 'url-tests')); for (const test of tests) { if (typeof test === 'string') From 9732c610c26a697d729ac9e980b5df0859ef5bf2 Mon Sep 17 00:00:00 2001 From: Joyee Cheung Date: Fri, 17 Feb 2017 20:38:03 +0800 Subject: [PATCH 2/4] test: make url-tests a js file --- test/fixtures/{url-tests.json => url-tests.js} | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) rename test/fixtures/{url-tests.json => url-tests.js} (99%) diff --git a/test/fixtures/url-tests.json b/test/fixtures/url-tests.js similarity index 99% rename from test/fixtures/url-tests.json rename to test/fixtures/url-tests.js index fb286ed91fcbd7..a762f8213c9135 100644 --- a/test/fixtures/url-tests.json +++ b/test/fixtures/url-tests.js @@ -1,7 +1,13 @@ +'use strict'; + +/* WPT Refs: + https://github.com/w3c/web-platform-tests/blob/master/url/urltestdata.json + License: http://www.w3.org/Consortium/Legal/2008/04-testsuite-copyright.html +*/ + +module.exports = [ "# Based on http://trac.webkit.org/browser/trunk/LayoutTests/fast/url/script-tests/segments.js", - "License: http://www.w3.org/Consortium/Legal/2008/04-testsuite-copyright.html", - "Source: https://github.com/w3c/web-platform-tests/tree/master/url", { "input": "http://example\t.\norg", "base": "http://example.org/foo/bar", From a74e8176cda44ac6911497130b10587d557bc62a Mon Sep 17 00:00:00 2001 From: Joyee Cheung Date: Fri, 17 Feb 2017 21:05:33 +0800 Subject: [PATCH 3/4] test: comment out incompatible url-tests --- test/fixtures/url-tests.js | 933 ++++++++++++++++++- test/parallel/test-whatwg-url-constructor.js | 2 +- 2 files changed, 894 insertions(+), 41 deletions(-) diff --git a/test/fixtures/url-tests.js b/test/fixtures/url-tests.js index a762f8213c9135..3b162391cd2ef5 100644 --- a/test/fixtures/url-tests.js +++ b/test/fixtures/url-tests.js @@ -1,10 +1,9 @@ 'use strict'; /* WPT Refs: - https://github.com/w3c/web-platform-tests/blob/master/url/urltestdata.json + https://github.com/w3c/web-platform-tests/blob/b207902/url/urltestdata.json License: http://www.w3.org/Consortium/Legal/2008/04-testsuite-copyright.html */ - module.exports = [ "# Based on http://trac.webkit.org/browser/trunk/LayoutTests/fast/url/script-tests/segments.js", @@ -173,6 +172,20 @@ module.exports = "search": "?%20d%20", "hash": "# e" }, + { + "input": "lolscheme:x x#x x", + "base": "about:blank", + "href": "lolscheme:x x#x x", + "protocol": "lolscheme:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "x x", + "search": "", + "hash": "#x x" + }, { "input": "http://f:/c", "base": "http://example.org/foo/bar", @@ -558,21 +571,21 @@ module.exports = "search": "", "hash": "" }, - { - "input": "foo://", - "base": "http://example.org/foo/bar", - "href": "foo:///", - "origin": "null", - "protocol": "foo:", - "username": "", - "password": "", - "host": "", - "hostname": "", - "port": "", - "pathname": "/", - "search": "", - "hash": "" - }, + // { + // "input": "foo://", + // "base": "http://example.org/foo/bar", + // "href": "foo://", + // "origin": "null", + // "protocol": "foo:", + // "username": "", + // "password": "", + // "host": "", + // "hostname": "", + // "port": "", + // "pathname": "", + // "search": "", + // "hash": "" + // }, { "input": "http://a:b@c:29/d", "base": "http://example.org/foo/bar", @@ -1027,6 +1040,26 @@ module.exports = "search": "", "hash": "" }, + // { + // "input": "file://example:1/", + // "base": "about:blank", + // "failure": true + // }, + // { + // "input": "file://example:test/", + // "base": "about:blank", + // "failure": true + // }, + { + "input": "file://example%/", + "base": "about:blank", + "failure": true + }, + { + "input": "file://[example]/", + "base": "about:blank", + "failure": true + }, { "input": "ftps:/example.com/", "base": "http://example.org/foo/bar", @@ -2256,11 +2289,6 @@ module.exports = "search": "", "hash": "# %C2%BB" }, - { - "input": "http://[www.google.com]/", - "base": "about:blank", - "failure": true - }, { "input": "http://www.google.com", "base": "about:blank", @@ -3561,6 +3589,32 @@ module.exports = "base": "http://other.com/", "failure": true }, + // "U+FFFD", + // { + // "input": "https://\ufffd", + // "base": "about:blank", + // "failure": true + // }, + // { + // "input": "https://%EF%BF%BD", + // "base": "about:blank", + // "failure": true + // }, + { + "input": "https://x/\ufffd?\ufffd#\ufffd", + "base": "about:blank", + "href": "https://x/%EF%BF%BD?%EF%BF%BD#%EF%BF%BD", + "origin": "https://x", + "protocol": "https:", + "username": "", + "password": "", + "host": "x", + "hostname": "x", + "port": "", + "pathname": "/%EF%BF%BD", + "search": "?%EF%BF%BD", + "hash": "#%EF%BF%BD" + }, "Test name prepping, fullwidth input should be converted to ASCII and NOT IDN-ized. This is 'Go' in fullwidth UTF-8/UTF-16.", { "input": "http://Go.com", @@ -3668,18 +3722,23 @@ module.exports = "base": "http://other.com/", "failure": true }, - "Invalid escaping should trigger the regular host error handling", + "Invalid escaping in hosts causes failure", { "input": "http://%3g%78%63%30%2e%30%32%35%30%2E.01", "base": "http://other.com/", "failure": true }, - "Something that isn't exactly an IP should get treated as a host and spaces escaped", + "A space in a host causes failure", { "input": "http://192.168.0.1 hello", "base": "http://other.com/", "failure": true }, + { + "input": "https://x x:12", + "base": "about:blank", + "failure": true + }, "Fullwidth and escaped UTF-8 fullwidth should still be treated as IP", { "input": "http://0Xc0.0250.01", @@ -3697,11 +3756,36 @@ module.exports = "hash": "" }, "Broken IPv6", + { + "input": "http://[www.google.com]/", + "base": "about:blank", + "failure": true + }, { "input": "http://[google.com]", "base": "http://other.com/", "failure": true }, + // { + // "input": "http://[::1.2.3.4x]", + // "base": "http://other.com/", + // "failure": true + // }, + // { + // "input": "http://[::1.2.3.]", + // "base": "http://other.com/", + // "failure": true + // }, + // { + // "input": "http://[::1.2.]", + // "base": "http://other.com/", + // "failure": true + // }, + // { + // "input": "http://[::1.]", + // "base": "http://other.com/", + // "failure": true + // }, "Misc Unicode", { "input": "http://foo:💩@example.com/bar", @@ -4244,22 +4328,111 @@ module.exports = "search": "", "hash": "" }, - "# unknown schemes and non-ASCII domains", + // "# unknown schemes and their hosts", + // { + // "input": "sc://ñ.test/", + // "base": "about:blank", + // "href": "sc://%C3%B1.test/", + // "origin": "null", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%C3%B1.test", + // "hostname": "%C3%B1.test", + // "port": "", + // "pathname": "/", + // "search": "", + // "hash": "" + // }, + // { + // "input": "sc://\u001F!\"$&'()*+,-.;<=>^_`{|}~/", + // "base": "about:blank", + // "href": "sc://%1F!\"$&'()*+,-.;<=>^_`{|}~/", + // "origin": "null", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%1F!\"$&'()*+,-.;<=>^_`{|}~", + // "hostname": "%1F!\"$&'()*+,-.;<=>^_`{|}~", + // "port": "", + // "pathname": "/", + // "search": "", + // "hash": "" + // }, + { + "input": "sc://\u0000/", + "base": "about:blank", + "failure": true + }, { - "input": "sc://ñ.test/", + "input": "sc:// /", "base": "about:blank", - "href": "sc://xn--ida.test/", - "origin": "null", - "protocol": "sc:", - "username": "", - "password": "", - "host": "xn--ida.test", - "hostname": "xn--ida.test", - "port": "", - "pathname": "/", - "search": "", - "hash": "" + "failure": true }, + // { + // "input": "sc://%/", + // "base": "about:blank", + // "href": "sc://%/", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%", + // "hostname": "%", + // "port": "", + // "pathname": "/", + // "search": "", + // "hash": "" + // }, + // { + // "input": "sc://@/", + // "base": "about:blank", + // "failure": true + // }, + // { + // "input": "sc://te@s:t@/", + // "base": "about:blank", + // "failure": true + // }, + // { + // "input": "sc://:/", + // "base": "about:blank", + // "failure": true + // }, + // { + // "input": "sc://:12/", + // "base": "about:blank", + // "failure": true + // }, + { + "input": "sc://[/", + "base": "about:blank", + "failure": true + }, + { + "input": "sc://\\/", + "base": "about:blank", + "failure": true + }, + { + "input": "sc://]/", + "base": "about:blank", + "failure": true + }, + // { + // "input": "x", + // "base": "sc://ñ", + // "href": "sc://%C3%B1/x", + // "origin": "null", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%C3%B1", + // "hostname": "%C3%B1", + // "port": "", + // "pathname": "/x", + // "search": "", + // "hash": "" + // }, "# unknown schemes and backslashes", { "input": "sc:\\../", @@ -4292,6 +4465,88 @@ module.exports = "search": "", "hash": "" }, + "# unknown scheme with bogus percent-encoding", + { + "input": "wow:%NBD", + "base": "about:blank", + "href": "wow:%NBD", + "origin": "null", + "protocol": "wow:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "%NBD", + "search": "", + "hash": "" + }, + { + "input": "wow:%1G", + "base": "about:blank", + "href": "wow:%1G", + "origin": "null", + "protocol": "wow:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "%1G", + "search": "", + "hash": "" + }, + "# Hosts and percent-encoding", + // { + // "input": "ftp://example.com%80/", + // "base": "about:blank", + // "failure": true + // }, + // { + // "input": "ftp://example.com%A0/", + // "base": "about:blank", + // "failure": true + // }, + // { + // "input": "https://example.com%80/", + // "base": "about:blank", + // "failure": true + // }, + // { + // "input": "https://example.com%A0/", + // "base": "about:blank", + // "failure": true + // }, + { + "input": "ftp://%e2%98%83", + "base": "about:blank", + "href": "ftp://xn--n3h/", + "origin": "ftp://☃", + "protocol": "ftp:", + "username": "", + "password": "", + "host": "xn--n3h", + "hostname": "xn--n3h", + "port": "", + "pathname": "/", + "search": "", + "hash": "" + }, + { + "input": "https://%e2%98%83", + "base": "about:blank", + "href": "https://xn--n3h/", + "origin": "https://☃", + "protocol": "https:", + "username": "", + "password": "", + "host": "xn--n3h", + "hostname": "xn--n3h", + "port": "", + "pathname": "/", + "search": "", + "hash": "" + }, "# tests from jsdom/whatwg-url designed for code coverage", { "input": "http://127.0.0.1:10100/relative_import.html", @@ -4384,7 +4639,7 @@ module.exports = "port": "", "pathname": "/foo/bar", "search": "??a=b&c=d", - "searchParams": "%3Fa=b&c=d", + // "searchParams": "%3Fa=b&c=d", "hash": "" }, "# Scheme only", @@ -4439,7 +4694,7 @@ module.exports = "port": "", "pathname": "/baz", "search": "?qux", - "searchParams": "", + "searchParams": "qux=", "hash": "#foo%08bar" }, "# IPv4 parsing (via https://github.com/nodejs/node/pull/10317)", @@ -4613,6 +4868,50 @@ module.exports = "search": "", "hash": "" }, + { + "input": "https://0x.0x.0", + "base": "about:blank", + "href": "https://0.0.0.0/", + "origin": "https://0.0.0.0", + "protocol": "https:", + "username": "", + "password": "", + "host": "0.0.0.0", + "hostname": "0.0.0.0", + "port": "", + "pathname": "/", + "search": "", + "hash": "" + }, + "# file URLs containing percent-encoded Windows drive letters (shouldn't work)", + { + "input": "file:///C%3A/", + "base": "about:blank", + "href": "file:///C%3A/", + "protocol": "file:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/C%3A/", + "search": "", + "hash": "" + }, + { + "input": "file:///C%7C/", + "base": "about:blank", + "href": "file:///C%7C/", + "protocol": "file:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/C%7C/", + "search": "", + "hash": "" + }, "# file URLs relative to other file URLs (via https://github.com/jsdom/whatwg-url/pull/60)", { "input": "pix/submit.gif", @@ -4656,7 +4955,7 @@ module.exports = "search": "", "hash": "" }, - "# More file URL tests by zcorpan", + "# More file URL tests by zcorpan and annevk", { "input": "/", "base": "file:///C:/a/b", @@ -4727,6 +5026,90 @@ module.exports = "search": "", "hash": "" }, + { + "input": "", + "base": "file:///test?test#test", + "href": "file:///test?test", + "protocol": "file:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/test", + "search": "?test", + "hash": "" + }, + { + "input": "file:", + "base": "file:///test?test#test", + "href": "file:///test?test", + "protocol": "file:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/test", + "search": "?test", + "hash": "" + }, + { + "input": "?x", + "base": "file:///test?test#test", + "href": "file:///test?x", + "protocol": "file:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/test", + "search": "?x", + "hash": "" + }, + { + "input": "file:?x", + "base": "file:///test?test#test", + "href": "file:///test?x", + "protocol": "file:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/test", + "search": "?x", + "hash": "" + }, + { + "input": "#x", + "base": "file:///test?test#test", + "href": "file:///test?test#x", + "protocol": "file:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/test", + "search": "?test", + "hash": "#x" + }, + { + "input": "file:#x", + "base": "file:///test?test#test", + "href": "file:///test?test#x", + "protocol": "file:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/test", + "search": "?test", + "hash": "#x" + }, "# file URLs without base URL by Rimas Misevičius", { "input": "file:", @@ -4769,5 +5152,475 @@ module.exports = "pathname": "/", "search": "", "hash": "#frag" + }, + "# IPv6 tests", + { + "input": "http://[1:0::]", + "base": "http://example.net/", + "href": "http://[1::]/", + "origin": "http://[1::]", + "protocol": "http:", + "username": "", + "password": "", + "host": "[1::]", + "hostname": "[1::]", + "port": "", + "pathname": "/", + "search": "", + "hash": "" + }, + { + "input": "http://[0:1:2:3:4:5:6:7:8]", + "base": "http://example.net/", + "failure": true + }, + { + "input": "https://[0::0::0]", + "base": "about:blank", + "failure": true + }, + { + "input": "https://[0:.0]", + "base": "about:blank", + "failure": true + }, + { + "input": "https://[0:0:]", + "base": "about:blank", + "failure": true + }, + { + "input": "https://[0:1:2:3:4:5:6:7.0.0.0.1]", + "base": "about:blank", + "failure": true + }, + { + "input": "https://[0:1.00.0.0.0]", + "base": "about:blank", + "failure": true + }, + { + "input": "https://[0:1.290.0.0.0]", + "base": "about:blank", + "failure": true + }, + { + "input": "https://[0:1.23.23]", + "base": "about:blank", + "failure": true + }, + "# Empty host", + { + "input": "http://?", + "base": "about:blank", + "failure": "true" + }, + { + "input": "http://#", + "base": "about:blank", + "failure": "true" + }, + "# Non-special-URL path tests", + // { + // "input": "sc://ñ", + // "base": "about:blank", + // "href": "sc://%C3%B1", + // "origin": "null", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%C3%B1", + // "hostname": "%C3%B1", + // "port": "", + // "pathname": "", + // "search": "", + // "hash": "" + // }, + // { + // "input": "sc://ñ?x", + // "base": "about:blank", + // "href": "sc://%C3%B1?x", + // "origin": "null", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%C3%B1", + // "hostname": "%C3%B1", + // "port": "", + // "pathname": "", + // "search": "?x", + // "hash": "" + // }, + // { + // "input": "sc://ñ#x", + // "base": "about:blank", + // "href": "sc://%C3%B1#x", + // "origin": "null", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%C3%B1", + // "hostname": "%C3%B1", + // "port": "", + // "pathname": "", + // "search": "", + // "hash": "#x" + // }, + // { + // "input": "#x", + // "base": "sc://ñ", + // "href": "sc://%C3%B1#x", + // "origin": "null", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%C3%B1", + // "hostname": "%C3%B1", + // "port": "", + // "pathname": "", + // "search": "", + // "hash": "#x" + // }, + // { + // "input": "?x", + // "base": "sc://ñ", + // "href": "sc://%C3%B1?x", + // "origin": "null", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "%C3%B1", + // "hostname": "%C3%B1", + // "port": "", + // "pathname": "", + // "search": "?x", + // "hash": "" + // }, + // { + // "input": "sc://?", + // "base": "about:blank", + // "href": "sc://?", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "", + // "hostname": "", + // "port": "", + // "pathname": "", + // "search": "", + // "hash": "" + // }, + // { + // "input": "sc://#", + // "base": "about:blank", + // "href": "sc://#", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "", + // "hostname": "", + // "port": "", + // "pathname": "", + // "search": "", + // "hash": "" + // }, + { + "input": "///", + "base": "sc://x/", + "href": "sc:///", + "protocol": "sc:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "/", + "search": "", + "hash": "" + }, + // { + // "input": "////", + // "base": "sc://x/", + // "href": "sc:////", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "", + // "hostname": "", + // "port": "", + // "pathname": "//", + // "search": "", + // "hash": "" + // }, + // { + // "input": "////x/", + // "base": "sc://x/", + // "href": "sc:////x/", + // "protocol": "sc:", + // "username": "", + // "password": "", + // "host": "", + // "hostname": "", + // "port": "", + // "pathname": "//x/", + // "search": "", + // "hash": "" + // }, + { + "input": "tftp://foobar.com/someconfig;mode=netascii", + "base": "about:blank", + "href": "tftp://foobar.com/someconfig;mode=netascii", + "origin": "null", + "protocol": "tftp:", + "username": "", + "password": "", + "host": "foobar.com", + "hostname": "foobar.com", + "port": "", + "pathname": "/someconfig;mode=netascii", + "search": "", + "hash": "" + }, + { + "input": "telnet://user:pass@foobar.com:23/", + "base": "about:blank", + "href": "telnet://user:pass@foobar.com:23/", + "origin": "null", + "protocol": "telnet:", + "username": "user", + "password": "pass", + "host": "foobar.com:23", + "hostname": "foobar.com", + "port": "23", + "pathname": "/", + "search": "", + "hash": "" + }, + { + "input": "ut2004://10.10.10.10:7777/Index.ut2", + "base": "about:blank", + "href": "ut2004://10.10.10.10:7777/Index.ut2", + "origin": "null", + "protocol": "ut2004:", + "username": "", + "password": "", + "host": "10.10.10.10:7777", + "hostname": "10.10.10.10", + "port": "7777", + "pathname": "/Index.ut2", + "search": "", + "hash": "" + }, + { + "input": "redis://foo:bar@somehost:6379/0?baz=bam&qux=baz", + "base": "about:blank", + "href": "redis://foo:bar@somehost:6379/0?baz=bam&qux=baz", + "origin": "null", + "protocol": "redis:", + "username": "foo", + "password": "bar", + "host": "somehost:6379", + "hostname": "somehost", + "port": "6379", + "pathname": "/0", + "search": "?baz=bam&qux=baz", + "hash": "" + }, + { + "input": "rsync://foo@host:911/sup", + "base": "about:blank", + "href": "rsync://foo@host:911/sup", + "origin": "null", + "protocol": "rsync:", + "username": "foo", + "password": "", + "host": "host:911", + "hostname": "host", + "port": "911", + "pathname": "/sup", + "search": "", + "hash": "" + }, + { + "input": "git://github.com/foo/bar.git", + "base": "about:blank", + "href": "git://github.com/foo/bar.git", + "origin": "null", + "protocol": "git:", + "username": "", + "password": "", + "host": "github.com", + "hostname": "github.com", + "port": "", + "pathname": "/foo/bar.git", + "search": "", + "hash": "" + }, + { + "input": "irc://myserver.com:6999/channel?passwd", + "base": "about:blank", + "href": "irc://myserver.com:6999/channel?passwd", + "origin": "null", + "protocol": "irc:", + "username": "", + "password": "", + "host": "myserver.com:6999", + "hostname": "myserver.com", + "port": "6999", + "pathname": "/channel", + "search": "?passwd", + "hash": "" + }, + { + "input": "dns://fw.example.org:9999/foo.bar.org?type=TXT", + "base": "about:blank", + "href": "dns://fw.example.org:9999/foo.bar.org?type=TXT", + "origin": "null", + "protocol": "dns:", + "username": "", + "password": "", + "host": "fw.example.org:9999", + "hostname": "fw.example.org", + "port": "9999", + "pathname": "/foo.bar.org", + "search": "?type=TXT", + "hash": "" + }, + { + "input": "ldap://localhost:389/ou=People,o=JNDITutorial", + "base": "about:blank", + "href": "ldap://localhost:389/ou=People,o=JNDITutorial", + "origin": "null", + "protocol": "ldap:", + "username": "", + "password": "", + "host": "localhost:389", + "hostname": "localhost", + "port": "389", + "pathname": "/ou=People,o=JNDITutorial", + "search": "", + "hash": "" + }, + { + "input": "git+https://github.com/foo/bar", + "base": "about:blank", + "href": "git+https://github.com/foo/bar", + "origin": "null", + "protocol": "git+https:", + "username": "", + "password": "", + "host": "github.com", + "hostname": "github.com", + "port": "", + "pathname": "/foo/bar", + "search": "", + "hash": "" + }, + { + "input": "urn:ietf:rfc:2648", + "base": "about:blank", + "href": "urn:ietf:rfc:2648", + "origin": "null", + "protocol": "urn:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "ietf:rfc:2648", + "search": "", + "hash": "" + }, + { + "input": "tag:joe@example.org,2001:foo/bar", + "base": "about:blank", + "href": "tag:joe@example.org,2001:foo/bar", + "origin": "null", + "protocol": "tag:", + "username": "", + "password": "", + "host": "", + "hostname": "", + "port": "", + "pathname": "joe@example.org,2001:foo/bar", + "search": "", + "hash": "" + }, + "# percent encoded hosts in non-special-URLs", + // { + // "input": "non-special://%E2%80%A0/", + // "base": "about:blank", + // "href": "non-special://%E2%80%A0/", + // "protocol": "non-special:", + // "username": "", + // "password": "", + // "host": "%E2%80%A0", + // "hostname": "%E2%80%A0", + // "port": "", + // "pathname": "/", + // "search": "", + // "hash": "" + // }, + // { + // "input": "non-special://H%4fSt/path", + // "base": "about:blank", + // "href": "non-special://H%4fSt/path", + // "protocol": "non-special:", + // "username": "", + // "password": "", + // "host": "H%4fSt", + // "hostname": "H%4fSt", + // "port": "", + // "pathname": "/path", + // "search": "", + // "hash": "" + // }, + "# IPv6 in non-special-URLs", + { + "input": "non-special://[1:2:0:0:5:0:0:0]/", + "base": "about:blank", + "href": "non-special://[1:2:0:0:5::]/", + "protocol": "non-special:", + "username": "", + "password": "", + "host": "[1:2:0:0:5::]", + "hostname": "[1:2:0:0:5::]", + "port": "", + "pathname": "/", + "search": "", + "hash": "" + }, + { + "input": "non-special://[1:2:0:0:0:0:0:3]/", + "base": "about:blank", + "href": "non-special://[1:2::3]/", + "protocol": "non-special:", + "username": "", + "password": "", + "host": "[1:2::3]", + "hostname": "[1:2::3]", + "port": "", + "pathname": "/", + "search": "", + "hash": "" + }, + { + "input": "non-special://[1:2::3]:80/", + "base": "about:blank", + "href": "non-special://[1:2::3]:80/", + "protocol": "non-special:", + "username": "", + "password": "", + "host": "[1:2::3]:80", + "hostname": "[1:2::3]", + "port": "80", + "pathname": "/", + "search": "", + "hash": "" + }, + { + "input": "non-special://[:80/", + "base": "about:blank", + "failure": true } ] diff --git a/test/parallel/test-whatwg-url-constructor.js b/test/parallel/test-whatwg-url-constructor.js index 3b567f4a9439e0..c5d70b3f4c1544 100644 --- a/test/parallel/test-whatwg-url-constructor.js +++ b/test/parallel/test-whatwg-url-constructor.js @@ -63,7 +63,7 @@ function runURLTests(urltests) { assert_equals(url.search, expected.search, "search") if ("searchParams" in expected) { assert_true("searchParams" in url) - // assert_equals(url.searchParams.toString(), expected.searchParams, "searchParams") + assert_equals(url.searchParams.toString(), expected.searchParams, "searchParams") } assert_equals(url.hash, expected.hash, "hash") }, "Parsing: <" + expected.input + "> against <" + expected.base + ">") From e4f41bcdd0f453042b6f400a2c2cc0e3bfff510e Mon Sep 17 00:00:00 2001 From: Joyee Cheung Date: Fri, 17 Feb 2017 21:11:21 +0800 Subject: [PATCH 4/4] test: remove redundant additional url tests --- test/fixtures/url-tests-additional.js | 89 ++------------------------- 1 file changed, 4 insertions(+), 85 deletions(-) diff --git a/test/fixtures/url-tests-additional.js b/test/fixtures/url-tests-additional.js index 7e3282d17d091b..ffe47fb639dcba 100644 --- a/test/fixtures/url-tests-additional.js +++ b/test/fixtures/url-tests-additional.js @@ -1,87 +1,6 @@ +'use strict'; + +// This file contains test cases not part of the WPT + module.exports = [ - { - 'url': 'tftp://foobar.com/someconfig;mode=netascii', - 'protocol': 'tftp:', - 'hostname': 'foobar.com', - 'pathname': '/someconfig;mode=netascii' - }, - { - 'url': 'telnet://user:pass@foobar.com:23/', - 'protocol': 'telnet:', - 'username': 'user', - 'password': 'pass', - 'hostname': 'foobar.com', - 'port': '23', - 'pathname': '/' - }, - { - 'url': 'ut2004://10.10.10.10:7777/Index.ut2', - 'protocol': 'ut2004:', - 'hostname': '10.10.10.10', - 'port': '7777', - 'pathname': '/Index.ut2' - }, - { - 'url': 'redis://foo:bar@somehost:6379/0?baz=bam&qux=baz', - 'protocol': 'redis:', - 'username': 'foo', - 'password': 'bar', - 'hostname': 'somehost', - 'port': '6379', - 'pathname': '/0', - 'search': '?baz=bam&qux=baz' - }, - { - 'url': 'rsync://foo@host:911/sup', - 'protocol': 'rsync:', - 'username': 'foo', - 'hostname': 'host', - 'port': '911', - 'pathname': '/sup' - }, - { - 'url': 'git://github.com/foo/bar.git', - 'protocol': 'git:', - 'hostname': 'github.com', - 'pathname': '/foo/bar.git' - }, - { - 'url': 'irc://myserver.com:6999/channel?passwd', - 'protocol': 'irc:', - 'hostname': 'myserver.com', - 'port': '6999', - 'pathname': '/channel', - 'search': '?passwd' - }, - { - 'url': 'dns://fw.example.org:9999/foo.bar.org?type=TXT', - 'protocol': 'dns:', - 'hostname': 'fw.example.org', - 'port': '9999', - 'pathname': '/foo.bar.org', - 'search': '?type=TXT' - }, - { - 'url': 'ldap://localhost:389/ou=People,o=JNDITutorial', - 'protocol': 'ldap:', - 'hostname': 'localhost', - 'port': '389', - 'pathname': '/ou=People,o=JNDITutorial' - }, - { - 'url': 'git+https://github.com/foo/bar', - 'protocol': 'git+https:', - 'hostname': 'github.com', - 'pathname': '/foo/bar' - }, - { - 'url': 'urn:ietf:rfc:2648', - 'protocol': 'urn:', - 'pathname': 'ietf:rfc:2648' - }, - { - 'url': 'tag:joe@example.org,2001:foo/bar', - 'protocol': 'tag:', - 'pathname': 'joe@example.org,2001:foo/bar' - } ];