aboutsummaryrefslogtreecommitdiff
path: root/test/cli/install
diff options
context:
space:
mode:
authorGravatar Jarred Sumner <jarred@jarredsumner.com> 2023-09-18 23:27:02 -0700
committerGravatar GitHub <noreply@github.com> 2023-09-18 23:27:02 -0700
commitcc54b62fac41c0977c7dfc4c6ba550a6408fa15f (patch)
treecf8f61c2dd1fa778e304c54e7fd92e4bece15268 /test/cli/install
parent9d3f60d44ed90bcb581b590067b42d92e7cdecad (diff)
downloadbun-cc54b62fac41c0977c7dfc4c6ba550a6408fa15f.tar.gz
bun-cc54b62fac41c0977c7dfc4c6ba550a6408fa15f.tar.zst
bun-cc54b62fac41c0977c7dfc4c6ba550a6408fa15f.zip
Encode slashes in package names in the registry manifest request (#5716)
* Encode slashes in package names in the registry manifest request Co-Authored-By: Max Brosnahan <1177034+gingermusketeer@users.noreply.github.com> * Update dummy.registry.ts * Fix tests * Add guide for Azure Artifacts * Update azure-artifacts.md * Update azure-artifacts.md * Typo --------- Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> Co-authored-by: Max Brosnahan <1177034+gingermusketeer@users.noreply.github.com>
Diffstat (limited to 'test/cli/install')
-rw-r--r--test/cli/install/bun-add.test.ts4
-rw-r--r--test/cli/install/bun-install.test.ts10
-rw-r--r--test/cli/install/bun-update.test.ts4
-rw-r--r--test/cli/install/dummy.registry.ts11
4 files changed, 16 insertions, 13 deletions
diff --git a/test/cli/install/bun-add.test.ts b/test/cli/install/bun-add.test.ts
index 4461584e4..c00c0ba7b 100644
--- a/test/cli/install/bun-add.test.ts
+++ b/test/cli/install/bun-add.test.ts
@@ -232,11 +232,11 @@ it("should handle @scoped names", async () => {
});
expect(stderr).toBeDefined();
const err = await new Response(stderr).text();
- expect(err.split(/\r?\n/)).toContain('error: package "@bar/baz" not found localhost/@bar/baz 404');
+ expect(err.split(/\r?\n/)).toContain('error: package "@bar/baz" not found localhost/@bar%2fbaz 404');
expect(stdout).toBeDefined();
expect(await new Response(stdout).text()).toBe("");
expect(await exited).toBe(1);
- expect(urls.sort()).toEqual([`${root_url}/@bar/baz`]);
+ expect(urls.sort()).toEqual([`${root_url}/@bar%2fbaz`]);
expect(requested).toBe(1);
try {
await access(join(package_dir, "bun.lockb"));
diff --git a/test/cli/install/bun-install.test.ts b/test/cli/install/bun-install.test.ts
index c4accb1b4..25cd0aca7 100644
--- a/test/cli/install/bun-install.test.ts
+++ b/test/cli/install/bun-install.test.ts
@@ -39,7 +39,7 @@ it("should report connection errors", async () => {
`
[install]
cache = false
-registry = "http://localhost:${server.port}/"
+registry = "http://${server.hostname}:${server.port}/"
`,
);
await writeFile(
@@ -62,7 +62,7 @@ registry = "http://localhost:${server.port}/"
});
expect(stderr).toBeDefined();
const err = await new Response(stderr).text();
- expect(err.split(/\r?\n/)).toContain("error: ConnectionClosed downloading package manifest bar");
+ expect(err.split(/\r?\n/)).toContain("error: ConnectionRefused downloading package manifest bar");
expect(stdout).toBeDefined();
expect(await new Response(stdout).text()).toBeEmpty();
expect(await exited).toBe(1);
@@ -112,7 +112,7 @@ it("should handle missing package", async () => {
it("should handle @scoped authentication", async () => {
let seen_token = false;
- const url = `${root_url}/@foo/bar`;
+ const url = `${root_url}/@foo%2fbar`;
const urls: string[] = [];
setHandler(async request => {
expect(request.method).toBe("GET");
@@ -2197,7 +2197,7 @@ it("should handle unscoped alias on scoped dependency", async () => {
" 1 packages installed",
]);
expect(await exited).toBe(0);
- expect(urls.sort()).toEqual([`${root_url}/@barn/moo`, `${root_url}/@barn/moo-0.1.0.tgz`]);
+ expect(urls.sort()).toEqual([`${root_url}/@barn%2fmoo`, `${root_url}/@barn/moo-0.1.0.tgz`]);
expect(requested).toBe(2);
expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".cache", "@barn", "moo"]);
expect(await readdirSorted(join(package_dir, "node_modules", "@barn"))).toEqual(["moo"]);
@@ -2327,7 +2327,7 @@ it("should handle aliased dependency with existing lockfile", async () => {
]);
expect(await exited1).toBe(0);
expect(urls.sort()).toEqual([
- `${root_url}/@barn/moo`,
+ `${root_url}/@barn%2fmoo`,
`${root_url}/@barn/moo-0.1.0.tgz`,
`${root_url}/bar`,
`${root_url}/bar-0.0.2.tgz`,
diff --git a/test/cli/install/bun-update.test.ts b/test/cli/install/bun-update.test.ts
index 2a6ee4eaf..ff8e22c37 100644
--- a/test/cli/install/bun-update.test.ts
+++ b/test/cli/install/bun-update.test.ts
@@ -185,7 +185,7 @@ it("should update to latest versions of dependencies", async () => {
]);
expect(await exited1).toBe(0);
expect(urls.sort()).toEqual([
- `${root_url}/@barn/moo`,
+ `${root_url}/@barn%2fmoo`,
`${root_url}/@barn/moo-0.1.0.tgz`,
`${root_url}/baz`,
`${root_url}/baz-0.0.3.tgz`,
@@ -236,7 +236,7 @@ it("should update to latest versions of dependencies", async () => {
]);
expect(await exited2).toBe(0);
expect(urls.sort()).toEqual([
- `${root_url}/@barn/moo`,
+ `${root_url}/@barn%2fmoo`,
`${root_url}/@barn/moo-0.1.0.tgz`,
`${root_url}/baz`,
`${root_url}/baz-0.0.5.tgz`,
diff --git a/test/cli/install/dummy.registry.ts b/test/cli/install/dummy.registry.ts
index 69af0c381..5d0982f57 100644
--- a/test/cli/install/dummy.registry.ts
+++ b/test/cli/install/dummy.registry.ts
@@ -34,16 +34,19 @@ export let root_url: string;
export function dummyRegistry(urls: string[], info: any = { "0.0.2": {} }) {
const _handler: Handler = async request => {
urls.push(request.url);
+ const url = request.url.replaceAll("%2f", "/");
+
expect(request.method).toBe("GET");
- if (request.url.endsWith(".tgz")) {
- return new Response(file(join(import.meta.dir, basename(request.url).toLowerCase())));
+ if (url.endsWith(".tgz")) {
+ return new Response(file(join(import.meta.dir, basename(url).toLowerCase())));
}
expect(request.headers.get("accept")).toBe(
"application/vnd.npm.install-v1+json; q=1.0, application/json; q=0.8, */*",
);
expect(request.headers.get("npm-auth-type")).toBe(null);
expect(await request.text()).toBe("");
- const name = request.url.slice(request.url.indexOf("/", root_url.length) + 1);
+
+ const name = url.slice(url.indexOf("/", root_url.length) + 1);
const versions: Record<string, Pkg> = {};
let version;
for (version in info) {
@@ -52,7 +55,7 @@ export function dummyRegistry(urls: string[], info: any = { "0.0.2": {} }) {
name,
version,
dist: {
- tarball: `${request.url}-${info[version].as ?? version}.tgz`,
+ tarball: `${url}-${info[version].as ?? version}.tgz`,
},
...info[version],
};