diff options
Diffstat (limited to 'testing/web-platform/tests/IndexedDB/idbobjectstore_getAll.any.js')
-rw-r--r-- | testing/web-platform/tests/IndexedDB/idbobjectstore_getAll.any.js | 148 |
1 files changed, 148 insertions, 0 deletions
diff --git a/testing/web-platform/tests/IndexedDB/idbobjectstore_getAll.any.js b/testing/web-platform/tests/IndexedDB/idbobjectstore_getAll.any.js new file mode 100644 index 0000000000..db7098f71e --- /dev/null +++ b/testing/web-platform/tests/IndexedDB/idbobjectstore_getAll.any.js @@ -0,0 +1,148 @@ +// META: title=IndexedDB: Test IDBObjectStore.getAll +// META: script=resources/support.js + +'use strict'; + +const alphabet = 'abcdefghijklmnopqrstuvwxyz'.split(''); + +function getall_test(func, name) { + indexeddb_test( + (t, connection, tx) => { + let store = connection.createObjectStore('generated', + { autoIncrement: true, keyPath: 'id' }); + alphabet.forEach(letter => { + store.put({ ch: letter }); + }); + + store = connection.createObjectStore('out-of-line', null); + alphabet.forEach(letter => { + store.put(`value-${letter}`, letter); + }); + + store = connection.createObjectStore('empty', null); + }, + func, + name + ); +} + +function createGetAllRequest(t, storeName, connection, keyRange, maxCount) { + const transaction = connection.transaction(storeName, 'readonly'); + const store = transaction.objectStore(storeName); + const req = store.getAll(keyRange, maxCount); + req.onerror = t.unreached_func('getAll request should succeed'); + return req; +} + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection, 'c'); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, ['value-c']); + t.done(); + }); +}, 'Single item get'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'generated', connection, 3); + req.onsuccess = t.step_func(evt => { + const data = evt.target.result; + assert_true(Array.isArray(data)); + assert_equals(data.length, 1); + assert_equals(data[0].id, 3); + assert_equals(data[0].ch, 'c'); + t.done(); + }); +}, 'Single item get (generated key)'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'empty', connection); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, [], + 'getAll() on empty object store should return an empty array'); + t.done(); + }); +}, 'getAll on empty object store'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, alphabet.map(c => `value-${c}`)); + t.done(); + }); +}, 'Get all values'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection, undefined, + 10); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, 'abcdefghij'.split('').map(c => `value-${c}`)); + t.done(); + }); +}, 'Test maxCount'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection, + IDBKeyRange.bound('g', 'm')); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, 'ghijklm'.split('').map(c => `value-${c}`)); + t.done(); + }); +}, 'Get bound range'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection, + IDBKeyRange.bound('g', 'm'), 3); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, ['g', 'h', 'i'].map(c => `value-${c}`)); + t.done(); + }); +}, 'Get bound range with maxCount'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection, + IDBKeyRange.bound('g', 'k', false, true)); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, ['g', 'h', 'i', 'j'].map(c => `value-${c}`)); + t.done(); + }); +}, 'Get upper excluded'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection, + IDBKeyRange.bound('g', 'k', true, false)); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, ['h', 'i', 'j', 'k'].map(c => `value-${c}`)); + t.done(); + }); +}, 'Get lower excluded'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'generated', connection, + IDBKeyRange.bound(4, 15), 3); + req.onsuccess = t.step_func(evt => { + const data = evt.target.result; + assert_true(Array.isArray(data)); + assert_array_equals(data.map(e => e.ch), ['d', 'e', 'f']); + assert_array_equals(data.map(e => e.id), [4, 5, 6]); + t.done(); + }); +}, 'Get bound range (generated) with maxCount'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection, + "Doesn't exist"); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, [], + 'getAll() using a nonexistent key should return an empty array'); + t.done(); + }); + req.onerror = t.unreached_func('getAll request should succeed'); +}, 'Non existent key'); + +getall_test((t, connection) => { + const req = createGetAllRequest(t, 'out-of-line', connection, undefined, 0); + req.onsuccess = t.step_func(evt => { + assert_array_equals(evt.target.result, alphabet.map(c => `value-${c}`)); + t.done(); + }); +}, 'zero maxCount'); |