| <!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> |
| <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> |