summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/storage/helpers.js
blob: b524c1b82cfb7b7f8810d1150ff3df8b98f31017 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/**
 * @description - Function will create a database with the supplied name
 *                and also create an object store with the specified name.
 *                If a db with the name dbName exists, this will raze the
 *                existing DB beforehand.
 * @param {string} dbName
 * @param {string} objectStoreName
 * @param {testCase} t
 * @returns {Promise} - A promise that resolves to an indexedDB open request
 */
function createDB(dbName, objectStoreName, t) {
  return new Promise((resolve, reject) => {
    const openRequest = indexedDB.open(dbName);
    t.add_cleanup(() => {
      indexedDB.deleteDatabase(dbName);
    });
    openRequest.onerror = () => {
      reject(openRequest.error);
    };
    openRequest.onsuccess = () => {
      resolve(openRequest.result);
    };
    openRequest.onupgradeneeded = (event) => {
      openRequest.result.createObjectStore(objectStoreName);
    };
  });
}

/**
 * @description - This function will wrap an IDBTransaction in a promise,
 *                resolving in the oncomplete() method and rejecting with the
 *                transaction error in the onabort() case.
 * @param {IDBTransaction} transaction - The transaction to wrap in a promise.
 * @returns {Promise} - A promise that resolves when the transaction is either
 *                      aborted or completed.
 */
function transactionPromise(transaction) {
  return new Promise((resolve, reject) => {
    transaction.onabort = () => {
      reject(transaction.error);
    };
    transaction.oncomplete = () => {
      resolve();
    };
  });
}