"use strict"; CookiePolicyHelper.runTest("IndexedDB", { cookieJarAccessAllowed: async w => { w.indexedDB.open("test", "1"); ok(true, "IDB should be allowed"); }, cookieJarAccessDenied: async w => { try { w.indexedDB.open("test", "1"); ok(false, "IDB should be blocked"); } catch (e) { ok(true, "IDB should be blocked"); is(e.name, "SecurityError", "We want a security error message."); } }, }); CookiePolicyHelper.runTest("IndexedDB in workers", { cookieJarAccessAllowed: async w => { function nonBlockCode() { indexedDB.open("test", "1"); postMessage(true); } let blob = new w.Blob([nonBlockCode.toString() + "; nonBlockCode();"]); ok(blob, "Blob has been created"); let blobURL = w.URL.createObjectURL(blob); ok(blobURL, "Blob URL has been created"); let worker = new w.Worker(blobURL); ok(worker, "Worker has been created"); await new w.Promise((resolve, reject) => { worker.onmessage = function (e) { if (e.data) { resolve(); } else { reject(); } }; worker.onerror = function () { reject(); }; }); }, cookieJarAccessDenied: async w => { function blockCode() { try { indexedDB.open("test", "1"); postMessage(false); } catch (e) { postMessage(e.name == "SecurityError"); } } let blob = new w.Blob([blockCode.toString() + "; blockCode();"]); ok(blob, "Blob has been created"); let blobURL = w.URL.createObjectURL(blob); ok(blobURL, "Blob URL has been created"); let worker = new w.Worker(blobURL); ok(worker, "Worker has been created"); await new w.Promise((resolve, reject) => { worker.onmessage = function (e) { if (e.data) { resolve(); } else { reject(); } }; worker.onerror = function () { reject(); }; }); }, });