diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /testing/web-platform/tests/IndexedDB/idbcursor-advance-continue-async.htm | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip |
Add m-esr52 at 52.6.0
Diffstat (limited to 'testing/web-platform/tests/IndexedDB/idbcursor-advance-continue-async.htm')
-rw-r--r-- | testing/web-platform/tests/IndexedDB/idbcursor-advance-continue-async.htm | 186 |
1 files changed, 186 insertions, 0 deletions
diff --git a/testing/web-platform/tests/IndexedDB/idbcursor-advance-continue-async.htm b/testing/web-platform/tests/IndexedDB/idbcursor-advance-continue-async.htm new file mode 100644 index 000000000..d1b6af3e1 --- /dev/null +++ b/testing/web-platform/tests/IndexedDB/idbcursor-advance-continue-async.htm @@ -0,0 +1,186 @@ +<!DOCTYPE html> +<title>IDBCursor asyncness</title> +<link rel="author" href="mailto:odinho@opera.com" title="Odin Hørthe Omdal"> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="support.js"></script> + +<script> + + var db, open; + + setup(function() { + open = indexedDB.open('testdb-' + new Date().getTime()); + open.onupgradeneeded = function(e) { + db = e.target.result; + var objStore = db.createObjectStore("test"); + objStore.createIndex("index", ""); + + objStore.add("data", 1); + objStore.add("data2", 2); + }; + }, + { explicit_done: true }); + + + open.onsuccess = function() { + + + async_test(document.title + " - advance").step(function(e) { + var count = 0; + var rq = db.transaction("test").objectStore("test").openCursor(); + + rq.onsuccess = this.step_func(function(e) { + if (!e.target.result) { + assert_equals(count, 2, 'count'); + this.done(); + return; + } + var cursor = e.target.result; + + switch(count) { + case 0: + assert_equals(cursor.value, "data") + assert_equals(cursor.key, 1) + cursor.advance(1) + assert_equals(cursor.value, "data") + assert_equals(cursor.key, 1) + break + + case 1: + assert_equals(cursor.value, "data2") + assert_equals(cursor.key, 2) + cursor.advance(1) + assert_equals(cursor.value, "data2") + assert_equals(cursor.key, 2) + break + + default: + assert_unreached("Unexpected count: " + count) + } + + count++; + }); + rq.onerror = fail(this, "unexpected error") + }); + + + async_test(document.title + " - continue").step(function(e) { + var count = 0; + var rq = db.transaction("test").objectStore("test").index("index").openCursor(); + + rq.onsuccess = this.step_func(function(e) { + if (!e.target.result) { + assert_equals(count, 2, 'count'); + this.done(); + return; + } + var cursor = e.target.result; + + switch(count) { + case 0: + assert_equals(cursor.value, "data") + assert_equals(cursor.key, "data") + assert_equals(cursor.primaryKey, 1) + cursor.continue("data2") + assert_equals(cursor.value, "data") + assert_equals(cursor.key, "data") + assert_equals(cursor.primaryKey, 1) + break + + case 1: + assert_equals(cursor.value, "data2") + assert_equals(cursor.key, "data2") + assert_equals(cursor.primaryKey, 2) + cursor.continue() + assert_equals(cursor.value, "data2") + assert_equals(cursor.key, "data2") + assert_equals(cursor.primaryKey, 2) + break + + default: + assert_unreached("Unexpected count: " + count) + } + + count++; + }); + rq.onerror = fail(this, "unexpected error") + }); + + + async_test(document.title + " - fresh advance still async").step(function(e) { + var count = 0; + var rq = db.transaction("test").objectStore("test").index("index").openCursor(); + + rq.onsuccess = this.step_func(function(e) { + if (!e.target.result) { + assert_equals(count, 2, 'count'); + this.done(); + return; + } + var cursor = e.target.result; + cursor.advance(1) + + switch(count) { + case 0: + assert_equals(cursor.value, "data") + assert_equals(cursor.key, "data") + assert_equals(cursor.primaryKey, 1) + break + + case 1: + assert_equals(cursor.value, "data2") + assert_equals(cursor.key, "data2") + assert_equals(cursor.primaryKey, 2) + break + + default: + assert_unreached("Unexpected count: " + count) + } + + count++; + }); + rq.onerror = fail(this, "unexpected error") + }); + + + async_test(document.title + " - fresh continue still async").step(function(e) { + var count = 0; + var rq = db.transaction("test").objectStore("test").openCursor(); + + rq.onsuccess = this.step_func(function(e) { + if (!e.target.result) { + assert_equals(count, 2, 'count'); + this.done(); + return; + } + var cursor = e.target.result; + cursor.continue() + + switch(count) { + case 0: + assert_equals(cursor.value, "data") + assert_equals(cursor.key, 1) + break + + case 1: + assert_equals(cursor.value, "data2") + assert_equals(cursor.key, 2) + break + + default: + assert_unreached("Unexpected count: " + count) + } + + count++; + }); + rq.onerror = fail(this, "unexpected error") + }); + + // Stop blocking the testing system from hereon + done(); + } + +</script> + +<div id=log></div> |