| // original test: |
| // http://mxr.mozilla.org/mozilla2.0/source/dom/indexedDB/test/test_odd_result_order.html?raw=1 |
| // license of original test: |
| // " Any copyright is dedicated to the Public Domain. |
| // http://creativecommons.org/publicdomain/zero/1.0/ " |
| |
| if (this.importScripts) { |
| importScripts('../../../../resources/js-test.js'); |
| importScripts('../../resources/shared.js'); |
| } |
| |
| description("Test IndexedDB: request result persists in setTimeout callback"); |
| |
| indexedDBTest(prepareDatabase, openSuccess); |
| function prepareDatabase() |
| { |
| request = event.target; |
| db = event.target.result; |
| objectStore = evalAndLog("objectStore = db.createObjectStore('foo', { keyPath: 'key', autoIncrement: true });"); |
| index = evalAndLog("index = objectStore.createIndex('foo', 'index');"); |
| } |
| |
| function openSuccess() |
| { |
| debug("openSuccess():"); |
| db = evalAndLog("db = null;"); |
| setTimeout(function() { |
| db = evalAndLog("db = request.result;"); |
| checkDatabaseType(); |
| addRecord(); |
| }, 0); |
| } |
| |
| function checkDatabaseType() |
| { |
| debug("checkDatabaseType():"); |
| shouldBeTrue("db instanceof IDBDatabase"); |
| db.onerror = unexpectedErrorCallback; |
| } |
| |
| function addRecord() |
| { |
| debug("addRecord():"); |
| objectStore = evalAndLog("objectStore = db.transaction('foo', 'readwrite').objectStore('foo');"); |
| data = evalAndLog("data = { key: 5, index: 10 };"); |
| request = evalAndLog("request = objectStore.add(data);"); |
| request.onsuccess = addSuccess; |
| request.onerror = unexpectedErrorCallback; |
| } |
| |
| function addSuccess() |
| { |
| debug("addSuccess():"); |
| key = evalAndLog("key = null;"); |
| setTimeout(function() { |
| key = evalAndLog("key = request.result;"); |
| checkAddedKey(); |
| }, 0); |
| } |
| |
| function checkAddedKey() |
| { |
| debug("checkAddedKey():"); |
| shouldBe("key", "data.key"); |
| objectStore = evalAndLog("objectStore = db.transaction('foo').objectStore('foo');"); |
| request = evalAndLog("request = objectStore.get(data.key);"); |
| request.onsuccess = getSuccess; |
| request.onerror = unexpectedErrorCallback; |
| } |
| |
| function getSuccess() |
| { |
| debug("getSuccess():"); |
| record = evalAndLog("record = null;"); |
| setTimeout(function() { |
| record = evalAndLog("record = request.result;"); |
| checkRetrievedKey(); |
| }, 0); |
| } |
| |
| function checkRetrievedKey() |
| { |
| debug("checkRetrievedKey():"); |
| shouldBe("record.key", "data.key"); |
| shouldBe("record.index", "data.index"); |
| deleteRecord(); |
| } |
| |
| function deleteRecord() |
| { |
| debug("deleteRecord():"); |
| objectStore = evalAndLog("objectStore = db.transaction('foo', 'readwrite').objectStore('foo');"); |
| request = evalAndLog("request = objectStore.delete(data.key);"); |
| request.onsuccess = deleteSuccess; |
| request.onerror = unexpectedErrorCallback; |
| } |
| |
| function deleteSuccess() |
| { |
| debug("deleteSuccess():"); |
| finishJSTest(); |
| } |