summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/fullscreen/api/document-fullscreen-enabled-removing-allowfullscreen.sub.html
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>