summaryrefslogtreecommitdiffstats
path: root/dom/indexedDB/test/unit/test_rename_objectStore.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /dom/indexedDB/test/unit/test_rename_objectStore.js
parentInitial commit. (diff)
downloadthunderbird-upstream.tar.xz
thunderbird-upstream.zip
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/indexedDB/test/unit/test_rename_objectStore.js')
-rw-r--r--dom/indexedDB/test/unit/test_rename_objectStore.js173
1 files changed, 173 insertions, 0 deletions
diff --git a/dom/indexedDB/test/unit/test_rename_objectStore.js b/dom/indexedDB/test/unit/test_rename_objectStore.js
new file mode 100644
index 0000000000..6d3524b8ff
--- /dev/null
+++ b/dom/indexedDB/test/unit/test_rename_objectStore.js
@@ -0,0 +1,173 @@
+/**
+ * Any copyright is dedicated to the Public Domain.
+ * http://creativecommons.org/publicdomain/zero/1.0/
+ */
+
+/* exported testGenerator */
+var testGenerator = testSteps();
+
+function* testSteps() {
+ const name = this.window ? window.location.pathname : "Splendid Test";
+ const storeName_ToBeDeleted = "test store to be deleted";
+ const storeName_v0 = "test store v0";
+ const storeName_v1 = "test store v1";
+ const storeName_v2 = "test store v2";
+ const storeName_v3 = storeName_ToBeDeleted;
+ const storeName_v4 = "test store v4";
+
+ info("Rename in v1.");
+ let request = indexedDB.open(name, 1);
+ request.onerror = errorHandler;
+ request.onupgradeneeded = grabEventAndContinueHandler;
+ request.onsuccess = unexpectedSuccessHandler;
+ let event = yield undefined;
+
+ let db = event.target.result;
+ let txn = event.target.transaction;
+
+ is(db.objectStoreNames.length, 0, "Correct objectStoreNames list");
+
+ // create objectstore to be deleted later in v3.
+ db.createObjectStore(storeName_ToBeDeleted, { keyPath: "foo" });
+ is(db.objectStoreNames.length, 1, "Correct objectStoreNames list");
+ ok(db.objectStoreNames.contains(storeName_ToBeDeleted), "Correct name");
+
+ // create target objectstore to be renamed.
+ let objectStore = db.createObjectStore(storeName_v0, { keyPath: "bar" });
+ is(db.objectStoreNames.length, 2, "Correct objectStoreNames list");
+ ok(db.objectStoreNames.contains(objectStore.name), "Correct name");
+
+ objectStore.name = storeName_v1;
+ is(objectStore.name, storeName_v1, "Renamed successfully");
+
+ txn.oncomplete = continueToNextStepSync;
+ yield undefined;
+ request.onsuccess = continueToNextStep;
+ yield undefined;
+ db.close();
+
+ info("Verify renaming done in v1 and run renaming in v2.");
+ request = indexedDB.open(name, 2);
+ request.onerror = errorHandler;
+ request.onupgradeneeded = grabEventAndContinueHandler;
+ request.onsuccess = unexpectedSuccessHandler;
+ event = yield undefined;
+
+ db = event.target.result;
+ txn = event.target.transaction;
+
+ is(db.objectStoreNames.length, 2, "Correct objectStoreNames list");
+ ok(db.objectStoreNames.contains(storeName_v1), "Correct name");
+ ok(db.objectStoreNames.contains(storeName_ToBeDeleted), "Correct name");
+
+ objectStore = txn.objectStore(storeName_v1);
+ objectStore.name = storeName_v2;
+ is(objectStore.name, storeName_v2, "Renamed successfully");
+
+ txn.oncomplete = continueToNextStepSync;
+ yield undefined;
+ request.onsuccess = continueToNextStep;
+ yield undefined;
+ db.close();
+
+ info("Verify renaming done in v2.");
+ request = indexedDB.open(name, 2);
+ request.onerror = errorHandler;
+ request.onupgradeneeded = errorHandler;
+ request.onsuccess = grabEventAndContinueHandler;
+ event = yield undefined;
+
+ db = event.target.result;
+
+ is(db.objectStoreNames.length, 2, "Correct objectStoreNames list");
+ ok(db.objectStoreNames.contains(storeName_v2), "Correct name");
+ ok(db.objectStoreNames.contains(storeName_ToBeDeleted), "Correct name");
+
+ db.close();
+
+ info("Rename in v3.");
+ request = indexedDB.open(name, 3);
+ request.onerror = errorHandler;
+ request.onupgradeneeded = grabEventAndContinueHandler;
+ request.onsuccess = unexpectedSuccessHandler;
+ event = yield undefined;
+
+ db = event.target.result;
+ txn = event.target.transaction;
+
+ is(db.objectStoreNames.length, 2, "Correct objectStoreNames list");
+ ok(db.objectStoreNames.contains(storeName_v2), "Correct name");
+ ok(db.objectStoreNames.contains(storeName_ToBeDeleted), "Correct name");
+ db.deleteObjectStore(storeName_ToBeDeleted);
+ is(db.objectStoreNames.length, 1, "Correct objectStoreNames list");
+ ok(
+ db.objectStoreNames.contains(storeName_v2) &&
+ !db.objectStoreNames.contains(storeName_ToBeDeleted),
+ "Deleted correctly"
+ );
+
+ objectStore = txn.objectStore(storeName_v2);
+ objectStore.name = storeName_v3;
+ is(objectStore.name, storeName_v3, "Renamed successfully");
+
+ txn.oncomplete = continueToNextStepSync;
+ yield undefined;
+ request.onsuccess = continueToNextStep;
+ yield undefined;
+ db.close();
+
+ info("Verify renaming done in v3.");
+ request = indexedDB.open(name, 3);
+ request.onerror = errorHandler;
+ request.onupgradeneeded = errorHandler;
+ request.onsuccess = grabEventAndContinueHandler;
+ event = yield undefined;
+
+ db = event.target.result;
+
+ is(db.objectStoreNames.length, 1, "Correct objectStoreNames list");
+ ok(db.objectStoreNames.contains(storeName_v3), "Correct name");
+
+ db.close();
+
+ info("Abort the version change transaction while renaming objectstore.");
+ request = indexedDB.open(name, 4);
+ request.onerror = errorHandler;
+ request.onupgradeneeded = grabEventAndContinueHandler;
+ request.onsuccess = unexpectedSuccessHandler;
+ event = yield undefined;
+
+ db = event.target.result;
+ txn = event.target.transaction;
+
+ objectStore = txn.objectStore(storeName_v3);
+ objectStore.name = storeName_v4;
+ is(objectStore.name, storeName_v4, "Renamed successfully");
+ let putRequest = objectStore.put({ bar: "barValue" });
+ putRequest.onsuccess = continueToNextStepSync;
+ yield undefined;
+
+ // Aborting the transaction.
+ request.onerror = expectedErrorHandler("AbortError");
+ txn.abort();
+ yield undefined;
+
+ // Verify if the name of the objectStore handle is reverted.
+ is(objectStore.name, storeName_v3, "The name is reverted after aborted.");
+
+ info("Verify if the objectstore name is unchanged.");
+ request = indexedDB.open(name, 3);
+ request.onerror = errorHandler;
+ request.onupgradeneeded = errorHandler;
+ request.onsuccess = grabEventAndContinueHandler;
+ event = yield undefined;
+
+ db = event.target.result;
+
+ is(db.objectStoreNames.length, 1, "Correct objectStoreNames list");
+ ok(db.objectStoreNames.contains(storeName_v3), "Correct name");
+
+ db.close();
+
+ finishTest();
+}