File: bare.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 (70 lines) | stat: -rw-r--r-- 2,273 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
<!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/bare": "./resources/log.js?pipe=sub&name=bare",
    "bare/cross-origin-bare": "https://{{domains[www1]}}:{{ports[https][0]}}/import-maps/resources/log.js?pipe=sub&name=cross-origin-bare",
    "bare/to-data": "data:text/javascript,log.push('dataURL')",

    "bare/std-blank": "std:blank",
    "bare/blank": "@std/blank",
    "bare/std-none": "std:none",
    "bare/none": "@std/none",

    "bare/to-bare": "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

  // Bare to HTTP(S).
  "bare/bare":
    [Result.URL, Result.URL, "log:bare", "log:bare"],
  "bare/cross-origin-bare":
    [Result.URL, Result.URL, "log:cross-origin-bare", "log:cross-origin-bare"],

  // Bare to data:
  "bare/to-data":
    [Result.URL, Result.URL, "dataURL", "dataURL"],

  // Bare to built-in.
  "bare/std-blank":
    [Result.URL, Result.URL, Result.BUILTIN, Result.BUILTIN],
  "bare/blank":
    [Result.URL, Result.URL, Result.BUILTIN, Result.BUILTIN],
  "bare/std-none":
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],
  "bare/none":
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],

  // Bare to bare mapping is disabled.
  "bare/to-bare":
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],
};

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