summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/cross-origin-embedder-policy/cache-storage-reporting-service-worker.https.html
blob: 96a328b2cc1922a45a1ad5e24aee9d79ab1979b3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
<!doctype html>
<html>
<head>
  <title>
    Check COEP report are send for CacheStorage requests in ServiceWorker.
  </title>
  <script src="/resources/testharness.js"></script>
  <script src="/resources/testharnessreport.js"></script>
  <script src="/common/get-host-info.sub.js"></script>
  <script src="/common/utils.js"></script>
  <script src="/service-workers/service-worker/resources/test-helpers.sub.js">
  </script>
  <script src="./resources/cache-storage-reporting.js"></script>
</head>
<script>

promise_test(async (t) => {
  const worker_url = local(encode(worker_path + header_coep));
  // As we don't want the service worker to control any page, generate a
  // one-time scope.
  const SCOPE = new URL(`resources/${token()}.html`, location).pathname;
  const reg =
    await service_worker_unregister_and_register(t, worker_url, SCOPE);
  add_completion_callback(() => reg.unregister());
  const worker = reg.installing || reg.waiting || reg.active;
  const mc = new MessageChannel();
  worker.postMessage({script: eval_script, port: mc.port2}, [mc.port2]);
  const reports = (await new Promise(r => mc.port1.onmessage = r)).data;
  assert_not_equals(reports, 'TIMEOUT');
  assert_equals(reports.length, 1);
  const report = reports[0];
  assert_equals(report.body.blockedURL, image_url);
  assert_equals(report.body.type, "corp");
  assert_equals(report.body.disposition, "enforce");
  assert_equals(report.body.destination, "");
  assert_equals(report.type, "coep");
  assert_equals(report.url, worker_url);
}, "COEP support on ServiceWorker.");

promise_test(async (t) => {
  const worker_url = local(encode(worker_path + header_coep_report_only));
  // As we don't want the service worker to control any page, generate a
  // one-time scope.
  const SCOPE = new URL(`resources/${token()}.html`, location).pathname;
  const reg =
    await service_worker_unregister_and_register(t, worker_url, SCOPE);
  add_completion_callback(() => reg.unregister());
  const worker = reg.installing || reg.waiting || reg.active;
  const mc = new MessageChannel();
  worker.postMessage({script: eval_script, port: mc.port2}, [mc.port2]);
  const reports = (await new Promise(r => mc.port1.onmessage = r)).data;
  assert_not_equals(reports, 'TIMEOUT');
  assert_equals(reports.length, 1);
  const report = reports[0];
  assert_equals(report.body.blockedURL, image_url);
  assert_equals(report.body.type, "corp");
  assert_equals(report.body.disposition, "reporting");
  assert_equals(report.body.destination, "");
  assert_equals(report.type, "coep");
  assert_equals(report.url, worker_url);
}, "COEP-Report-Only support on ServiceWorker.");

</script>
</html>