Skip to content

Commit

Permalink
Bug 1497567 [wpt PR 13435] - Test Location sans browsing context, a=t…
Browse files Browse the repository at this point in the history
…estonly

Automatic update from web-platform-testsTest Location sans browsing context

For whatwg/html#3959 and whatwg/html#4076.
--

wpt-commits: fce65ebd7656136f5f8452378146f1b7af30bf79
wpt-pr: 13435
  • Loading branch information
annevk authored and moz-wptsync-bot committed Nov 10, 2018
1 parent c994992 commit ec1e8e5
Showing 1 changed file with 86 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
test(() => {
const frame = document.body.appendChild(document.createElement("iframe")),
win = frame.contentWindow,
loc = win.location;
frame.remove();
assert_equals(win.location, loc);
}, "Window and Location are 1:1 after browsing context removal");

function bcLessLocation() {
const frame = document.body.appendChild(document.createElement("iframe")),
win = frame.contentWindow,
loc = win.location;
frame.remove();
return loc;
}

[
{
"property": "href",
"expected": "about:blank",
"values": ["https://example.com/", "/", "http://test:test/", "test test", "test:test", "chrome:fail"]
},
{
"property": "protocol",
"expected": "about:",
"values": ["http", "about", "test"]
},
{
"property": "host",
"expected": "",
"values": ["example.com", "test test", "()"]
},
{
"property": "hostname",
"expected": "",
"values": ["example.com"]
},
{
"property": "port",
"expected": "",
"values": ["80", "", "443", "notaport"]
},
{
"property": "pathname",
"expected": "",
"values": ["/", "x"]
},
{
"property": "search",
"expected": "",
"values": ["test"]
},
{
"property": "hash",
"expected": "",
"values": ["test", "#"]
}
].forEach(testSetup => {
testSetup.values.forEach(value => {
test(() => {
const loc = bcLessLocation();
loc[testSetup.property] = value;
assert_equals(loc[testSetup.property], testSetup.expected);
}, "Setting `" + testSetup.property + "` to `" + value + "` of a `Location` object sans browsing context is a no-op");
});
});

test(() => {
const loc = bcLessLocation();
assert_equals(loc.origin, "null");
}, "Getting `origin` of a `Location` object sans browsing context should be \"null\"");

["assign", "replace", "reload"].forEach(method => {
["about:blank", "https://example.com/", "/", "http://test:test/", "test test", "test:test", "chrome:fail"].forEach(value => {
test(() => {
const loc = bcLessLocation();
loc[method](value);
assert_equals(loc.href, "about:blank");
}, "Invoking `" + method + "` with `" + value + "` on a `Location` object sans browsing context is a no-op");
});
});

test(() => {
const loc = bcLessLocation();
assert_array_equals(loc.ancestorOrigins, []);
}, "Getting `ancestorOrigins` of a `Location` object sans browsing context should be []");

0 comments on commit ec1e8e5

Please sign in to comment.