diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /testing/web-platform/tests/window-management/multi-screen-fullscreen-companion.tentative.https.html | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/window-management/multi-screen-fullscreen-companion.tentative.https.html')
-rw-r--r-- | testing/web-platform/tests/window-management/multi-screen-fullscreen-companion.tentative.https.html | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/testing/web-platform/tests/window-management/multi-screen-fullscreen-companion.tentative.https.html b/testing/web-platform/tests/window-management/multi-screen-fullscreen-companion.tentative.https.html new file mode 100644 index 0000000000..a4b09f3d5a --- /dev/null +++ b/testing/web-platform/tests/window-management/multi-screen-fullscreen-companion.tentative.https.html @@ -0,0 +1,54 @@ +<!DOCTYPE html> +<meta name="timeout" content="long"> +<!-- user agents are not required to support open features other than `noopener` + and on some platforms position and size features don't make sense --> +<meta name="flags" content="may"> +<title>Window Management test: Fullscreen Companion Window</title> +<link rel="help" href="https://w3c.github.io/window-management/"> +Tests use of multi-screen details to enter fullscreen and open a 'companion' +popup window in the same user activation.<br> +The host device must have 2+ screens to yield meaningful results.<br><br> +<button id="closeButton" onclick="closePopups">Close popups</button><br> +<input id="autoClose" type="checkbox" checked=true>Auto-close popups</input> +<ul id="list"></ul> +<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="resources/helpers.js"></script> +<script> +'use strict'; + +let popups = []; +function closePopups() { + popups.forEach(p => p.close()); + popups = []; +} + +promise_test(async setUpTest => { + await setUpWindowManagement(setUpTest); + const screens = window.screenDetails.screens; + const originalScreen = window.screenDetails.currentScreen; + for (const [i, screenA] of screens.entries()) { + const screenB = screens[(i + 1) % screens.length]; + let name = `Fullscreen on '${screenA.label}'; popup on '${screenB.label}'`; + promise_test(async test => { + await buttonClick(test, name); + await document.documentElement.requestFullscreen({ screen: screenA }); + await assertWindowOnScreen(window, screenA); + // Expect the popup to open if multiple screens are available. + const assertPlacement = screens.length > 1; + const popup = await openPopupOnScreen(screenB, assertPlacement); + if (!!popup) + popups.push(popup); + // Exit fullscreen; `window` should move back to `originalScreen`. + await buttonClick(test, `Exit fullscreen`); + await document.exitFullscreen(); + await assertWindowOnScreen(window, originalScreen); + assert_false(!!document.fullscreenElement); + if (autoClose.checked) + closePopups(); + }, name); + } +}, 'Enter fullscreen and open a popup from one transient activation.'); +</script> |