зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1394554: Test block data: URI toplevel navigations after redirect. r=smaug
This commit is contained in:
Родитель
8cc650c579
Коммит
11ddd453de
|
@ -1,2 +1,5 @@
|
||||||
[DEFAULT]
|
[DEFAULT]
|
||||||
[browser_test_toplevel_data_navigations.js]
|
[browser_test_toplevel_data_navigations.js]
|
||||||
|
support-files =
|
||||||
|
file_toplevel_data_navigations.sjs
|
||||||
|
file_toplevel_data_meta_redirect.html
|
||||||
|
|
|
@ -1,9 +1,15 @@
|
||||||
|
/* eslint-disable mozilla/no-arbitrary-setTimeout */
|
||||||
|
|
||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
const kDataBody = "toplevel navigation to data: URI allowed";
|
const kDataBody = "toplevel navigation to data: URI allowed";
|
||||||
const kDataURI = "data:text/html,<body>" + kDataBody + "</body>";
|
const kDataURI = "data:text/html,<body>" + kDataBody + "</body>";
|
||||||
|
const kTestPath = getRootDirectory(gTestPath)
|
||||||
|
.replace("chrome://mochitests/content", "http://example.com")
|
||||||
|
const kRedirectURI = kTestPath + "file_toplevel_data_navigations.sjs";
|
||||||
|
const kMetaRedirectURI = kTestPath + "file_toplevel_data_meta_redirect.html";
|
||||||
|
|
||||||
add_task(async function test_nav_data_uri_click() {
|
add_task(async function test_nav_data_uri() {
|
||||||
await SpecialPowers.pushPrefEnv({
|
await SpecialPowers.pushPrefEnv({
|
||||||
"set": [["security.data_uri.block_toplevel_data_uri_navigations", true]],
|
"set": [["security.data_uri.block_toplevel_data_uri_navigations", true]],
|
||||||
});
|
});
|
||||||
|
@ -14,3 +20,35 @@ add_task(async function test_nav_data_uri_click() {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
add_task(async function test_nav_data_uri_redirect() {
|
||||||
|
await SpecialPowers.pushPrefEnv({
|
||||||
|
"set": [["security.data_uri.block_toplevel_data_uri_navigations", true]],
|
||||||
|
});
|
||||||
|
let tab = BrowserTestUtils.addTab(gBrowser, kRedirectURI);
|
||||||
|
registerCleanupFunction(async function() {
|
||||||
|
await BrowserTestUtils.removeTab(tab);
|
||||||
|
});
|
||||||
|
// wait to make sure data: URI did not load before checking that it got blocked
|
||||||
|
await new Promise(resolve => setTimeout(resolve, 500));
|
||||||
|
await ContentTask.spawn(gBrowser.selectedBrowser, {}, async function() {
|
||||||
|
is(content.document.body.innerHTML, "",
|
||||||
|
"data: URI navigation after server redirect should be blocked");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
add_task(async function test_nav_data_uri_meta_redirect() {
|
||||||
|
await SpecialPowers.pushPrefEnv({
|
||||||
|
"set": [["security.data_uri.block_toplevel_data_uri_navigations", true]],
|
||||||
|
});
|
||||||
|
let tab = BrowserTestUtils.addTab(gBrowser, kMetaRedirectURI);
|
||||||
|
registerCleanupFunction(async function() {
|
||||||
|
await BrowserTestUtils.removeTab(tab);
|
||||||
|
});
|
||||||
|
// wait to make sure data: URI did not load before checking that it got blocked
|
||||||
|
await new Promise(resolve => setTimeout(resolve, 500));
|
||||||
|
await ContentTask.spawn(gBrowser.selectedBrowser, {}, async function() {
|
||||||
|
is(content.document.body.innerHTML, "",
|
||||||
|
"data: URI navigation after meta redirect should be blocked");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
<html>
|
||||||
|
<body>
|
||||||
|
<head>
|
||||||
|
<meta http-equiv="refresh"
|
||||||
|
content="0; url='data:text/html,<body>toplevel meta redirect to data: URI should be blocked</body>'">
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
Meta Redirect to data: URI
|
||||||
|
</body>
|
||||||
|
</html>
|
|
@ -0,0 +1,14 @@
|
||||||
|
// Custom *.sjs file specifically for the needs of Bug:
|
||||||
|
// Bug 1394554 - Block toplevel data: URI navigations after redirect
|
||||||
|
|
||||||
|
var DATA_URI =
|
||||||
|
"data:text/html,<body>toplevel data: URI navigations after redirect should be blocked</body>";
|
||||||
|
|
||||||
|
function handleRequest(request, response)
|
||||||
|
{
|
||||||
|
// avoid confusing cache behaviors
|
||||||
|
response.setHeader("Cache-Control", "no-cache", false);
|
||||||
|
|
||||||
|
response.setStatusLine("1.1", 302, "Found");
|
||||||
|
response.setHeader("Location", DATA_URI, false);
|
||||||
|
}
|
Загрузка…
Ссылка в новой задаче