blob: 687a4ff1e4190c7bde1d9fdd6eee48314be9be8e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
<!DOCTYPE html>
<title>
Document#fullscreenEnabled removing allowfullscreen after load and then
navigating
</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<div id="log"></div>
<iframe></iframe>
<script>
function requestStatus(iframe) {
iframe.contentWindow.postMessage(
"What is document.fullscreenEnabled?",
"*"
);
return new Promise((resolve) => {
window.addEventListener("message", function listener(e) {
window.removeEventListener("message", listener);
resolve(event.data);
});
});
}
promise_test(async (t) => {
const iframe = document.querySelector("iframe");
iframe.allowFullscreen = true;
assert_true(iframe.allowFullscreen, "allowFullscreen is false");
assert_true(
iframe.hasAttribute("allowfullscreen"),
"allowFullscreen attribute is present"
);
await new Promise((resolve) => {
iframe.onload = resolve;
const path = location.pathname.substring(
0,
location.pathname.lastIndexOf("/") + 1
);
iframe.src = `http://{{hosts[][]}}:{{ports[http][0]}}${path}resources/echo-fullscreenEnabled.html`;
});
assert_true(
await requestStatus(iframe),
"document.fullscreenEnabled in the iframe, before navigation"
);
iframe.allowFullscreen = false;
assert_false(iframe.allowFullscreen, "allowFullscreen is false");
assert_false(
iframe.hasAttribute("allowfullscreen"),
"allowFullscreen attribute is not present"
);
await new Promise((resolve) => {
iframe.onload = resolve;
iframe.contentWindow.location.href = iframe.src + "?2";
});
assert_false(
await requestStatus(iframe),
"document.fullscreenEnabled in the iframe, after navigation"
);
});
</script>
|