// 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 result = await getAllViaCursor(testCase, index); assert_equals(result.length, 32); for (let i = 1; i <= 32; ++i) { assert_equals(result[i - 1].key, i, 'Autoincrement index key'); assert_equals(result[i - 1].primaryKey, i, 'Autoincrement primary key'); assert_equals(result[i - 1].value.id, i, 'Autoincrement key in value'); assert_equals(result[i - 1].value.name, nameForId(i), 'String property in value'); } database.close(); }, 'IDBIndex.openCursor() iterates over 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 result = await getAllKeysViaCursor(testCase, index); assert_equals(result.length, 32); for (let i = 1; i <= 32; ++i) { assert_equals(result[i - 1].key, i, 'Autoincrement index key'); assert_equals(result[i - 1].primaryKey, i, 'Autoincrement primary key'); } database.close(); }, 'IDBIndex.openKeyCursor() iterates over 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_name'); const stringSortedIds = idsSortedByStringCompare(); const result = await getAllViaCursor(testCase, index); assert_equals(result.length, 32); for (let i = 1; i <= 32; ++i) { assert_equals(result[i - 1].key, nameForId(stringSortedIds[i - 1]), 'Index key'); assert_equals(result[i - 1].primaryKey, stringSortedIds[i - 1], 'Autoincrement primary key'); assert_equals(result[i - 1].value.id, stringSortedIds[i - 1], 'Autoincrement key in value'); assert_equals(result[i - 1].value.name, nameForId(stringSortedIds[i - 1]), 'String property in value'); } database.close(); }, 'IDBIndex.openCursor() iterates over 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'); const stringSortedIds = idsSortedByStringCompare(); const result = await getAllKeysViaCursor(testCase, index); assert_equals(result.length, 32); for (let i = 1; i <= 32; ++i) { assert_equals(result[i - 1].key, nameForId(stringSortedIds[i - 1]), 'Index key'); assert_equals(result[i - 1].primaryKey, stringSortedIds[i - 1], 'Autoincrement primary key'); } database.close(); }, 'IDBIndex.openKeyCursor() iterates over an index not covering the ' + 'autoincrement key');