summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/cookie-store/cookieStore_special_names.https.any.js
blob: 6b18c4f0668a4dfad5864273082bc1ae7ba6ca95 (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
// META: title=Cookie Store API: cookieStore.set()/get()/delete() for cookies with special names
// META: global=window,serviceworker

'use strict';

['__Secure-', '__Host-'].forEach(prefix => {
  promise_test(async testCase => {
    await cookieStore.set(`${prefix}cookie-name`, `secure-cookie-value`);
    assert_equals(
      (await cookieStore.get(`${prefix}cookie-name`)).value,
      'secure-cookie-value',
      `Setting ${prefix} cookies should not fail in secure context`);

    try { await cookieStore.delete(`${prefix}cookie-name`); } catch (e) {}
  }, `cookieStore.set with ${prefix} name on secure origin`);

  promise_test(async testCase => {
    // This test is for symmetry with the non-secure case. In non-secure
    // contexts, the set() should fail even if the expiration date makes
    // the operation a no-op.
    await cookieStore.set(
        { name: `${prefix}cookie-name`, value: `secure-cookie-value`,
          expires: Date.now() - (24 * 60 * 60 * 1000)});
    assert_equals(await cookieStore.get(`${prefix}cookie-name`), null);
    try { await cookieStore.delete(`${prefix}cookie-name`); } catch (e) {}
  }, `cookieStore.set of expired ${prefix} cookie name on secure origin`);

  promise_test(async testCase => {
    assert_equals(
      await cookieStore.delete(`${prefix}cookie-name`), undefined,
      `Deleting ${prefix} cookies should not fail in secure context`);
  }, `cookieStore.delete with ${prefix} name on secure origin`);
});

promise_test(async testCase => {
  const currentUrl = new URL(self.location.href);
  const currentDomain = currentUrl.hostname;
  await promise_rejects_js(testCase, TypeError,
      cookieStore.set({ name: '__Host-cookie-name', value: 'cookie-value',
                        domain: currentDomain }));
}, 'cookieStore.set with __Host- prefix and a domain option');

promise_test(async testCase => {
  await cookieStore.set({ name: '__Host-cookie-name', value: 'cookie-value',
                          path: "/" });

  assert_equals(
      (await cookieStore.get(`__Host-cookie-name`)).value, "cookie-value");

  await promise_rejects_js(testCase, TypeError,
      cookieStore.set( { name: '__Host-cookie-name', value: 'cookie-value',
                         path: "/path" }));
}, 'cookieStore.set with __Host- prefix a path option');

promise_test(async testCase => {
    let exceptionThrown = false;
    try {
        await cookieStore.set(unescape('cookie-name%0D1'), 'cookie-value');
    } catch (e) {
        assert_equals (e.name, "TypeError", "cookieStore thrown an incorrect exception -");
        exceptionThrown = true;
    }
    assert_true(exceptionThrown, "No exception thrown.");
}, 'cookieStore.set with malformed name.');