summaryrefslogtreecommitdiffstats
path: root/dom/indexedDB/test/unit/test_view_put_get_values.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /dom/indexedDB/test/unit/test_view_put_get_values.js
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/indexedDB/test/unit/test_view_put_get_values.js')
-rw-r--r--dom/indexedDB/test/unit/test_view_put_get_values.js151
1 files changed, 151 insertions, 0 deletions
diff --git a/dom/indexedDB/test/unit/test_view_put_get_values.js b/dom/indexedDB/test/unit/test_view_put_get_values.js
new file mode 100644
index 0000000000..a270e65f2f
--- /dev/null
+++ b/dom/indexedDB/test/unit/test_view_put_get_values.js
@@ -0,0 +1,151 @@
+/**
+ * Any copyright is dedicated to the Public Domain.
+ * http://creativecommons.org/publicdomain/zero/1.0/
+ */
+
+/* exported testGenerator, disableWorkerTest */
+var disableWorkerTest = "Need a way to set temporary prefs from a worker";
+
+var testGenerator = testSteps();
+
+function* testSteps() {
+ const name = this.window
+ ? window.location.pathname
+ : "test_view_put_get_values.js";
+
+ const objectStoreName = "Views";
+
+ const viewData = { key: 1, view: getRandomView(100000) };
+
+ const tests = [
+ {
+ external: false,
+ preprocessing: false,
+ },
+ {
+ external: true,
+ preprocessing: false,
+ },
+ {
+ external: true,
+ preprocessing: true,
+ },
+ ];
+
+ for (let test of tests) {
+ if (test.external) {
+ if (this.window) {
+ info("Setting data threshold pref");
+
+ SpecialPowers.pushPrefEnv(
+ { set: [["dom.indexedDB.dataThreshold", 0]] },
+ continueToNextStep
+ );
+ yield undefined;
+ } else {
+ setDataThreshold(0);
+ }
+ }
+
+ if (test.preprocessing) {
+ if (this.window) {
+ info("Setting preprocessing pref");
+
+ SpecialPowers.pushPrefEnv(
+ { set: [["dom.indexedDB.preprocessing", true]] },
+ continueToNextStep
+ );
+ yield undefined;
+ } else {
+ enablePreprocessing();
+ }
+ }
+
+ info("Opening database");
+
+ let request = indexedDB.open(name);
+ request.onerror = errorHandler;
+ request.onupgradeneeded = continueToNextStepSync;
+ request.onsuccess = unexpectedSuccessHandler;
+ yield undefined;
+
+ // upgradeneeded
+ request.onupgradeneeded = unexpectedSuccessHandler;
+ request.onsuccess = continueToNextStepSync;
+
+ info("Creating objectStore");
+
+ request.result.createObjectStore(objectStoreName);
+
+ yield undefined;
+
+ // success
+ let db = request.result;
+ db.onerror = errorHandler;
+
+ info("Storing view");
+
+ let objectStore = db
+ .transaction([objectStoreName], "readwrite")
+ .objectStore(objectStoreName);
+ request = objectStore.add(viewData.view, viewData.key);
+ request.onsuccess = continueToNextStepSync;
+ yield undefined;
+
+ is(request.result, viewData.key, "Got correct key");
+
+ info("Getting view");
+
+ request = objectStore.get(viewData.key);
+ request.onsuccess = continueToNextStepSync;
+ yield undefined;
+
+ verifyView(request.result, viewData.view);
+ yield undefined;
+
+ info("Getting view in new transaction");
+
+ request = db
+ .transaction([objectStoreName])
+ .objectStore(objectStoreName)
+ .get(viewData.key);
+ request.onsuccess = continueToNextStepSync;
+ yield undefined;
+
+ verifyView(request.result, viewData.view);
+ yield undefined;
+
+ getCurrentUsage(grabFileUsageAndContinueHandler);
+ let fileUsage = yield undefined;
+
+ if (test.external) {
+ ok(fileUsage > 0, "File usage is not zero");
+ } else {
+ ok(fileUsage == 0, "File usage is zero");
+ }
+
+ db.close();
+
+ request = indexedDB.deleteDatabase(name);
+ request.onerror = errorHandler;
+ request.onsuccess = continueToNextStepSync;
+ yield undefined;
+
+ if (this.window) {
+ info("Resetting prefs");
+
+ SpecialPowers.popPrefEnv(continueToNextStep);
+ yield undefined;
+ } else {
+ if (test.external) {
+ resetDataThreshold();
+ }
+
+ if (test.preprocessing) {
+ resetPreprocessing();
+ }
+ }
+ }
+
+ finishTest();
+}