summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNayeem Rahman <nayeemrmn99@gmail.com>2020-06-26 13:34:17 +0100
committerGitHub <noreply@github.com>2020-06-26 08:34:17 -0400
commited0b1d462718166143b67056c36c7db15cc736d7 (patch)
tree9151555dc8fe7e547e415a185e25a13de11c7b98
parent175867ab763a96f591b65386f09a385b87b399ab (diff)
fix(cli/js/web/url): Support UNC paths on Windows (#6418)
-rw-r--r--cli/js/web/url.ts11
-rw-r--r--cli/tests/unit/url_test.ts15
-rw-r--r--std/path/from_file_url_test.ts60
3 files changed, 53 insertions, 33 deletions
diff --git a/cli/js/web/url.ts b/cli/js/web/url.ts
index 76aa21919..60690d46a 100644
--- a/cli/js/web/url.ts
+++ b/cli/js/web/url.ts
@@ -62,12 +62,15 @@ function parse(url: string, isBase = true): URLParts | undefined {
parts.password = "";
[parts.hostname, restUrl] = takePattern(restUrl, /^[/\\]{2}([^/\\?#]*)/);
parts.port = "";
+ if (build.os == "windows" && parts.hostname == "") {
+ // UNC paths. e.g. "\\\\localhost\\foo\\bar" on Windows should be
+ // representable as `new URL("file:////localhost/foo/bar")` which is
+ // equivalent to: `new URL("file://localhost/foo/bar")`.
+ [parts.hostname, restUrl] = takePattern(restUrl, /^[/\\]{2,}([^/\\?#]*)/);
+ }
} else if (specialSchemes.includes(parts.protocol)) {
let restAuthority;
- [restAuthority, restUrl] = takePattern(
- restUrl,
- /^[/\\]{2}[/\\]*([^/\\?#]+)/
- );
+ [restAuthority, restUrl] = takePattern(restUrl, /^[/\\]{2,}([^/\\?#]+)/);
if (isBase && restAuthority == "") {
return undefined;
}
diff --git a/cli/tests/unit/url_test.ts b/cli/tests/unit/url_test.ts
index b4c31ea6d..d22787f1c 100644
--- a/cli/tests/unit/url_test.ts
+++ b/cli/tests/unit/url_test.ts
@@ -191,6 +191,21 @@ unitTest(function urlDriveLetter() {
assertEquals(new URL("http://example.com/C:").href, "http://example.com/C:");
});
+unitTest(function urlUncHostname() {
+ assertEquals(
+ new URL("file:////").href,
+ Deno.build.os == "windows" ? "file:///" : "file:////"
+ );
+ assertEquals(
+ new URL("file:////server").href,
+ Deno.build.os == "windows" ? "file://server/" : "file:////server"
+ );
+ assertEquals(
+ new URL("file:////server/file").href,
+ Deno.build.os == "windows" ? "file://server/file" : "file:////server/file"
+ );
+});
+
unitTest(function urlHostnameUpperCase() {
assertEquals(new URL("https://EXAMPLE.COM").href, "https://example.com/");
});
diff --git a/std/path/from_file_url_test.ts b/std/path/from_file_url_test.ts
index b3f2bb6c6..8bbc4e986 100644
--- a/std/path/from_file_url_test.ts
+++ b/std/path/from_file_url_test.ts
@@ -1,37 +1,39 @@
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
-import * as path from "./mod.ts";
+import { posix, win32 } from "./mod.ts";
import { assertEquals } from "../testing/asserts.ts";
Deno.test("[path] fromFileUrl", function () {
- assertEquals(
- path.posix.fromFileUrl(new URL("file:///home/foo")),
- "/home/foo"
- );
- assertEquals(path.posix.fromFileUrl("file:///home/foo"), "/home/foo");
- assertEquals(path.posix.fromFileUrl("https://example.com/foo"), "/foo");
- assertEquals(path.posix.fromFileUrl("file:///"), "/");
+ assertEquals(posix.fromFileUrl(new URL("file:///home/foo")), "/home/foo");
+ assertEquals(posix.fromFileUrl("file:///home/foo"), "/home/foo");
+ assertEquals(posix.fromFileUrl("https://example.com/foo"), "/foo");
+ assertEquals(posix.fromFileUrl("file:///"), "/");
+ // FIXME(nayeemrmn): Remove the condition. UNC paths are supported here when
+ // run on Windows (matching the underlying URL class), but
+ // `posix.fromFileUrl()` should not support them under any circumstance.
+ if (Deno.build.os != "windows") {
+ assertEquals(posix.fromFileUrl("file:////"), "//");
+ assertEquals(posix.fromFileUrl("file:////server"), "//server");
+ assertEquals(posix.fromFileUrl("file:////server/file"), "//server/file");
+ }
});
Deno.test("[path] fromFileUrl (win32)", function () {
- assertEquals(
- path.win32.fromFileUrl(new URL("file:///home/foo")),
- "\\home\\foo"
- );
- assertEquals(path.win32.fromFileUrl("file:///home/foo"), "\\home\\foo");
- assertEquals(path.win32.fromFileUrl("https://example.com/foo"), "\\foo");
- assertEquals(path.win32.fromFileUrl("file:///"), "\\");
- // FIXME(nayeemrmn): Support UNC paths. Needs support in the underlying URL
- // built-in like Chrome has.
- // assertEquals(path.win32.fromFileUrl("file:////"), "\\");
- // assertEquals(path.win32.fromFileUrl("file:////server"), "\\");
- // assertEquals(path.win32.fromFileUrl("file:////server/file"), "\\file");
- assertEquals(path.win32.fromFileUrl("file:///c"), "\\c");
- assertEquals(path.win32.fromFileUrl("file:///c:"), "c:\\");
- assertEquals(path.win32.fromFileUrl("file:///c:/"), "c:\\");
- assertEquals(path.win32.fromFileUrl("file:///C:/"), "C:\\");
- assertEquals(path.win32.fromFileUrl("file:///C:/Users/"), "C:\\Users\\");
- assertEquals(
- path.win32.fromFileUrl("file:///C:cwd/another"),
- "\\C:cwd\\another"
- );
+ assertEquals(win32.fromFileUrl(new URL("file:///home/foo")), "\\home\\foo");
+ assertEquals(win32.fromFileUrl("file:///home/foo"), "\\home\\foo");
+ assertEquals(win32.fromFileUrl("https://example.com/foo"), "\\foo");
+ assertEquals(win32.fromFileUrl("file:///"), "\\");
+ // FIXME(nayeemrmn): Remove the condition. UNC paths are only supported here
+ // when run on Windows (matching the underlying URL class), but
+ // `win32.fromFileUrl()` should support them under every circumstance.
+ if (Deno.build.os == "windows") {
+ assertEquals(win32.fromFileUrl("file:////"), "\\");
+ assertEquals(win32.fromFileUrl("file:////server"), "\\");
+ assertEquals(win32.fromFileUrl("file:////server/file"), "\\file");
+ }
+ assertEquals(win32.fromFileUrl("file:///c"), "\\c");
+ assertEquals(win32.fromFileUrl("file:///c:"), "c:\\");
+ assertEquals(win32.fromFileUrl("file:///c:/"), "c:\\");
+ assertEquals(win32.fromFileUrl("file:///C:/"), "C:\\");
+ assertEquals(win32.fromFileUrl("file:///C:/Users/"), "C:\\Users\\");
+ assertEquals(win32.fromFileUrl("file:///C:cwd/another"), "\\C:cwd\\another");
});