Index: third_party/WebKit/LayoutTests/external/wpt/IndexedDB/fire-error-event-exception.html |
diff --git a/third_party/WebKit/LayoutTests/external/wpt/IndexedDB/fire-error-event-exception.html b/third_party/WebKit/LayoutTests/external/wpt/IndexedDB/fire-error-event-exception.html |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0f231a29b081bbf30dad4cfe102833abf9693d25 |
--- /dev/null |
+++ b/third_party/WebKit/LayoutTests/external/wpt/IndexedDB/fire-error-event-exception.html |
@@ -0,0 +1,352 @@ |
+<!DOCTYPE html> |
+<meta charset=utf-8> |
+<title>Fire error event - Exception thrown</title> |
+<script src=/resources/testharness.js></script> |
pwnall
2017/03/04 00:27:33
Do you think it's worth adding help links, like be
jsbell
2017/03/06 18:25:02
Done.
|
+<script src=/resources/testharnessreport.js></script> |
+<script src=support.js></script> |
+<script> |
+setup({allow_uncaught_exception:true}); |
+ |
+// Listeners on the request. |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
pwnall
2017/03/04 00:27:33
It seems to me that lines 17-21 and 25-28 repeat i
jsbell
2017/03/06 18:25:02
Factored out wrapper functions here and in the oth
|
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ request.onerror = () => { |
+ throw Error(); |
+ }; |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event handler on request'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ request.onerror = e => { |
+ e.preventDefault(); |
+ throw Error(); |
+ }; |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event handler on request, with preventDefault'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ request.addEventListener('error', () => { |
+ throw Error(); |
+ }); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event listener on request'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ request.addEventListener('error', () => { |
+ // no-op |
+ }); |
+ request.addEventListener('error', () => { |
+ throw Error(); |
+ }); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in second error event listener on request'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ let second_listener_called = false; |
+ request.addEventListener('error', () => { |
+ throw Error(); |
+ }); |
+ request.addEventListener('error', t.step_func(() => { |
+ second_listener_called = true; |
+ assert_true(is_transaction_active(tx, 's'), |
+ 'Transaction should be active until dispatch completes'); |
+ })); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_true(second_listener_called); |
pwnall
2017/03/04 00:27:33
This shows up in a few places. I imagine you could
jsbell
2017/03/06 18:25:02
I kept the onabort handler explicit in each test.
|
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in first error event listener on request, ' + |
+ 'transaction active in second'); |
+ |
+// Listeners on the transaction. |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ tx.onerror = () => { |
+ throw Error(); |
+ }; |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event handler on transaction'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ tx.onerror = e => { |
+ e.preventDefault(); |
+ throw Error(); |
+ }; |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event handler on transaction, with preventDefault'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ tx.addEventListener('error', () => { |
+ throw Error(); |
+ }); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event listener on transaction'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ tx.addEventListener('error', () => { |
+ // no-op |
+ }); |
+ tx.addEventListener('error', () => { |
+ throw Error(); |
+ }); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in second error event listener on transaction'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ let second_listener_called = false; |
+ tx.addEventListener('error', () => { |
+ throw Error(); |
+ }); |
+ tx.addEventListener('error', t.step_func(() => { |
+ second_listener_called = true; |
+ assert_true(is_transaction_active(tx, 's'), |
+ 'Transaction should be active until dispatch completes'); |
+ })); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_true(second_listener_called); |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in first error event listener on transaction, ' + |
+ 'transaction active in second'); |
+ |
+// Listeners on the connection. |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ db.onerror = () => { |
+ throw Error(); |
+ }; |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event handler on connection'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ db.onerror = e => { |
+ e.preventDefault() |
+ throw Error(); |
+ }; |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event handler on connection, with preventDefault'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ db.addEventListener('error', () => { |
+ throw Error(); |
+ }); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in error event listener on connection'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ db.addEventListener('error', () => { |
+ // no-op |
+ }); |
+ db.addEventListener('error', () => { |
+ throw Error(); |
+ }); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in second error event listener on connection'); |
+ |
+indexeddb_test( |
+ (t, db) => { |
+ db.createObjectStore('s'); |
+ }, |
+ (t, db) => { |
+ const tx = db.transaction('s', 'readwrite'); |
+ const store = tx.objectStore('s'); |
+ store.put(0, 0); |
+ const request = store.add(0, 0); |
+ request.onsuccess = t.unreached_func('request should fail'); |
+ let second_listener_called = false; |
+ db.addEventListener('error', () => { |
+ throw Error('hi there'); |
pwnall
2017/03/04 00:27:33
It's slightly odd that this error has a message, w
jsbell
2017/03/06 18:25:02
Oops, I left that in from some debugging. Will rem
|
+ }); |
+ db.addEventListener('error', t.step_func(() => { |
+ second_listener_called = true; |
+ assert_true(is_transaction_active(tx, 's'), |
+ 'Transaction should be active until dispatch completes'); |
+ })); |
+ tx.oncomplete = t.unreached_func('transaction should abort'); |
+ tx.onabort = t.step_func_done(() => { |
+ assert_true(second_listener_called); |
+ assert_equals(tx.error.name, 'AbortError'); |
+ }); |
+ }, |
+ 'Exception in first error event listener on connection, ' + |
+ 'transaction active in second'); |
+ |
+</script> |