summaryrefslogtreecommitdiffstats
path: root/dom/indexedDB/test/browser_private_idb.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /dom/indexedDB/test/browser_private_idb.js
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/indexedDB/test/browser_private_idb.js')
-rw-r--r--dom/indexedDB/test/browser_private_idb.js199
1 files changed, 199 insertions, 0 deletions
diff --git a/dom/indexedDB/test/browser_private_idb.js b/dom/indexedDB/test/browser_private_idb.js
new file mode 100644
index 0000000000..5627361fc6
--- /dev/null
+++ b/dom/indexedDB/test/browser_private_idb.js
@@ -0,0 +1,199 @@
+async function idbCheckFunc() {
+ let factory, console;
+ try {
+ // in a worker, this resolves directly.
+ factory = indexedDB;
+ console = self.console;
+ } catch (ex) {
+ // in a frame-script, we need to pierce "content"
+ factory = content.indexedDB;
+ console = content.console;
+ }
+ try {
+ console.log("opening db");
+ const req = factory.open("db", 1);
+ const result = await new Promise((resolve, reject) => {
+ req.onerror = () => {
+ resolve("error");
+ };
+ // we expect the db to not exist and for created to resolve first
+ req.onupgradeneeded = () => {
+ resolve("created");
+ };
+ // ...so this will lose the race
+ req.onsuccess = event => {
+ resolve("already-exists");
+ };
+ });
+ const db = req.result;
+ console.log("db req completed:", result);
+ if (result !== "error") {
+ db.close();
+ console.log("deleting database");
+ await new Promise((resolve, reject) => {
+ const delReq = factory.deleteDatabase("db");
+ delReq.onerror = reject;
+ delReq.onsuccess = resolve;
+ });
+ console.log("deleted database");
+ }
+ return result;
+ } catch (ex) {
+ console.error("received error:", ex);
+ return "exception";
+ }
+}
+
+async function workerDriverFunc() {
+ const resultPromise = idbCheckFunc();
+ /* eslint-env worker */
+ // (SharedWorker)
+ if (!("postMessage" in self)) {
+ addEventListener("connect", function (evt) {
+ const port = evt.ports[0];
+ resultPromise.then(result => {
+ console.log("worker test completed, postMessage-ing result:", result);
+ port.postMessage({ idbResult: result });
+ });
+ });
+ }
+ const result = await resultPromise;
+ // (DedicatedWorker)
+ if ("postMessage" in self) {
+ console.log("worker test completed, postMessage-ing result:", result);
+ postMessage({ idbResult: result });
+ }
+}
+
+const workerScript = `
+${idbCheckFunc.toSource()}
+(${workerDriverFunc.toSource()})();
+`;
+const workerScriptBlob = new Blob([workerScript]);
+
+/**
+ * This function is deployed via ContextTask.spawn and operates in a tab
+ * frame script context. Its job is to create the worker that will run the
+ * idbCheckFunc and return the result to us.
+ */
+async function workerCheckDeployer({ srcBlob, workerType }) {
+ const { console } = content;
+ let worker, port;
+ const url = content.URL.createObjectURL(srcBlob);
+ if (workerType === "dedicated") {
+ worker = new content.Worker(url);
+ port = worker;
+ } else if (workerType === "shared") {
+ worker = new content.SharedWorker(url);
+ port = worker.port;
+ port.start();
+ } else {
+ throw new Error("bad worker type!");
+ }
+
+ const result = await new Promise((resolve, reject) => {
+ port.addEventListener(
+ "message",
+ function (evt) {
+ resolve(evt.data.idbResult);
+ },
+ { once: true }
+ );
+ worker.addEventListener("error", function (evt) {
+ console.error("worker problem:", evt);
+ reject(evt);
+ });
+ });
+ console.log("worker completed test with result:", result);
+
+ return result;
+}
+
+function checkTabWindowIDB(tab) {
+ return SpecialPowers.spawn(tab.linkedBrowser, [], idbCheckFunc);
+}
+
+async function checkTabDedicatedWorkerIDB(tab) {
+ return SpecialPowers.spawn(
+ tab.linkedBrowser,
+ [
+ {
+ srcBlob: workerScriptBlob,
+ workerType: "dedicated",
+ },
+ ],
+ workerCheckDeployer
+ );
+}
+
+async function checkTabSharedWorkerIDB(tab) {
+ return SpecialPowers.spawn(
+ tab.linkedBrowser,
+ [
+ {
+ srcBlob: workerScriptBlob,
+ workerType: "shared",
+ },
+ ],
+ workerCheckDeployer
+ );
+}
+
+add_task(async function () {
+ const pageUrl =
+ "http://example.com/browser/dom/indexedDB/test/page_private_idb.html";
+
+ const enabled = SpecialPowers.getBoolPref(
+ "dom.indexedDB.privateBrowsing.enabled"
+ );
+
+ let normalWin = await BrowserTestUtils.openNewBrowserWindow();
+ let privateWin = await BrowserTestUtils.openNewBrowserWindow({
+ private: true,
+ });
+
+ let normalTab = await BrowserTestUtils.openNewForegroundTab(
+ normalWin.gBrowser,
+ pageUrl
+ );
+ let privateTab = await BrowserTestUtils.openNewForegroundTab(
+ privateWin.gBrowser,
+ pageUrl
+ );
+
+ is(
+ await checkTabWindowIDB(normalTab),
+ "created",
+ "IndexedDB works in a non-private-browsing page."
+ );
+ is(
+ await checkTabWindowIDB(privateTab),
+ enabled ? "created" : "error",
+ "IndexedDB does not work in a private-browsing page."
+ );
+
+ is(
+ await checkTabDedicatedWorkerIDB(normalTab),
+ "created",
+ "IndexedDB works in a non-private-browsing Worker."
+ );
+ is(
+ await checkTabDedicatedWorkerIDB(privateTab),
+ enabled ? "created" : "error",
+ "IndexedDB does not work in a private-browsing Worker."
+ );
+
+ is(
+ await checkTabSharedWorkerIDB(normalTab),
+ "created",
+ "IndexedDB works in a non-private-browsing SharedWorker."
+ );
+ is(
+ await checkTabSharedWorkerIDB(privateTab),
+ enabled ? "created" : "error",
+ "IndexedDB does not work in a private-browsing SharedWorker."
+ );
+
+ await BrowserTestUtils.closeWindow(normalWin);
+ await BrowserTestUtils.closeWindow(privateWin);
+});