Index: LayoutTests/imported/web-platform-tests/IndexedDB/request_bubble-and-capture.htm |
diff --git a/LayoutTests/imported/web-platform-tests/IndexedDB/request_bubble-and-capture.htm b/LayoutTests/imported/web-platform-tests/IndexedDB/request_bubble-and-capture.htm |
new file mode 100644 |
index 0000000000000000000000000000000000000000..5523cc42177b314322503694146417b9f6790b35 |
--- /dev/null |
+++ b/LayoutTests/imported/web-platform-tests/IndexedDB/request_bubble-and-capture.htm |
@@ -0,0 +1,69 @@ |
+<!DOCTYPE html> |
+<meta charset=utf-8> |
+<title>Bubbling and capturing of request events</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 events = []; |
+ |
+ var open_rq = createdb(async_test(document.title, {timeout: 10000})); |
+ open_rq.onupgradeneeded = function(e) { |
+ var db = e.target.result; |
+ var txn = e.target.transaction; |
+ var store = db.createObjectStore("s"); |
+ var rq1 = store.add("", 1); |
+ var rq2 = store.add("", 1); |
+ db.onerror = function(){}; |
+ |
+ log_request(' db', db); |
+ log_request('txn', txn); |
+ log_request('rq1', rq1); |
+ log_request('rq2', rq2); |
+ |
+ // Don't let it get to abort |
+ db.addEventListener('error', function(e) { e.preventDefault() }, false); |
+ } |
+ |
+ open_rq.onsuccess = function(e) { |
+ log("open_rq.success")(e); |
+ assert_object_equals(events, [ |
+ "capture db.success", |
+ "capture txn.success", |
+ "capture rq1.success", |
+ "bubble rq1.success", |
+ |
+ "capture db.error: ConstraintError", |
+ "capture txn.error: ConstraintError", |
+ "capture rq2.error: ConstraintError", |
+ "bubble rq2.error: ConstraintError", |
+ "bubble txn.error: ConstraintError", |
+ "bubble db.error: ConstraintError", |
+ |
+ "open_rq.success" |
+ ], |
+ "events"); |
+ this.done(); |
+ } |
+ |
+ |
+ function log_request(type, obj) { |
+ obj.addEventListener('success', log('capture ' + type + '.success'), true); |
+ obj.addEventListener('success', log('bubble ' + type + '.success'), false); |
+ obj.addEventListener('error', log('capture ' + type + '.error'), true); |
+ obj.addEventListener('error', log('bubble ' + type + '.error'), false); |
+ } |
+ |
+ function log(msg) { |
+ return function(e) { |
+ if(e && e.target && e.target.error) |
+ events.push(msg + ": " + e.target.error.name); |
+ else |
+ events.push(msg); |
+ }; |
+ } |
+</script> |
+ |
+<div id=log></div> |