Source code

Revision control

Copy as Markdown

Other Tools

<!DOCTYPE html>
<script src="/common/utils.js"></script>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script src="/speculation-rules/prerender/resources/utils.js"></script>
<script src="/speculation-rules/prerender/resources/deferred-promise-utils.js"></script>
<body>
<script>
async function main() {
// Start loading a sandbox iframe, which is treated as cross-origin iframe.
// The iframe messages us with the value of its document.prerendering,
// which should be false since load is delayed until after activation.
const sandboxIframe = document.createElement('iframe');
sandboxIframe.sandbox = 'allow-scripts';
const gotMessage = new Promise((resolve, reject) => {
window.addEventListener('message', (e) => {
if (e.data === 'document.prerendering: false')
resolve();
else
reject('bad message: ' + e.data);
});
});
sandboxIframe.src = 'post-message-prerendering-completion-notification.html';
document.body.appendChild(sandboxIframe);
// To give the test a chance to fail by giving enough time if it loads the
// cross-origin iframe instead of deferring, wait for a same-origin iframe to
// load before proceeding with the test.
await createFrame('empty.html');
// Start the event collector to trigger activation.
const prerenderEventCollector = new PrerenderEventCollector();
prerenderEventCollector.start(gotMessage, 'iframe loaded');
}
// The main test page (prerender/sandbox-iframe.html) loads the initiator
// page, then the initiator page will prerender itself with the
// `prerendering` parameter.
const params = new URLSearchParams(location.search);
if (!params.has('prerendering')) {
loadInitiatorPage();
} else {
main();
}
</script>
</body>