summaryrefslogtreecommitdiffstats
path: root/dom/security/test/csp/test_bug1452037.html
blob: fa46e9129168be33e3a462004a72c35d86905e71 (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
<!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>