summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/service-workers/service-worker/resources/partitioned-cookies-3p-credentialless-frame.html
blob: 25ddf601457c484160490a267cd8053f84c01063 (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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<!DOCTYPE html>
<head>
<meta charset="utf-8"/>
<meta name="timeout" content="long">
<title>Service Worker: Partitioned Cookies 3P Credentialless Iframe</title>
<script src="/resources/testharness.js"></script>
<script src="test-helpers.sub.js"></script>
<script src="/common/get-host-info.sub.js"></script>
</head>

<body>
<script>

// Check workers registered by a credentialless frame can access cookies set in that frame.
promise_test(async t => {
  const script = './partitioned-cookies-3p-sw.js';
  const scope = './partitioned-cookies-3p-';
  const absolute_scope = new URL(scope, window.location).href;

  // Set a Partitioned cookie.
  document.cookie = '__Host-partitioned=123; Secure; Path=/; SameSite=None; Partitioned;';
  assert_true(document.cookie.includes('__Host-partitioned=123'));

  // Make sure DOM cannot access the unpartitioned cookie.
  assert_false(document.cookie.includes('unpartitioned=456'));

  const reg = await service_worker_unregister_and_register(t, script, scope);
  await wait_for_state(t, reg.installing, 'activated');

  let retrieved_registrations =
        await navigator.serviceWorker.getRegistrations();
  let filtered_registrations =
      retrieved_registrations.filter(reg => reg.scope == absolute_scope);

  // on_message will be reassigned below based on the expected reply from the service worker.
  let on_message;
  self.addEventListener('message', ev => on_message(ev));
  navigator.serviceWorker.addEventListener('message', evt => {
    self.postMessage(evt.data, '*');
  });

  // First test that the worker script started correctly and message passing is enabled.
  let resolve_wait_promise;
  let wait_promise = new Promise(resolve => {
    resolve_wait_promise = resolve;
  });
  let got;
  on_message = ev => {
    got = ev.data;
    resolve_wait_promise();
  };
  filtered_registrations[0].active.postMessage({type: 'test_message'});
  await wait_promise;
  assert_true(got.ok, 'Message passing');

  // Test that the partitioned cookie is available to this worker via CookieStore API.
  wait_promise = new Promise(resolve => {
    resolve_wait_promise = resolve;
  });
  on_message = ev => {
    got = ev.data;
    resolve_wait_promise();
  };
  filtered_registrations[0].active.postMessage({type: 'echo_cookies_js'});
  await wait_promise;
  assert_true(got.ok, 'Get cookies');
  assert_true(
      got.cookies.includes('__Host-partitioned'),
      'Credentialless frame worker can access partitioned cookie via JS');
  assert_false(
      got.cookies.includes('unpartitioned'),
      'Credentialless frame worker cannot access unpartitioned cookie via JS');

  // Test that the partitioned cookie is available to this worker via HTTP.
  wait_promise = new Promise(resolve => {
    resolve_wait_promise = resolve;
  });
  on_message = ev => {
    got = ev.data;
    resolve_wait_promise();
  };
  filtered_registrations[0].active.postMessage({ type: 'echo_cookies_http' });
  await wait_promise;
  assert_true(got.ok, 'Get cookies');
  assert_true(
      got.cookies.includes('__Host-partitioned'),
      'Credentialless frame worker can access partitioned cookie via HTTP');
  assert_false(
      got.cookies.includes('unpartitioned'),
      'Credentialless frame worker cannot access unpartitioned cookie via HTTP');

  // Test that the partitioned cookie is not available to this worker in HTTP
  // requests from importScripts.
  wait_promise = new Promise(resolve => {
    resolve_wait_promise = resolve;
  });
  on_message = ev => {
    got = ev.data;
    resolve_wait_promise();
  };
  filtered_registrations[0].active.postMessage({ type: 'echo_cookies_import' });
  await wait_promise;
  assert_true(got.ok, 'Get cookies');
  assert_true(
      got.cookies.includes('__Host-partitioned'),
      'Credentialless frame worker can access partitioned cookie via importScripts');
  assert_false(
      got.cookies.includes('unpartitioned'),
      'Credentialless frame worker cannot access unpartitioned cookie via importScripts');
});

</script>
</body>
</html>