64 lines
1.7 KiB
JavaScript
64 lines
1.7 KiB
JavaScript
// This test works by setting up an exception for the tracker domain, which
|
|
// disables all the anti-tracking tests.
|
|
|
|
add_task(async _ => {
|
|
PermissionTestUtils.add(
|
|
"https://tracking.example.org",
|
|
"cookie",
|
|
Services.perms.DENY_ACTION
|
|
);
|
|
PermissionTestUtils.add(
|
|
"https://tracking.example.com",
|
|
"cookie",
|
|
Services.perms.DENY_ACTION
|
|
);
|
|
// Grant interaction permission so we can directly call
|
|
// requestStorageAccess from the tracker.
|
|
PermissionTestUtils.add(
|
|
"https://tracking.example.org",
|
|
"storageAccessAPI",
|
|
Services.perms.ALLOW_ACTION
|
|
);
|
|
|
|
registerCleanupFunction(_ => {
|
|
Services.perms.removeAll();
|
|
});
|
|
});
|
|
|
|
AntiTracking._createTask({
|
|
name: "Test that we do honour a cookie permission for nested windows",
|
|
cookieBehavior: BEHAVIOR_REJECT_TRACKER,
|
|
blockingByContentBlockingRTUI: true,
|
|
allowList: false,
|
|
callback: async _ => {
|
|
document.cookie = "name=value";
|
|
ok(document.cookie == "", "All is blocked");
|
|
|
|
// requestStorageAccess should reject
|
|
SpecialPowers.wrap(document).notifyUserGestureActivation();
|
|
await document
|
|
.requestStorageAccess()
|
|
.then(() => {
|
|
ok(false, "Should not grant storage access");
|
|
})
|
|
.catch(() => {
|
|
ok(true, "Should not grant storage access");
|
|
});
|
|
SpecialPowers.wrap(document).clearUserGestureActivation();
|
|
},
|
|
extraPrefs: null,
|
|
expectedBlockingNotifications:
|
|
Ci.nsIWebProgressListener.STATE_COOKIES_BLOCKED_BY_PERMISSION,
|
|
runInPrivateWindow: false,
|
|
iframeSandbox: null,
|
|
accessRemoval: null,
|
|
callbackAfterRemoval: null,
|
|
});
|
|
|
|
add_task(async _ => {
|
|
await new Promise(resolve => {
|
|
Services.clearData.deleteData(Ci.nsIClearDataService.CLEAR_ALL, () =>
|
|
resolve()
|
|
);
|
|
});
|
|
});
|