Bug 1187335 - P7 - A test for serviceworker and sharedworker on webconsole. r=bkelly.

This commit is contained in:
Tom Tung 2016-08-29 16:48:54 +08:00
Родитель db38e2111a
Коммит 44ef4d812f
5 изменённых файлов: 233 добавлений и 0 удалений

Просмотреть файл

@ -0,0 +1,6 @@
<!DOCTYPE HTML>
<title>Shared workers: create antoehr sharedworekr client</title>
<pre id=log>Hello World</pre>
<script>
var worker = new SharedWorker('sharedWorker_fetch.js');
</script>

Просмотреть файл

@ -0,0 +1,13 @@
addEventListener('fetch', function(event) {
if (event.request.url.indexOf("fail.html") !== -1) {
event.respondWith(fetch("serviceworker.html", {"integrity": "abc"}));
} else if (event.request.url.indexOf("fake.html") !== -1) {
event.respondWith(fetch("serviceworker.html"));
} else {
event.respondWith(new Response("Hello world"));
}
});
addEventListener("activate", function(event) {
event.waitUntil(clients.claim());
});

Просмотреть файл

@ -209,6 +209,10 @@ support-files =
sw_bad_mime_type.js
sw_bad_mime_type.js^headers^
error_reporting_helpers.js
fetch.js
serviceworker.html
create_another_sharedWorker.html
sharedWorker_fetch.js
[test_bug1151916.html]
[test_bug1240436.html]
@ -225,6 +229,7 @@ support-files =
[test_eval_allowed.html]
[test_eventsource_intercept.html]
[test_fetch_event.html]
[test_fetch_integrity.html]
skip-if = (debug && e10s) # Bug 1262224
[test_file_blob_response.html]
[test_file_blob_upload.html]

Просмотреть файл

@ -0,0 +1,31 @@
var clients = new Array();
clients.length = 0;
var broadcast = function(message) {
var length = clients.length;
for (var i = 0; i < length; i++) {
port = clients[i];
port.postMessage(message);
}
}
onconnect = function(e) {
clients.push(e.ports[0]);
if (clients.length == 1) {
clients[0].postMessage("Connected");
} else if (clients.length == 2) {
broadcast("BothConnected");
clients[0].onmessage = function(e) {
if (e.data == "StartFetchWithWrongIntegrity") {
// The fetch will succeed because the integrity value is invalid and we
// are looking for the console message regarding the bad integrity value.
fetch("SharedWorker_SRIFailed.html", {"integrity": "abc"}).then(
function () {
clients[0].postMessage('SRI_failed');
});
}
}
}
}

Просмотреть файл

@ -0,0 +1,178 @@
<!DOCTYPE HTML>
<html>
<head>
<title> Test fetch.integrity on console report for serviceWorker and sharedWorker </title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<script src="/tests/SimpleTest/SpawnTask.js"></script>
<script src="error_reporting_helpers.js"></script>
<link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
<meta http-equiv="Content-type" content="text/html;charset=UTF-8">
</head>
<body>
<div id="content" style="display: none"></div>
<script type="text/javascript">
"use strict";
let security_localizer =
stringBundleService.createBundle("chrome://global/locale/security/security.properties");
function expect_security_console_message(/* msgId, args, ... */) {
let expectations = [];
// process repeated paired arguments of: msgId, args
for (let i = 0; i < arguments.length; i += 4) {
let msgId = arguments[i];
let args = arguments[i + 1];
let filename = arguments[i + 2];
let windowId = arguments[i + 3];
expectations.push({
errorMessage: security_localizer.formatStringFromName(msgId, args, args.length),
sourceName: filename,
windowID: windowId
});
}
return new Promise(resolve => {
SimpleTest.monitorConsole(resolve, expectations);
});
}
// (This doesn't really need to be its own task, but it allows the actual test
// case to be self-contained.)
add_task(function setupPrefs() {
return SpecialPowers.pushPrefEnv({"set": [
["dom.serviceWorkers.enabled", true],
["dom.serviceWorkers.testing.enabled", true],
]});
});
add_task(function* test_integrity_serviceWorker() {
var filename = make_absolute_url("fetch.js");
var filename2 = make_absolute_url("fake.html");
// The SW will claim us once it activates; this is async, start listening now.
let waitForControlled = new Promise((resolve) => {
navigator.serviceWorker.oncontrollerchange = resolve;
});
let registration = yield navigator.serviceWorker.register("fetch.js",
{ scope: "./" });
yield waitForControlled;
info("Test for mNavigationInterceptions.")
// The client_win will reload to another URL after opening filename2.
let client_win = window.open(filename2);
// XXX windowID should be innerWindowID
let mainWindowID = SpecialPowers.getDOMWindowUtils(window).outerWindowID;
let clientWindowID = SpecialPowers.getDOMWindowUtils(client_win).outerWindowID;
let expectedMessage = expect_security_console_message(
"MalformedIntegrityHash",
["abc"],
filename,
mainWindowID,
"NoValidMetadata",
[""],
filename,
mainWindowID
);
let expectedMessage2 = expect_security_console_message(
"MalformedIntegrityHash",
["abc"],
filename,
clientWindowID,
"NoValidMetadata",
[""],
filename,
clientWindowID
);
info("Test for mControlledDocuments and report error message to console.");
// The fetch will succeed because the integrity value is invalid and we are
// looking for the console message regarding the bad integrity value.
yield fetch("fail.html");
yield wait_for_expected_message(expectedMessage);
yield wait_for_expected_message(expectedMessage2);
yield registration.unregister();
client_win.close();
});
add_task(function* test_integrity_sharedWorker() {
var filename = make_absolute_url("sharedWorker_fetch.js");
info("Attch main window to a SharedWorker.");
let sharedWorker = new SharedWorker(filename);
let waitForConnected = new Promise((resolve) => {
sharedWorker.port.onmessage = function (e) {
if (e.data == "Connected") {
resolve();
} else {
reject();
}
}
});
yield waitForConnected;
info("Attch another window to the same SharedWorker.");
// Open another window and its also managed by the shared worker.
let client_win = window.open("create_another_sharedWorker.html");
let waitForBothConnected = new Promise((resolve) => {
sharedWorker.port.onmessage = function (e) {
if (e.data == "BothConnected") {
resolve();
} else {
reject();
}
}
});
yield waitForBothConnected;
// XXX windowID should be innerWindowID
let mainWindowID = SpecialPowers.getDOMWindowUtils(window).outerWindowID;
let clientWindowID = SpecialPowers.getDOMWindowUtils(client_win).outerWindowID;
let expectedMessage = expect_security_console_message(
"MalformedIntegrityHash",
["abc"],
filename,
mainWindowID,
"NoValidMetadata",
[""],
filename,
mainWindowID
);
let expectedMessage2 = expect_security_console_message(
"MalformedIntegrityHash",
["abc"],
filename,
clientWindowID,
"NoValidMetadata",
[""],
filename,
clientWindowID
);
info("Start to fetch a URL with wrong integrity.")
sharedWorker.port.start();
sharedWorker.port.postMessage("StartFetchWithWrongIntegrity");
let waitForSRIFailed = new Promise((resolve) => {
sharedWorker.port.onmessage = function (e) {
if (e.data == "SRI_failed") {
resolve();
} else {
reject();
}
}
});
yield waitForSRIFailed;
yield wait_for_expected_message(expectedMessage);
yield wait_for_expected_message(expectedMessage2);
client_win.close();
});
</script>
</body>
</html>