File: test_bug1452037.html

package info (click to toggle)
firefox 149.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,767,760 kB
  • sloc: cpp: 7,416,064; javascript: 6,752,859; ansic: 3,774,850; python: 1,250,473; xml: 641,578; asm: 439,191; java: 186,617; sh: 56,634; makefile: 18,856; objc: 13,092; perl: 12,763; pascal: 5,960; yacc: 4,583; cs: 3,846; lex: 1,720; ruby: 1,002; php: 436; lisp: 258; awk: 105; sql: 66; sed: 53; csh: 10; exp: 6
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>