mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
ebd6e6dc19
- Bug 1174323 - Disable screenClientXYConst subtest of pointerlock test on OS X. rs=KWierso (2d0db6d1b) - Bug 992096 - Implement Sub Resource Integrity [1/2]. r=baku,r=ckerschb (c30671ac0) - Bug 992096 - Implement Sub Resource Integrity [2/2]. r=ckerschb (0afc64d88) - Bug 1091883 - Added test, this is fixed by a fix to bug 1113438. r=sstamm CLOSED TREE (fd9a64b43) - Bug 1196740 - Consider redirects when looking for SRI-eligibility. r=ckerschb (5c749cdc9) - Bug 1202015 - Better document the SRI strings for translators. r=ckerschb (a7860e0fb) - Bug 1202027 - Make SRI require CORS loads for cross-origin resources. r=ckerschb (ea451323d) - bit of Bug 1202902 - Mass replace toplevel 'let' with 'var' (a6e8a587d) - Bug 1208629 - Properly support data: and blob: URIs with an integrity atribute. r=ckerschb (6b2018fe4) - Bug 1140129 - Don't clear tab title when location changes (r=Mossop) (ca1945ba8) - Bug 1073462: Send synthetic property with Content:LocationChange message. r=felipe (1aa418acf) - bug 1165017 - annotate content process URL on location change. r=mconley (cdca4fa75) - Bug 1157561 - Add webRequest-like API to Firefox (r=Mossop) (546a57822) - Bug 1163861 - Include windowID in all WebRequest notifications (r=Mossop) (c140af560) - Bug 1171248 - Add MatchPattern support to WebRequest module (r=Mossop) (b09a05658)
90 lines
2.2 KiB
JavaScript
90 lines
2.2 KiB
JavaScript
"use strict";
|
|
|
|
const { interfaces: Ci, classes: Cc, utils: Cu, results: Cr } = Components;
|
|
|
|
let {WebRequest} = Cu.import("resource://gre/modules/WebRequest.jsm", {});
|
|
|
|
const BASE = "http://example.com/browser/toolkit/modules/tests/browser";
|
|
const URL = BASE + "/WebRequest_dynamic.sjs";
|
|
|
|
let countBefore = 0;
|
|
let countAfter = 0;
|
|
|
|
function onBeforeSendHeaders(details)
|
|
{
|
|
if (details.url != URL) {
|
|
return;
|
|
}
|
|
|
|
countBefore++;
|
|
|
|
info(`onBeforeSendHeaders ${details.url}`);
|
|
let found = false;
|
|
let headers = [];
|
|
for (let {name, value} of details.requestHeaders) {
|
|
info(`Saw header ${name} '${value}'`);
|
|
if (name == "Cookie") {
|
|
is(value, "foopy=1", "Cookie is correct");
|
|
headers.push({name, value: "blinky=1"});
|
|
found = true;
|
|
} else {
|
|
headers.push({name, value});
|
|
}
|
|
}
|
|
ok(found, "Saw cookie header");
|
|
|
|
return {requestHeaders: headers};
|
|
}
|
|
|
|
function onResponseStarted(details)
|
|
{
|
|
if (details.url != URL) {
|
|
return;
|
|
}
|
|
|
|
countAfter++;
|
|
|
|
info(`onResponseStarted ${details.url}`);
|
|
let found = false;
|
|
for (let {name, value} of details.responseHeaders) {
|
|
info(`Saw header ${name} '${value}'`);
|
|
if (name == "Set-Cookie") {
|
|
is(value, "dinky=1", "Cookie is correct");
|
|
found = true;
|
|
}
|
|
}
|
|
ok(found, "Saw cookie header");
|
|
}
|
|
|
|
add_task(function* filter_urls() {
|
|
// First load the URL so that we set cookie foopy=1.
|
|
gBrowser.selectedTab = gBrowser.addTab(URL);
|
|
yield waitForLoad();
|
|
gBrowser.removeCurrentTab();
|
|
|
|
// Now load with WebRequest set up.
|
|
WebRequest.onBeforeSendHeaders.addListener(onBeforeSendHeaders, null, ["blocking"]);
|
|
WebRequest.onResponseStarted.addListener(onResponseStarted, null);
|
|
|
|
gBrowser.selectedTab = gBrowser.addTab(URL);
|
|
|
|
yield waitForLoad();
|
|
|
|
gBrowser.removeCurrentTab();
|
|
|
|
WebRequest.onBeforeSendHeaders.removeListener(onBeforeSendHeaders);
|
|
WebRequest.onResponseStarted.removeListener(onResponseStarted);
|
|
|
|
is(countBefore, 1, "onBeforeSendHeaders hit once");
|
|
is(countAfter, 1, "onResponseStarted hit once");
|
|
});
|
|
|
|
function waitForLoad(browser = gBrowser.selectedBrowser) {
|
|
return new Promise(resolve => {
|
|
browser.addEventListener("load", function listener() {
|
|
browser.removeEventListener("load", listener, true);
|
|
resolve();
|
|
}, true);
|
|
});
|
|
}
|