aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorGravatar Alex Lam S.L <alexlamsl@gmail.com> 2023-07-25 03:01:43 +0300
committerGravatar GitHub <noreply@github.com> 2023-07-24 17:01:43 -0700
commit961312eab0e44b6b67c3bde536991d442da1118e (patch)
tree288a2926fc66d01896e4456f90553f6977776810 /test
parent6ca50526d787c19679f296e302b0aa7bb3292f18 (diff)
downloadbun-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.ts106
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"));
+});