From f4bce10cdaf038cdb559de35238edf096084b82e Mon Sep 17 00:00:00 2001 From: Florian Dold Date: Tue, 16 Feb 2021 15:07:38 +0100 Subject: more test WPTs --- .../request-bubble-and-capture.test.ts | 83 ++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 packages/idb-bridge/src/idb-wpt-ported/request-bubble-and-capture.test.ts (limited to 'packages/idb-bridge/src/idb-wpt-ported/request-bubble-and-capture.test.ts') diff --git a/packages/idb-bridge/src/idb-wpt-ported/request-bubble-and-capture.test.ts b/packages/idb-bridge/src/idb-wpt-ported/request-bubble-and-capture.test.ts new file mode 100644 index 000000000..c59a63bc6 --- /dev/null +++ b/packages/idb-bridge/src/idb-wpt-ported/request-bubble-and-capture.test.ts @@ -0,0 +1,83 @@ +import test from "ava"; +import { BridgeIDBRequest } from ".."; +import { EventTarget, IDBDatabase } from "../idbtypes"; +import { createdb } from "./wptsupport"; + +// Bubbling and capturing of request events +test("WPT request_bubble-and-capture.htm", async (t) => { + await new Promise((resolve, reject) => { + var events: any[] = []; + + var open_rq = createdb(t); + open_rq.onupgradeneeded = function (e: any) { + 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: any) { + e.preventDefault(); + }, + false, + ); + }; + + open_rq.onsuccess = function (e) { + log("open_rq.success")(e); + t.deepEqual( + 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", + ); + resolve(); + }; + + function log_request(type: any, obj: EventTarget) { + 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: any) { + return function (e: any) { + if (e && e.target && e.target.error) + events.push(msg + ": " + e.target.error.name); + else events.push(msg); + }; + } + }); + t.pass(); +}); -- cgit v1.2.3