diff options
author | 2023-07-25 03:01:43 +0300 | |
---|---|---|
committer | 2023-07-24 17:01:43 -0700 | |
commit | 961312eab0e44b6b67c3bde536991d442da1118e (patch) | |
tree | 288a2926fc66d01896e4456f90553f6977776810 /test | |
parent | 6ca50526d787c19679f296e302b0aa7bb3292f18 (diff) | |
download | bun-961312eab0e44b6b67c3bde536991d442da1118e.tar.gz bun-961312eab0e44b6b67c3bde536991d442da1118e.tar.zst bun-961312eab0e44b6b67c3bde536991d442da1118e.zip |
[install] fix workspace override of aliased npm dependency (#3784)
Diffstat (limited to '')
-rw-r--r-- | test/cli/install/bun-install.test.ts | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/test/cli/install/bun-install.test.ts b/test/cli/install/bun-install.test.ts index 21c98efb3..b1f453f86 100644 --- a/test/cli/install/bun-install.test.ts +++ b/test/cli/install/bun-install.test.ts @@ -4901,6 +4901,52 @@ it("should override @scoped npm dependency by matching workspace", async () => { await access(join(package_dir, "bun.lockb")); }); +it("should override aliased npm dependency by matching workspace", async () => { + const urls: string[] = []; + setHandler(dummyRegistry(urls)); + await writeFile( + join(package_dir, "package.json"), + JSON.stringify({ + name: "foo", + workspaces: ["*"], + dependencies: { + bar: "npm:baz@<0.0.2", + }, + }), + ); + await mkdir(join(package_dir, "baz")); + const baz_package = JSON.stringify({ + name: "baz", + version: "0.0.1", + }); + await writeFile(join(package_dir, "baz", "package.json"), baz_package); + const { stdout, stderr, exited } = spawn({ + cmd: [bunExe(), "install"], + cwd: package_dir, + stdout: null, + stdin: "pipe", + stderr: "pipe", + env, + }); + expect(stderr).toBeDefined(); + const err = await new Response(stderr).text(); + expect(err).toContain("Saved lockfile"); + expect(stdout).toBeDefined(); + const out = await new Response(stdout).text(); + expect(out.replace(/\s*\[[0-9\.]+m?s\]\s*$/, "").split(/\r?\n/)).toEqual([ + " + bar@workspace:baz", + "", + " 1 packages installed", + ]); + expect(await exited).toBe(0); + expect(urls.sort()).toBeEmpty(); + expect(requested).toBe(0); + expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".cache", "bar"]); + expect(await readlink(join(package_dir, "node_modules", "bar"))).toBe(join("..", "baz")); + expect(await file(join(package_dir, "node_modules", "bar", "package.json")).text()).toEqual(baz_package); + await access(join(package_dir, "bun.lockb")); +}); + it("should override child npm dependency by matching workspace", async () => { const urls: string[] = []; setHandler(dummyRegistry(urls)); @@ -5082,3 +5128,63 @@ it("should override @scoped child npm dependency by matching workspace", async ( expect(await readdirSorted(join(package_dir, "node_modules", "@moo", "baz"))).toEqual(["package.json"]); await access(join(package_dir, "bun.lockb")); }); + +it("should override aliased child npm dependency by matching workspace", async () => { + const urls: string[] = []; + setHandler(dummyRegistry(urls)); + await writeFile( + join(package_dir, "package.json"), + JSON.stringify({ + name: "foo", + workspaces: ["packages/*"], + }), + ); + await mkdir(join(package_dir, "packages", "bar"), { recursive: true }); + const bar_package = JSON.stringify({ + name: "@moo/bar", + version: "0.0.1", + }); + await writeFile(join(package_dir, "packages", "bar", "package.json"), bar_package); + await mkdir(join(package_dir, "packages", "baz"), { recursive: true }); + await writeFile( + join(package_dir, "packages", "baz", "package.json"), + JSON.stringify({ + name: "baz", + version: "0.1.0", + dependencies: { + bar: "npm:@moo/bar@*", + }, + }), + ); + const { stdout, stderr, exited } = spawn({ + cmd: [bunExe(), "install"], + cwd: package_dir, + stdout: null, + stdin: "pipe", + stderr: "pipe", + env, + }); + expect(stderr).toBeDefined(); + const err = await new Response(stderr).text(); + expect(err).toContain("Saved lockfile"); + expect(stdout).toBeDefined(); + const out = await new Response(stdout).text(); + expect(out.replace(/\s*\[[0-9\.]+m?s\]\s*$/, "").split(/\r?\n/)).toEqual([ + " + @moo/bar@workspace:packages/bar", + " + baz@workspace:packages/baz", + "", + " 2 packages installed", + ]); + expect(await exited).toBe(0); + expect(urls.sort()).toBeEmpty(); + expect(requested).toBe(0); + expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".cache", "@moo", "baz"]); + expect(await readdirSorted(join(package_dir, "node_modules", "@moo"))).toEqual(["bar"]); + expect(await readlink(join(package_dir, "node_modules", "@moo", "bar"))).toBe(join("..", "..", "packages", "bar")); + expect(await file(join(package_dir, "node_modules", "@moo", "bar", "package.json")).text()).toEqual(bar_package); + expect(await readlink(join(package_dir, "node_modules", "baz"))).toBe(join("..", "packages", "baz")); + expect(await readdirSorted(join(package_dir, "packages", "baz"))).toEqual(["node_modules", "package.json"]); + expect(await readdirSorted(join(package_dir, "packages", "baz", "node_modules"))).toEqual(["bar"]); + expect(await readlink(join(package_dir, "packages", "baz", "node_modules", "bar"))).toBe(join("..", "..", "bar")); + await access(join(package_dir, "bun.lockb")); +}); |