mirror of
https://github.com/LadybirdBrowser/ladybird
synced 2026-04-27 10:07:15 +02:00
Tests/LibWeb: Import Fullscreen WPT tests
This commit is contained in:
Notes:
github-actions[bot]
2026-02-23 18:45:39 +00:00
Author: https://github.com/Lubrsi Commit: https://github.com/LadybirdBrowser/ladybird/commit/8017f8a7ed3 Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/7649 Reviewed-by: https://github.com/shannonbooth ✅ Reviewed-by: https://github.com/tcl3
@@ -0,0 +1,46 @@
|
||||
<!DOCTYPE html>
|
||||
<title>Document#exitFullscreen() timing</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>
|
||||
<script>
|
||||
promise_test(async (t) => {
|
||||
const div = document.querySelector("div");
|
||||
await trusted_request(div);
|
||||
|
||||
await Promise.all([
|
||||
new Promise((r) => (document.onfullscreenchange = r)),
|
||||
document.exitFullscreen(),
|
||||
]);
|
||||
|
||||
// If fullscreenchange is an animation frame event, then animation frame
|
||||
// callbacks should be run after it is fired, before the timer callback.
|
||||
// The resize event should fire before the fullscreenchange event.
|
||||
const events = [];
|
||||
const callback = t.step_func((event) => {
|
||||
// fullscreenElement should have changed before either event is fired.
|
||||
assert_equals(
|
||||
document.fullscreenElement,
|
||||
null,
|
||||
`fullscreenElement in ${event.type} event`
|
||||
);
|
||||
events.push(event.type);
|
||||
if (event.type == "fullscreenchange") {
|
||||
step_timeout(t.unreached_func("timer callback"));
|
||||
requestAnimationFrame(
|
||||
t.step_func_done(() => {
|
||||
assert_array_equals(
|
||||
events,
|
||||
["resize", "fullscreenchange"],
|
||||
"event order"
|
||||
);
|
||||
})
|
||||
);
|
||||
}
|
||||
});
|
||||
document.onfullscreenchange = window.onresize = callback;
|
||||
}, "Timing of fullscreenchange and resize events");
|
||||
</script>
|
||||
Reference in New Issue
Block a user