diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
commit | 43a97878ce14b72f0981164f87f2e35e14151312 (patch) | |
tree | 620249daf56c0258faa40cbdcf9cfba06de2a846 /testing/web-platform/tests/IndexedDB/idbcursor-advance-invalid.htm | |
parent | Initial commit. (diff) | |
download | firefox-43a97878ce14b72f0981164f87f2e35e14151312.tar.xz firefox-43a97878ce14b72f0981164f87f2e35e14151312.zip |
Adding upstream version 110.0.1.upstream/110.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/IndexedDB/idbcursor-advance-invalid.htm')
-rw-r--r-- | testing/web-platform/tests/IndexedDB/idbcursor-advance-invalid.htm | 192 |
1 files changed, 192 insertions, 0 deletions
diff --git a/testing/web-platform/tests/IndexedDB/idbcursor-advance-invalid.htm b/testing/web-platform/tests/IndexedDB/idbcursor-advance-invalid.htm new file mode 100644 index 0000000000..67c5e93df0 --- /dev/null +++ b/testing/web-platform/tests/IndexedDB/idbcursor-advance-invalid.htm @@ -0,0 +1,192 @@ +<!DOCTYPE html> +<title>IDBCursor.advance() - invalid</title> +<link rel="author" href="mailto:odinho@opera.com" title="Odin Hørthe Omdal"> +<link rel=help href="http://dvcs.w3.org/hg/IndexedDB/raw-file/tip/Overview.html#widl-IDBCursor-advance-void-unsigned-long-count"> +<link rel=assert title="If the value for count is 0 (zero) or a negative number, this method must throw a JavaScript TypeError exception."> +<link rel=assert title="TypeError The value passed into the count parameter was zero or a negative number."> +<link rel=assert title="InvalidStateError The cursor is currently being iterated, or has iterated past its end."> +<link rel=assert title="Calling this method more than once before new cursor data has been loaded is not allowed and results in a DOMException of type InvalidStateError being thrown. For example, calling advance() twice from the same onsuccess handler results in a DOMException of type InvalidStateError being thrown on the second call."> +<link rel=assert title="Before this method returns, unless an exception was thrown, it sets the got value flag on the cursor to false."> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="resources/support.js"></script> + +<script> + +function upgrade_func(t, db, tx) { + var objStore = db.createObjectStore("test"); + objStore.createIndex("index", ""); + + objStore.add("data", 1); + objStore.add("data2", 2); +} + +indexeddb_test( + upgrade_func, + function(t, db) { + var count = 0; + var rq = db.transaction("test", "readonly", {durability: 'relaxed'}).objectStore("test").index("index").openCursor(); + + rq.onsuccess = t.step_func(function(e) { + if (!e.target.result) { + assert_equals(count, 2, 'count'); + t.done(); + return; + } + var cursor = e.target.result; + + cursor.advance(1); + + // Second try + assert_throws_dom('InvalidStateError', + function() { cursor.advance(1); }, 'second advance'); + + assert_throws_dom('InvalidStateError', + function() { cursor.advance(3); }, 'third advance'); + + count++; + }); + rq.onerror = t.unreached_func("unexpected error") + }, + document.title + " - attempt to call advance twice" +); + +indexeddb_test( + upgrade_func, + function(t, db) { + var rq = db.transaction("test", "readonly", {durability: 'relaxed'}).objectStore("test").index("index").openCursor(); + + rq.onsuccess = t.step_func(function(e) { + var cursor = e.target.result; + + assert_throws_js(TypeError, + function() { cursor.advance(document); }); + + assert_throws_js(TypeError, + function() { cursor.advance({}); }); + + assert_throws_js(TypeError, + function() { cursor.advance([]); }); + + assert_throws_js(TypeError, + function() { cursor.advance(""); }); + + assert_throws_js(TypeError, + function() { cursor.advance("1 2"); }); + + t.done(); + }); + rq.onerror = t.unreached_func("unexpected error") + }, + document.title + " - pass something other than number" +); + + +indexeddb_test( + upgrade_func, + function(t, db) { + var rq = db.transaction("test", "readonly", {durability: 'relaxed'}).objectStore("test").index("index").openCursor(); + + rq.onsuccess = t.step_func(function(e) { + var cursor = e.target.result; + + assert_throws_js(TypeError, + function() { cursor.advance(null); }); + + assert_throws_js(TypeError, + function() { cursor.advance(undefined); }); + + var myvar = null; + assert_throws_js(TypeError, + function() { cursor.advance(myvar); }); + + t.done(); + }); + rq.onerror = t.unreached_func("unexpected error") + }, + document.title + " - pass null/undefined" +); + + +indexeddb_test( + upgrade_func, + function(t, db) { + var rq = db.transaction("test", "readonly", {durability: 'relaxed'}).objectStore("test").index("index").openCursor(); + + rq.onsuccess = t.step_func(function(e) { + var cursor = e.target.result; + + assert_throws_js(TypeError, + function() { cursor.advance(); }); + + t.done(); + }); + rq.onerror = t.unreached_func("unexpected error") + }, + document.title + " - missing argument" +); + +indexeddb_test( + upgrade_func, + function(t, db) { + var rq = db.transaction("test", "readonly", {durability: 'relaxed'}).objectStore("test").index("index").openCursor(); + + rq.onsuccess = t.step_func(function(e) { + var cursor = e.target.result; + + assert_throws_js(TypeError, + function() { cursor.advance(-1); }); + + assert_throws_js(TypeError, + function() { cursor.advance(NaN); }); + + assert_throws_js(TypeError, + function() { cursor.advance(0); }); + + assert_throws_js(TypeError, + function() { cursor.advance(-0); }); + + assert_throws_js(TypeError, + function() { cursor.advance(Infinity); }); + + assert_throws_js(TypeError, + function() { cursor.advance(-Infinity); }); + + var myvar = -999999; + assert_throws_js(TypeError, + function() { cursor.advance(myvar); }); + + t.done(); + }); + rq.onerror = t.unreached_func("unexpected error") + }, + document.title + " - pass negative numbers" +); + +indexeddb_test( + upgrade_func, + function(t, db) { + var count = 0; + var rq = db.transaction("test", "readonly", {durability: 'relaxed'}).objectStore("test").index("index").openCursor(); + + rq.onsuccess = t.step_func(function(e) { + var cursor = e.target.result; + if (!cursor) + { + assert_equals(count, 2, "count runs"); + t.done(); + return; + } + + assert_throws_js(TypeError, + function() { cursor.advance(0); }); + + cursor.advance(1); + count++; + }); + rq.onerror = t.unreached_func("unexpected error") + }, + document.title + " - got value not set on exception" +); + +</script> |