File: data.sub.tentative.html

package info (click to toggle)
firefox-esr 68.10.0esr-1~deb9u1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 3,143,932 kB
  • sloc: cpp: 5,227,879; javascript: 4,315,531; ansic: 2,467,042; python: 794,975; java: 349,993; asm: 232,034; xml: 228,320; sh: 82,008; lisp: 41,202; makefile: 22,347; perl: 15,555; objc: 5,277; cs: 4,725; yacc: 1,778; ada: 1,681; pascal: 1,673; lex: 1,417; exp: 527; php: 436; ruby: 225; awk: 162; sed: 53; csh: 44
file content (72 lines) | stat: -rw-r--r-- 2,844 bytes parent folder | download | duplicates (2)
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<!DOCTYPE html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/test-helper.js"></script>

<script>
// "bare/..." (i.e. without leading "./") are bare specifiers
// (not relative paths).
//
// Discussions about notations for builtin modules are ongoing, e.g.
// https://github.com/tc39/proposal-javascript-standard-library/issues/12
// Currently the tests expects two notations are accepted.
// TODO: Once the discussions converge, update the tests.
const importMap = `
{
  "imports": {
    "bare": "./resources/log.js?pipe=sub&name=bare",

    "data:text/javascript,log.push('data:foo')": "./resources/log.js?pipe=sub&name=foo",
    "data:text/javascript,log.push('data:cross-origin-foo')": "https://{{domains[www1]}}:{{ports[https][0]}}/import-maps/resources/log.js?pipe=sub&name=cross-origin-foo",
    "data:text/javascript,log.push('data:to-data')": "data:text/javascript,log.push('dataURL')",

    "data:text/javascript,log.push('data:std-blank')": "std:blank",
    "data:text/javascript,log.push('data:blank')": "@std/blank",
    "data:text/javascript,log.push('data:std-none')": "std:none",
    "data:text/javascript,log.push('data:none')": "@std/none",

    "data:text/javascript,log.push('data:to-bare')": "bare"
  }
}
`;

const tests = {
  // Arrays of expected results for:
  // - <script src type="module">,
  // - <script src> (classic script),
  // - static import, and
  // - dynamic import.

  // Currently, Chromium's implementation resolves import maps as a part of
  // specifier resolution, and thus failure in import map resolution causes
  // a parse error, not fetch error. Therefore, we use Result.PARSE_ERROR
  // below. https://crbug.com/928435

  // data: to HTTP(S).
  "data:text/javascript,log.push('data:foo')":
    [Result.URL, Result.URL, "log:foo", "log:foo"],
  "data:text/javascript,log.push('data:cross-origin-foo')":
    [Result.URL, Result.URL, "log:cross-origin-foo", "log:cross-origin-foo"],

  // data: to data:
  "data:text/javascript,log.push('data:to-data')":
    [Result.URL, Result.URL, "dataURL", "dataURL"],

  // data: to built-in.
  "data:text/javascript,log.push('data:std-blank')":
    [Result.URL, Result.URL, Result.BUILTIN, Result.BUILTIN],
  "data:text/javascript,log.push('data:blank')":
    [Result.URL, Result.URL, Result.BUILTIN, Result.BUILTIN],
  "data:text/javascript,log.push('data:std-none')":
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],
  "data:text/javascript,log.push('data:none')":
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],

  // data: to bare mapping is disabled.
  "data:text/javascript,log.push('data:to-bare')":
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],
};

doTests(importMap, null, tests);
</script>
<body>