author Hiroshige Hayashizaki <hiroshige@chromium.org>
Tue, 05 Mar 2019 11:11:07 +0000
changeset 522132 793206aecd5e7cdc78e5e0dd1ea097f81608f466
permissions -rw-r--r--
Bug 1527643 [wpt PR 15197] - Add tentative WPT tests for Built-in Module Infra and Import Maps, a=testonly Automatic update from web-platform-tests Add tentative WPT tests for Built-in Module Infra and Import Maps Bug: 848607, 927477, 928435 Change-Id: Id0573736a762c26df28f32da0716d94a566cfce3 Reviewed-on: https://chromium-review.googlesource.com/c/1449072 Commit-Queue: Hiroshige Hayashizaki <hiroshige@chromium.org> Reviewed-by: Kouhei Ueno <kouhei@chromium.org> Cr-Commit-Position: refs/heads/master@{#631546} -- wpt-commits: 896ca12d8a73e7679ef3a4c7402301a5603b5faa wpt-pr: 15197

<!DOCTYPE html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/test-helper.js"></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).
    [Result.URL, Result.URL, "log:bare", "log:bare"],
    [Result.URL, Result.URL, "log:cross-origin-bare", "log:cross-origin-bare"],

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

  // Bare to built-in.
    [Result.URL, Result.URL, Result.BUILTIN, Result.BUILTIN],
    [Result.URL, Result.URL, Result.BUILTIN, Result.BUILTIN],
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],

  // Bare to bare mapping is disabled.
    [Result.URL, Result.URL, Result.PARSE_ERROR, Result.PARSE_ERROR],

doTests(importMap, null, tests);