chromium/third_party/blink/web_tests/http/tests/inspector-protocol/fetch-later/activate-and-redirect-when-document-alive.https.js

(async function(/** @type {import('test_runner').TestRunner} */ testRunner) {
  const {_, session, dp} = await testRunner.startBlank(
      'Tests that appropriate Network domain events are dispatched during a fetchLater request following redirects.');

  dp.Page.enable();
  dp.Page.reload();
  await dp.Page.onceLoadEventFired();

  const gatherNetworkEvents =
      await testRunner.loadScript('resources/gather-network-events.js');
  const events = gatherNetworkEvents(
      testRunner, dp, {requests: 1, log: true, expectedRedirect: true});

  await session.evaluateAsync(async () => {
    const redirectDestination = '/resources/blank.html';
    const url = `/resources/redirect.php?url=${
        encodeURIComponent(redirectDestination)}`;

    function waitForActivated(fetchLaterResult) {
      function waitFor(result) {
        if (result && result.activated) {
          return result;
        }
        return new Promise(resolve => setTimeout(resolve, 100))
            .then(() => waitFor(fetchLaterResult));
      }
      return waitFor();
    }
    return waitForActivated(fetchLater(url, {activateAfter: 0}));
  });

  const requestId = (await events)
                        .find(event => event.params.type === 'Fetch')
                        ?.params.requestId;
  const msg = await dp.Network.getResponseBody({requestId: requestId});
  if (msg.error) {
    testRunner.log(msg.error, 'Unable to get fetchLater response body');
  } else {
    testRunner.log(msg.result, 'fetchLater response body');
  }

  testRunner.completeTest();
})