summaryrefslogtreecommitdiffstats
path: root/dom/indexedDB/test/unit/test_view_put_get_values.js
diff options
context:
space:
mode:
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.js102
1 files changed, 102 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 000000000..51b9db572
--- /dev/null
+++ b/dom/indexedDB/test/unit/test_view_put_get_values.js
@@ -0,0 +1,102 @@
+/**
+ * Any copyright is dedicated to the Public Domain.
+ * http://creativecommons.org/publicdomain/zero/1.0/
+ */
+
+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) };
+
+ for (let external of [false, true]) {
+ if (external) {
+ info("Setting data threshold pref");
+
+ if (this.window) {
+ SpecialPowers.pushPrefEnv(
+ { "set": [["dom.indexedDB.dataThreshold", 0]] }, continueToNextStep);
+ yield undefined;
+ } else {
+ setDataThreshold(0);
+ }
+ }
+
+ 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 (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;
+ }
+
+ finishTest();
+ yield undefined;
+}