84 lines
1.9 KiB
JavaScript
84 lines
1.9 KiB
JavaScript
"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();
|
|
};
|
|
});
|
|
},
|
|
});
|