summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-exit-iframe.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-exit-iframe.html')
-rw-r--r--testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-exit-iframe.html97
1 files changed, 97 insertions, 0 deletions
diff --git a/testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-exit-iframe.html b/testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-exit-iframe.html
new file mode 100644
index 0000000000..f0bf5f6bac
--- /dev/null
+++ b/testing/web-platform/tests/fullscreen/api/element-request-fullscreen-and-exit-iframe.html
@@ -0,0 +1,97 @@
+<!DOCTYPE html>
+<title>
+ Element#requestFullscreen() and Document#exitFullscreen() in 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>
+<iframe allowfullscreen></iframe>
+<script>
+ const iframe = document.querySelector("iframe");
+ let iframeDoc;
+ let iframeBody;
+
+ promise_setup(async () => {
+ const iframe = document.querySelector("iframe");
+ await new Promise((resolve) => {
+ iframe.onload = resolve;
+ iframe.src = "about:blank";
+ });
+ iframeDoc = iframe.contentDocument;
+ iframeBody = iframeDoc.body;
+ });
+ /**
+ *
+ * @param {Document} doc
+ * @param {HTMLElement} value
+ * @returns {Promise<Event>}
+ */
+ function makeChangeListener(doc) {
+ return new Promise((resolve) => {
+ doc.addEventListener("fullscreenchange", resolve, { once: true });
+ });
+ }
+
+ // Both when entering and exiting, the fullscreenchange event is fired first
+ // on the outer document and then on the iframe's document. This is because
+ // the events are fired in animation frame tasks, which run in "frame tree"
+ // order.
+ promise_test(async (t) => {
+ document.onfullscreenerror = t.unreached_func(
+ "document fullscreenerror event"
+ );
+ iframeDoc.onfullscreenerror = t.unreached_func(
+ "iframe fullscreenerror event"
+ );
+ const outerPromise = makeChangeListener(document);
+ const innerPromise = makeChangeListener(iframeDoc);
+ const request = trusted_request(iframeBody, iframeBody);
+
+ const winningEvent = await Promise.race([outerPromise, innerPromise]);
+ assert_equals(winningEvent.target, iframe);
+
+ await Promise.allSettled([outerPromise, innerPromise, request]);
+
+ assert_equals(
+ document.fullscreenElement,
+ iframe,
+ "outer fullscreenElement"
+ );
+
+ assert_equals(
+ iframeDoc.fullscreenElement,
+ iframeBody,
+ "inner fullscreenElement"
+ );
+ }, "Checks that the fullscreenchange events fire in right order when entering fullscreen");
+
+ promise_test(async (t) => {
+ document.onfullscreenerror = t.unreached_func(
+ "document fullscreenerror event"
+ );
+ iframeDoc.onfullscreenerror = t.unreached_func(
+ "iframe fullscreenerror event"
+ );
+ const outerPromise = makeChangeListener(document);
+ const innerPromise = makeChangeListener(iframeDoc);
+ const exitPromise = iframeDoc.exitFullscreen();
+
+ const winningEvent = await Promise.race([outerPromise, innerPromise]);
+ assert_equals(winningEvent.target, iframe);
+
+ await Promise.allSettled([outerPromise, innerPromise, exitPromise]);
+ assert_equals(
+ document.fullscreenElement,
+ null,
+ "outer fullscreenElement"
+ );
+ assert_equals(
+ iframeDoc.fullscreenElement,
+ null,
+ "inner fullscreenElement"
+ );
+ }, "Checks that the fullscreenchange events fire in right order when exiting fullscreen");
+</script>