diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /dom/base/test/test_lock_orientation_with_pending_fullscreen.html | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esrupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/base/test/test_lock_orientation_with_pending_fullscreen.html')
-rw-r--r-- | dom/base/test/test_lock_orientation_with_pending_fullscreen.html | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/dom/base/test/test_lock_orientation_with_pending_fullscreen.html b/dom/base/test/test_lock_orientation_with_pending_fullscreen.html new file mode 100644 index 0000000000..7df60a7e72 --- /dev/null +++ b/dom/base/test/test_lock_orientation_with_pending_fullscreen.html @@ -0,0 +1,126 @@ +<!DOCTYPE html> +<html> +<!-- +https://bugzilla.mozilla.org/show_bug.cgi?id=1744288 +--> +<head> +<meta charset="utf-8"> +<title>Test for Bug 1744288</title> +<script src="/tests/SimpleTest/SimpleTest.js"></script> +<link rel="stylesheet" href="/tests/SimpleTest/test.css"/> +</head> +<body> +<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=174488">Mozilla Bug 1744288</a> +<script> +const kIsWin = navigator.platform.indexOf("Win") == 0; + +add_task(async function test_pending_fullscreen_request() { + if (kIsWin) { + // CI won't run on Windows tablet mode. + ok(true, "Skip on Windows"); + return; + } + + await SpecialPowers.pushPrefEnv({ + set: [["dom.screenorientation.allow-lock", true]] + }); + + SpecialPowers.wrap(document.documentElement).requestFullscreen(); + let gotException = false; + try { + await window.screen.orientation.lock("any"); + } catch (e) { + gotException = true; + } + ok(!gotException, "No exception even if fullscreen request is pending."); + + window.screen.orientation.unlock(); + try { + await document.exitFullscreen(); + } catch (e) { + } +}); + +// Gecko doesn't allow orientation lock without fullscreen by default +add_task(async function test_no_fullscreen_request() { + if (kIsWin) { + // CI won't run on Windows tablet mode. + ok(true, "Skip on Windows"); + return; + } + + await SpecialPowers.pushPrefEnv({ + set: [["dom.screenorientation.allow-lock", true]] + }); + + let gotException = false; + try { + await window.screen.orientation.lock("any"); + } catch (e) { + gotException = true; + } + ok(gotException, "Should throw an exception when fullscreen request is nothing."); +}); + +// Gecko doesn't allow orientation lock after fullscreen request is canceled +add_task(async function test_cancel_pending_fullscreen_request() { + if (kIsWin) { + // CI won't run on Windows tablet mode. + ok(true, "Skip on Windows"); + return; + } + + await SpecialPowers.pushPrefEnv({ + set: [["dom.screenorientation.allow-lock", true]] + }); + + const element = document.createElement("div"); + document.body.appendChild(element); + SpecialPowers.wrap(element).requestFullscreen().then(() => { + ok(false, "Fullscreen request should be canceled."); + }, () => { + ok(true, "Fullscreen request is canceled."); + }); + let gotException = false; + try { + const promise = window.screen.orientation.lock("any"); + // Removing element causes that fullscreen request is canceled. + document.body.removeChild(element); + await promise; + } catch (e) { + gotException = true; + } + ok(gotException, "Should throw an exception when pending fullscreen request is canceled."); + + try { + window.screen.orientation.unlock(); + await document.exitFullscreen(); + } catch (e) { + } +}); + +add_task(async function test_dont_leak_memory_with_pending_fullscreen_request() { + await SpecialPowers.pushPrefEnv({ + set: [["dom.screenorientation.allow-lock", true]] + }); + + const iframe = document.createElement("iframe"); + iframe.setAttribute("allowFullScreen", ""); + iframe.src = "file_lock_orientation_with_pending_fullscreen.html"; + + const promise = new Promise(resolve => { + window.addEventListener("message", function handler(e) { + if (e.data === "pending") { + document.body.removeChild(iframe); + window.removeEventListener("message", handler); + resolve(); + } + }); + }); + + document.body.appendChild(iframe); + await promise; +}); +</script> +</body> +</html> |