// META: global=window,dedicatedworker,sharedworker,serviceworker // META: script=resources/support-promises.js // META: script=resources/reading-autoincrement-common.js promise_test(async testCase => { const database = await setupAutoincrementDatabase(testCase); const transaction = database.transaction(['store'], 'readonly'); const store = transaction.objectStore('store'); const index = store.index('by_id'); const request = index.getAll(); const result = await promiseForRequest(testCase, request); assert_equals(result.length, 32); for (let i = 1; i <= 32; ++i) { assert_equals(result[i - 1].id, i, 'Autoincrement key'); assert_equals(result[i - 1].name, nameForId(i), 'String property'); } database.close(); }, 'IDBIndex.getAll() for an index on the autoincrement key'); promise_test(async testCase => { const database = await setupAutoincrementDatabase(testCase); const transaction = database.transaction(['store'], 'readonly'); const store = transaction.objectStore('store'); const index = store.index('by_id'); const request = index.getAllKeys(); const result = await promiseForRequest(testCase, request); assert_equals(result.length, 32); for (let i = 1; i <= 32; ++i) assert_equals(result[i - 1], i, 'Autoincrement key'); database.close(); }, 'IDBIndex.getAllKeys() for an index on the autoincrement key'); promise_test(async testCase => { const database = await setupAutoincrementDatabase(testCase); const transaction = database.transaction(['store'], 'readonly'); const store = transaction.objectStore('store'); const index = store.index('by_id'); for (let i = 1; i <= 32; ++i) { const request = index.get(i); const result = await promiseForRequest(testCase, request); assert_equals(result.id, i, 'autoincrement key'); assert_equals(result.name, nameForId(i), 'string property'); } database.close(); }, 'IDBIndex.get() for an index on the autoincrement key'); promise_test(async testCase => { const database = await setupAutoincrementDatabase(testCase); const stringSortedIds = idsSortedByStringCompare(); const transaction = database.transaction(['store'], 'readonly'); const store = transaction.objectStore('store'); const index = store.index('by_name'); const request = index.getAll(); const result = await promiseForRequest(testCase, request); assert_equals(result.length, 32); for (let i = 1; i <= 32; ++i) { assert_equals(result[i - 1].id, stringSortedIds[i - 1], 'autoincrement key'); assert_equals(result[i - 1].name, nameForId(stringSortedIds[i - 1]), 'string property'); } database.close(); }, 'IDBIndex.getAll() for an index not covering the autoincrement key'); promise_test(async testCase => { const database = await setupAutoincrementDatabase(testCase); const stringSortedIds = idsSortedByStringCompare(); const transaction = database.transaction(['store'], 'readonly'); const store = transaction.objectStore('store'); const index = store.index('by_name'); const request = index.getAllKeys(); const result = await promiseForRequest(testCase, request); assert_equals(result.length, 32); for (let i = 1; i <= 32; ++i) assert_equals(result[i - 1], stringSortedIds[i - 1], 'String property'); database.close(); }, 'IDBIndex.getAllKeys() returns correct result for an index not covering ' + 'the autoincrement key'); promise_test(async testCase => { const database = await setupAutoincrementDatabase(testCase); const transaction = database.transaction(['store'], 'readonly'); const store = transaction.objectStore('store'); const index = store.index('by_name'); for (let i = 1; i <= 32; ++i) { const request = index.get(nameForId(i)); const result = await promiseForRequest(testCase, request); assert_equals(result.id, i, 'Autoincrement key'); assert_equals(result.name, nameForId(i), 'String property'); } database.close(); }, 'IDBIndex.get() for an index not covering the autoincrement key');