File: script-html-correctly-labeled.tentative.sub.html

package info (click to toggle)
firefox-esr 78.15.0esr-1~deb11u1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 3,301,156 kB
  • sloc: cpp: 5,665,905; javascript: 4,798,386; ansic: 2,878,233; python: 977,004; asm: 270,347; xml: 181,456; java: 111,756; sh: 72,926; makefile: 21,819; perl: 13,380; cs: 4,725; yacc: 4,565; objc: 3,026; pascal: 1,787; lex: 1,720; ada: 1,681; exp: 505; php: 436; lisp: 260; awk: 152; ruby: 103; csh: 80; sed: 53; sql: 45
file content (30 lines) | stat: -rw-r--r-- 1,210 bytes parent folder | download | duplicates (8)
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
<!DOCTYPE html>
<!-- Test verifies that html fed to a <script> tag won't report a syntax
  error after CORB blocks the response (an empty response body injected
  by CORB won't have any JavaScript syntax errors).
-->
<meta charset="utf-8">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<div id=log></div>
<script>
setup({allow_uncaught_exception : true});
async_test(function(t) {
  var script = document.createElement("script")

  // Without CORB, the html document would cause a syntax error when parsed as
  // JavaScript, but with CORB there should be no errors (because CORB will
  // replace the response body with an empty body).
  script.onload = t.step_func_done(function(){})
  addEventListener("error",function(e) {
    t.step(function() {
      assert_unreached("Empty body of a CORS-blocked response shouldn't trigger syntax errors.");
      t.done();
    })
  });

  // www1 is cross-origin, so the HTTP response is CORB-eligible.
  script.src = 'http://{{domains[www1]}}:{{ports[http][0]}}/fetch/corb/resources/html-correctly-labeled.html';
  document.body.appendChild(script)
}, "CORB-blocked script has no syntax errors");
</script>