blob: 6f461abca582f66d5f8949e6cee9d522f4173046 [file] [log] [blame]
<!DOCTYPE html>
<title>Remove the last element on the fullscreen element stack</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="../trusted-click.js"></script>
<div id="log"></div>
<div id="first">
<div id="last"></div>
</div>
<script>
async_test(function(t)
{
t.add_cleanup(() => {
Promise.resolve(document.exitFullscreen()).catch(() => {});
});
var first = document.getElementById("first");
trusted_request(t, first);
document.onfullscreenchange = t.step_func(function(event)
{
assert_equals(document.fullscreenElement, first);
assert_equals(event.target, first);
var last = document.getElementById("last");
trusted_request(t, last);
document.onfullscreenchange = t.step_func(function(event)
{
assert_equals(document.fullscreenElement, last);
assert_equals(event.target, last);
last.remove();
// Because /last/ was removed from the top layer, we exit
// fullscreen element synchronously.
assert_equals(document.fullscreenElement, first);
document.onfullscreenchange = t.step_func_done(function(event)
{
// fullscreen change element should be queued against the
// document target.
assert_equals(document.fullscreenElement, null);
assert_equals(event.target, document);
});
});
});
});
</script>