Source code
Revision control
Copy as Markdown
Other Tools
<!DOCTYPE html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/speculation-rules/prerender/resources/utils.js"></script>
<script>
function runAlertTest() {
  window.alert('Hello! Preprendering!');
  return 'no block';
}
function runConfirmTest() {
  const result = window.confirm('Are you preprendering page?');
  return 'the return value is ' + (result === true ? 'yes' : 'no');
}
function runPromptTest() {
  const result = window.prompt('Are you preprendering page?',
    'the default value');
  return 'the return value is ' + (result === null ? 'null' : result);
}
const params = new URLSearchParams(location.search);
const uid = params.get('uid');
// The main test page (restriction-message-boxes.html) loads the
// initiator page, then the initiator page will prerender itself with the
// `prerendering` parameter.
const isPrerendering = params.has('prerendering');
if (isPrerendering) {
  // Test web APIs on the pages.
  const bc = new PrerenderChannel('prerender-channel', uid);
  assert_true(document.prerendering);
  if (params.has('alert')) {
    bc.postMessage(runAlertTest());
  } else if (params.has('confirm')) {
    bc.postMessage(runConfirmTest());
  } else if (params.has('prompt')) {
    bc.postMessage(runPromptTest());
  }
  bc.close();
  window.close();
} else {
  // Initiator pages should prerender the prerendering page.
  const url = new URL(document.URL);
  url.searchParams.append('prerendering', '');
  startPrerendering(url);
}
</script>