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/fullscreen/api/element-request-fullscreen-and-move-to-iframe.html | |
parent | Initial commit. (diff) | |
download | firefox-upstream.tar.xz firefox-upstream.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/fullscreen/api/element-request-fullscreen-and-move-to-iframe.html')
-rw-r--r-- | testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-move-to-iframe.html | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-move-to-iframe.html b/testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-move-to-iframe.html new file mode 100644 index 0000000000..f758835012 --- /dev/null +++ b/testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-move-to-iframe.html @@ -0,0 +1,61 @@ +<!DOCTYPE html> +<title> + Element#requestFullscreen() followed by moving the element into an iframe +</title> +<script src="/resources/testharness.js"></script> +<script src="/resources/testharnessreport.js"></script> +<script src="/resources/testdriver.js"></script> +<script src="/resources/testdriver-vendor.js"></script> +<script src="../trusted-click.js"></script> +<div id="log"></div> +<div id="target"></div> +<iframe allowfullscreen></iframe> +<script> + // rfsPromise will be uncaught + setup({ allow_uncaught_exception: true }); + + promise_test(async (t) => { + const iframe = document.querySelector("iframe"); + await new Promise((r) => { + iframe.onload = r; + iframe.src = "about:blank"; + }); + const target = document.getElementById("target"); + const iframeDoc = iframe.contentDocument; + + iframeDoc.onfullscreenchange = t.unreached_func( + "fullscreenchange event in iframe" + ); + iframeDoc.onfullscreenerror = t.unreached_func( + "fullscreenerror event in iframe" + ); + document.onfullscreenchange = t.unreached_func( + "fullscreenchange event" + ); + + const errorPromise = new Promise( + (resolve) => (document.onfullscreenerror = resolve) + ); + await trusted_click(document.body); + const rfsPromise = target.requestFullscreen(); + iframeDoc.body.appendChild(target); + const event = await errorPromise; + assert_equals( + iframeDoc.fullscreenElement, + null, + "inner fullscreen element" + ); + assert_equals( + document.fullscreenElement, + null, + "outer fullscreen element" + ); + assert_equals(event.target, document, "event target"); + await promise_rejects_js( + t, + TypeError, + rfsPromise, + "requestFullscreen promise" + ); + }, "Element#requestFullscreen() followed by moving the element into an iframe"); +</script> |