mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-11-07 11:48:19 +02:00
183 lines
5.4 KiB
JavaScript
183 lines
5.4 KiB
JavaScript
requestLongerTimeout(4);
|
|
|
|
// Bug 1617611: Fix all the tests broken by "cookies SameSite=lax by default"
|
|
Services.prefs.setBoolPref("network.cookie.sameSite.laxByDefault", false);
|
|
registerCleanupFunction(() => {
|
|
Services.prefs.clearUserPref("network.cookie.sameSite.laxByDefault");
|
|
});
|
|
|
|
AntiTracking.runTestInNormalAndPrivateMode(
|
|
"Set/Get Cookies",
|
|
// Blocking callback
|
|
async _ => {
|
|
is(document.cookie, "", "No cookies for me");
|
|
document.cookie = "name=value";
|
|
is(document.cookie, "", "No cookies for me");
|
|
|
|
for (let arg of ["?checkonly", "?redirect-checkonly"]) {
|
|
info(`checking with arg=${arg}`);
|
|
await fetch("server.sjs" + arg)
|
|
.then(r => r.text())
|
|
.then(text => {
|
|
is(text, "cookie-not-present", "We should not have cookies");
|
|
});
|
|
// Let's do it twice.
|
|
await fetch("server.sjs" + arg)
|
|
.then(r => r.text())
|
|
.then(text => {
|
|
is(text, "cookie-not-present", "We should not have cookies");
|
|
});
|
|
}
|
|
|
|
is(document.cookie, "", "Still no cookies for me");
|
|
},
|
|
|
|
// Non blocking callback
|
|
async _ => {
|
|
is(document.cookie, "", "No cookies for me");
|
|
|
|
// Note: The ?redirect test is _not_ using checkonly, so it will actually
|
|
// set our foopy=1 cookie.
|
|
for (let arg of ["?checkonly", "?redirect"]) {
|
|
info(`checking with arg=${arg}`);
|
|
await fetch("server.sjs" + arg)
|
|
.then(r => r.text())
|
|
.then(text => {
|
|
is(text, "cookie-not-present", "We should not have cookies");
|
|
});
|
|
}
|
|
|
|
document.cookie = "name=value";
|
|
ok(document.cookie.includes("name=value"), "Some cookies for me");
|
|
ok(document.cookie.includes("foopy=1"), "Some cookies for me");
|
|
|
|
for (let arg of ["", "?redirect"]) {
|
|
info(`checking with arg=${arg}`);
|
|
await fetch("server.sjs" + arg)
|
|
.then(r => r.text())
|
|
.then(text => {
|
|
is(text, "cookie-present", "We should have cookies");
|
|
});
|
|
}
|
|
|
|
ok(document.cookie.length, "Some Cookies for me");
|
|
},
|
|
|
|
// Cleanup callback
|
|
async _ => {
|
|
await new Promise(resolve => {
|
|
Services.clearData.deleteData(Ci.nsIClearDataService.CLEAR_ALL, value =>
|
|
resolve()
|
|
);
|
|
});
|
|
}
|
|
);
|
|
|
|
AntiTracking.runTestInNormalAndPrivateMode(
|
|
"Cookies and Storage Access API",
|
|
// Blocking callback
|
|
async _ => {
|
|
/* import-globals-from storageAccessAPIHelpers.js */
|
|
await noStorageAccessInitially();
|
|
|
|
is(document.cookie, "", "No cookies for me");
|
|
document.cookie = "name=value";
|
|
is(document.cookie, "", "No cookies for me");
|
|
|
|
for (let arg of ["", "?redirect"]) {
|
|
info(`checking with arg=${arg}`);
|
|
await fetch("server.sjs" + arg)
|
|
.then(r => r.text())
|
|
.then(text => {
|
|
is(text, "cookie-not-present", "We should not have cookies");
|
|
});
|
|
// Let's do it twice.
|
|
await fetch("server.sjs" + arg)
|
|
.then(r => r.text())
|
|
.then(text => {
|
|
is(text, "cookie-not-present", "We should not have cookies");
|
|
});
|
|
}
|
|
|
|
is(document.cookie, "", "Still no cookies for me");
|
|
|
|
/* import-globals-from storageAccessAPIHelpers.js */
|
|
await callRequestStorageAccess();
|
|
|
|
is(document.cookie, "", "No cookies for me");
|
|
document.cookie = "name=value";
|
|
|
|
let effectiveCookieBehavior = SpecialPowers.isContentWindowPrivate(window)
|
|
? SpecialPowers.Services.prefs.getIntPref(
|
|
"network.cookie.cookieBehavior.pbmode"
|
|
)
|
|
: SpecialPowers.Services.prefs.getIntPref(
|
|
"network.cookie.cookieBehavior"
|
|
);
|
|
|
|
if (
|
|
[
|
|
SpecialPowers.Ci.nsICookieService.BEHAVIOR_REJECT,
|
|
SpecialPowers.Ci.nsICookieService.BEHAVIOR_REJECT_FOREIGN,
|
|
].includes(effectiveCookieBehavior)
|
|
) {
|
|
is(document.cookie, "", "No cookies for me");
|
|
} else {
|
|
is(document.cookie, "name=value", "I have the cookies!");
|
|
}
|
|
},
|
|
|
|
// Non blocking callback
|
|
async _ => {
|
|
/* import-globals-from storageAccessAPIHelpers.js */
|
|
await hasStorageAccessInitially();
|
|
|
|
is(document.cookie, "", "No cookies for me");
|
|
|
|
// Note: The ?redirect test is _not_ using checkonly, so it will actually
|
|
// set our foopy=1 cookie.
|
|
for (let arg of ["?checkonly", "?redirect"]) {
|
|
info(`checking with arg=${arg}`);
|
|
await fetch("server.sjs" + arg)
|
|
.then(r => r.text())
|
|
.then(text => {
|
|
is(text, "cookie-not-present", "We should not have cookies");
|
|
});
|
|
}
|
|
|
|
document.cookie = "name=value";
|
|
ok(document.cookie.includes("name=value"), "Some cookies for me");
|
|
ok(document.cookie.includes("foopy=1"), "Some cookies for me");
|
|
|
|
for (let arg of ["", "?redirect"]) {
|
|
info(`checking with arg=${arg}`);
|
|
await fetch("server.sjs" + arg)
|
|
.then(r => r.text())
|
|
.then(text => {
|
|
is(text, "cookie-present", "We should have cookies");
|
|
});
|
|
}
|
|
|
|
ok(document.cookie.length, "Some Cookies for me");
|
|
|
|
/* import-globals-from storageAccessAPIHelpers.js */
|
|
await callRequestStorageAccess();
|
|
|
|
// For non-tracking windows, calling the API is a no-op
|
|
ok(document.cookie.length, "Still some Cookies for me");
|
|
ok(document.cookie.includes("name=value"), "Some cookies for me");
|
|
ok(document.cookie.includes("foopy=1"), "Some cookies for me");
|
|
},
|
|
|
|
// Cleanup callback
|
|
async _ => {
|
|
await new Promise(resolve => {
|
|
Services.clearData.deleteData(Ci.nsIClearDataService.CLEAR_ALL, value =>
|
|
resolve()
|
|
);
|
|
});
|
|
},
|
|
null,
|
|
false,
|
|
false
|
|
);
|