// This test works by setting up an exception for the tracker domain, which // disables all the anti-tracking tests. /* import-globals-from antitracking_head.js */ 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, value => resolve() ); }); });