File: test_bug1452037.html

package info (click to toggle)
firefox-esr 128.14.0esr-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 4,230,248 kB
  • sloc: cpp: 7,104,262; javascript: 6,088,450; ansic: 3,654,017; python: 1,212,326; xml: 594,604; asm: 420,654; java: 182,969; sh: 71,124; makefile: 20,739; perl: 13,449; objc: 12,399; yacc: 4,583; cs: 3,846; pascal: 2,973; lex: 1,720; ruby: 1,194; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (41 lines) | stat: -rw-r--r-- 1,229 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
41
<!DOCTYPE HTML>
<html>
<head>
  <title>Test if "script-src: sha-... " Allowlists "javascript:" URIs</title>
  <!-- Including SimpleTest.js so we can use waitForExplicitFinish !-->
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body>
    <iframe></iframe>

<script class="testbody">
      SimpleTest.requestCompleteLog();
      SimpleTest.waitForExplicitFinish();

      let frame = document.querySelector("iframe");

      window.addEventListener("message", (msg) => {
        ok(false, "The CSP did not block javascript:uri");
        SimpleTest.finish();
      });

      document.addEventListener("securitypolicyviolation", () => {
        ok(true, "The CSP did block javascript:uri");
        SimpleTest.finish();
      });

      frame.addEventListener("load", () => {
        let link = frame.contentWindow.document.querySelector("a");
        frame.contentWindow.document.addEventListener("securitypolicyviolation", () => {
          ok(true, "The CSP did block javascript:uri");
          SimpleTest.finish();
        })
        link.click();
      });
      frame.src = "file_bug1452037.html";


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