summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/speculation-rules/prerender/restriction-window-resize.html
blob: 20a71b4bdb5945d6217b1a4055a2ee06f8507ceb (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
<!DOCTYPE html>
<meta name="timeout" content="long">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/utils.js"></script>
<script src="resources/utils.js"></script>
<body>
<script>

setup(() => assertSpeculationRulesIsSupported());

// ResizeTo and ResizeBy operations should be ignored.
// See https://github.com/jeremyroman/alternate-loading-modes/issues/73.
['resizeTo', 'resizeBy'].forEach(resizeFunc => {
  promise_test(
      async t => {
        const uid = token();
        const bc = new PrerenderChannel('test-channel', uid);
        t.add_cleanup(_ => bc.close());

        const gotMessage = new Promise(resolve => {
          bc.addEventListener('message', e => {
            resolve(e.data);
          }, {once: true});
        });

        const url = `resources/window-resize.html?resize=${resizeFunc}&uid=${uid}`;

        // We have to open a new window to run the test, since a window that was
        // not created by window.open() cannot be resized.
        window.open(
            url, '_blank',
            `width=${window.screen.availWidth / 2},height=${
                window.screen.availHeight / 2},noopener`);

        const result = await gotMessage;
        assert_equals(result.status, 'PASS');
        assert_equals(
            result.prevRect.width, result.newRect.width,
            'width for prerendering');
        assert_equals(
            result.prevRect.height, result.newRect.height,
            'height for prerendering');
      },
      `a prerendering page cannot resize its window by executing ${
          resizeFunc}.`);
});

</script>
</body>