File: sandbox-new-execution-context.html

package info (click to toggle)
thunderbird 1%3A128.14.0esr-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 4,334,824 kB
  • sloc: cpp: 7,391,917; javascript: 5,617,271; ansic: 3,833,216; python: 1,230,742; xml: 619,690; asm: 456,022; java: 179,892; sh: 118,796; makefile: 21,908; perl: 14,825; objc: 12,399; yacc: 4,583; pascal: 2,973; lex: 1,720; ruby: 1,190; exp: 762; sql: 674; awk: 580; php: 436; lisp: 430; sed: 70; csh: 10
file content (39 lines) | stat: -rw-r--r-- 1,703 bytes parent folder | download | duplicates (23)
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
<!doctype html>
<html>
  <head>
    <title>Reuse of iframe about:blank document execution context</title>
    <link rel="author" title="Dan Clark" href="mailto:daniec@microsoft.com">
    <link rel="help" href="http://www.w3.org/html/wg/drafts/html/master/browsers.html#sandboxing">
    <script src="/resources/testharness.js"></script>
    <script src="/resources/testharnessreport.js"></script>
  </head>

  <body>
    <h1>Reuse of iframe about:blank document execution context in sandbox="allow-scripts" iframe</h1>
    <script type="text/javascript">
      async_test(t => {
        let iframe = document.createElement("iframe");
        document.body.appendChild(iframe);

        let iframeAboutBlankDocument = iframe.contentDocument;
        assert_equals(iframeAboutBlankDocument.URL, "about:blank");

        iframe.sandbox = "allow-scripts";
        iframe.src = './sandbox-new-execution-context-iframe.html';

        iframe.onload = t.step_func_done(() => {
          assert_equals(iframe.contentDocument, null,
            "New document in sandboxed iframe should have opaque origin");

          assert_equals(Object.getPrototypeOf(iframeAboutBlankDocument).changeFromSandboxedIframe, undefined,
            "Sandboxed iframe contents should not have been able to mess with type system of about:blank document");

          let iframeAboutBlankContents = iframeAboutBlankDocument.querySelectorAll('body');
          assert_equals(iframeAboutBlankContents[0].tagName, "BODY",
            "about:blank document's contents should still be accessible");
        });
      },"iframe with sandbox should load with new execution context");
    </script>
    <div id="log"></div>
  </body>
</html>