tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

restriction-background-fetch.https.html (2667B)


      1 <!DOCTYPE html>
      2 <title>Access to the Background Fetch API is deferred</title>
      3 <meta name="variant" content="?target_hint=_self">
      4 <meta name="variant" content="?target_hint=_blank">
      5 <meta name="timeout" content="long">
      6 <script src="/resources/testharness.js"></script>
      7 <script src="/resources/testharnessreport.js"></script>
      8 <script src="/resources/testdriver.js"></script>
      9 <script src="/resources/testdriver-vendor.js"></script>
     10 <script src="/common/utils.js"></script>
     11 <script src="/service-workers/service-worker/resources/test-helpers.sub.js"></script>
     12 <script src="../resources/utils.js"></script>
     13 <script src="resources/utils.js"></script>
     14 
     15 <body>
     16 <script>
     17 setup(() => assertSpeculationRulesIsSupported());
     18 
     19 promise_test(async t => {
     20  const uid = token();
     21  const bc = new PrerenderChannel('test-channel', uid);
     22  t.add_cleanup(_ => bc.close());
     23 
     24  // We grant the permission here to make a more discerning test because
     25  // backgroundFetch.fetch() waits until the permission is granted, which
     26  // is deferred during prerendering so the test would trivially pass without
     27  // the permission.
     28  await test_driver.set_permission({ name: "background-fetch" }, "granted");
     29 
     30  const gotMessage = new Promise(resolve => {
     31    bc.addEventListener('message', e => {
     32      resolve(e.data);
     33    }, {
     34      once: true
     35    });
     36  });
     37 
     38  // Install the service worker first to test backgroundFetch.fetch in the
     39  // prerendering page.
     40  const scope = 'resources/';
     41  const script = 'resources/do-nothing-worker.js';
     42  const registration =
     43      await service_worker_unregister_and_register(t, script, scope);
     44  t.add_cleanup(() => registration.unregister());
     45  await wait_for_state(t, registration.installing, 'activated');
     46 
     47  const url = `resources/background-fetch.https.html?uid=${uid}&target_hint=${getTargetHint()}`;
     48  window.open(url, '_blank', 'noopener');
     49 
     50  const result = await gotMessage;
     51  const expected = [
     52    {event: 'started waiting backgroundFetch.fetch',    prerendering: true},
     53    {event: 'prerendering change',                      prerendering: false},
     54    {event: 'finished waiting backgroundFetch.fetch',   prerendering: false},
     55  ];
     56  assert_equals(result.length, expected.length);
     57  for (let i = 0; i < result.length; i++) {
     58    assert_equals(result[i].event, expected[i].event, `event[${i}]`);
     59    assert_equals(result[i].prerendering, expected[i].prerendering,
     60      `prerendering[${i}]`);
     61  }
     62 
     63  // Send a close signal to PrerenderEventCollector on the prerendered page.
     64  new PrerenderChannel('close', uid).postMessage('');
     65 }, `The access to the Background Fetch API should be deferred until the
     66    prerendered page is activated`);
     67 </script>