| <!DOCTYPE html> |
| <title>Prerendering cannot invoke |
| HTMLVideoElement.requestPictureInPicture</title> |
| <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()); |
| |
| promise_test(async t => { |
| const uid = token(); |
| const bc = new PrerenderChannel('prerender-channel', uid); |
| t.add_cleanup(_ => bc.close()); |
| |
| const gotMessage = new Promise(resolve => { |
| bc.addEventListener('message', e => { |
| resolve(e.data); |
| }, { |
| once: true |
| }); |
| }); |
| |
| // Start prerendering a page that attempts to invoke |
| // HTMLVideoElement.requestPictureInPicture. This API needs |
| // transient activation. So it's expected to fail. |
| startPrerendering(`resources/request-picture-in-picture.html?uid=${uid}`); |
| |
| const result = await gotMessage; |
| assert_equals(result, 'Metadata for the video element are not loaded yet'); |
| }, 'prerendering page cannot invoke' + |
| 'HTMLVideoElement.requestPictureInPicture'); |
| </script> |