<!doctype html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<body>
<script>
promise_test(async (t) => {
const i = await setupIframe();
const watcher = new i.contentWindow.CloseWatcher();
watcher.oncancel = () => i.remove();
watcher.onclose = () => t.unreached_func("close event must not fire");
watcher.requestClose();
}, "detaching the iframe during the cancel event");
promise_test(async (t) => {
const i = await setupIframe();
const watcher = new i.contentWindow.CloseWatcher();
watcher.onclose = () => i.remove();
watcher.requestClose();
}, "detaching the iframe during the close event");
promise_test(async (t) => {
const i = await setupIframe();
const watcher = new i.contentWindow.CloseWatcher();
i.remove();
watcher.destroy();
}, "detaching the iframe then calling destroy()");
promise_test(async (t) => {
const i = await setupIframe();
const watcher = new i.contentWindow.CloseWatcher();
watcher.oncancel = () => t.unreached_func("cancel event must not fire");
watcher.onclose = () => t.unreached_func("close event must not fire");
i.remove();
watcher.close();
}, "detaching the iframe then calling close()");
promise_test(async (t) => {
const i = await setupIframe();
const watcher = new i.contentWindow.CloseWatcher();
watcher.oncancel = () => t.unreached_func("cancel event must not fire");
watcher.onclose = () => t.unreached_func("close event must not fire");
i.remove();
watcher.requestClose();
}, "detaching the iframe then calling requestClose()");
promise_test(async (t) => {
const i = await setupIframe();
const iCloseWatcher = i.contentWindow.CloseWatcher;
const iDOMException = i.contentWindow.DOMException;
i.remove();
assert_throws_dom("InvalidStateError", iDOMException, () => new iCloseWatcher());
}, "detaching the iframe then constructing a CloseWatcher");
function setupIframe() {
return new Promise(resolve => {
const i = document.createElement("iframe");
i.onload = () => resolve(i);
i.src = "/common/blank.html";
document.body.append(i);
});
}
</script>