File: coop-csp-sandbox-navigate.https.html

package info (click to toggle)
firefox 145.0.1-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,653,528 kB
  • sloc: cpp: 7,594,999; javascript: 6,459,658; ansic: 3,752,909; python: 1,403,455; xml: 629,809; asm: 438,679; java: 186,421; sh: 67,287; makefile: 19,169; objc: 13,086; perl: 12,982; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (40 lines) | stat: -rw-r--r-- 1,918 bytes parent folder | download | duplicates (18)
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
<!doctype html>
<title>CSP sandbox popup navigate to Cross-Origin-Opener-Policy document should work</title>
<meta name="timeout" content="long">
<script src=/resources/testharness.js></script>
<script src=/resources/testharnessreport.js></script>
<script src="/common/utils.js"></script> <!-- Use token() to allow running tests in parallel -->
<div id=log>
<script>
[
  "allow-popups allow-scripts allow-same-origin",
  "allow-popups allow-scripts",
].forEach(sandboxValue => {
  async_test(t => {
    const channel = new BroadcastChannel(token());
    let popup;
    channel.onmessage = t.step_func_done(e => {
      assert_equals(e.data.name, '', 'e.data.name');
      assert_false(e.data.opener, 'e.data.opener');
      // `popup` is still the WindowProxy that holds the CSP sandbox document, not the
      // after-navigation COOP document. The CSP sandbox only applies to the before navigation
      // document/window.
      assert_true(popup.closed, 'popup.closed');
      // Same-origin check (with the CSP sandbox document) should not throw when 'allow-same-origin'
      if (sandboxValue.includes('allow-same-origin')) {
        assert_true(!!popup.document, 'same-origin check');
      } else {
        assert_throws_dom("SecurityError", () => { popup.document; }, 'same-origin check');
      }
    });
    const navigateTo = `/html/cross-origin-opener-policy/resources/coop-coep.py?coop=same-origin&coep=&channel=${channel.name}`;
    popup = window.open(`resources/csp-sandbox.py?coop=&coep=&sandbox=${sandboxValue}&channel=&navigate=${encodeURIComponent(navigateTo)}`, sandboxValue.replace(/ /g, '_'));
    t.add_cleanup(() => { popup.close(); });
    addEventListener('load', t.step_func(() => {
      t.step_timeout(() => {
        assert_unreached('Navigation from CSP sandbox to COOP document failed')
      }, 10000);
    }));
  }, `CSP: sandbox ${sandboxValue}; ${document.title}`);
});
</script>