diff options
author | 2023-02-27 19:36:17 +0200 | |
---|---|---|
committer | 2023-02-27 09:36:17 -0800 | |
commit | c8be1e9a5dd36f5c6883a0d7058d1c6e6da2a5f8 (patch) | |
tree | 2e890d89e07e1191e69127dcb7ebef0b2402e4b0 /test/bun.js | |
parent | f420e81e85e9597cb96799d313b75dc7da16edd6 (diff) | |
download | bun-c8be1e9a5dd36f5c6883a0d7058d1c6e6da2a5f8.tar.gz bun-c8be1e9a5dd36f5c6883a0d7058d1c6e6da2a5f8.tar.zst bun-c8be1e9a5dd36f5c6883a0d7058d1c6e6da2a5f8.zip |
resolve duplicated dependency correctly (#2213)
Diffstat (limited to 'test/bun.js')
-rw-r--r-- | test/bun.js/install/bun-add.test.ts | 120 | ||||
-rw-r--r-- | test/bun.js/install/bun-install.test.ts | 112 |
2 files changed, 232 insertions, 0 deletions
diff --git a/test/bun.js/install/bun-add.test.ts b/test/bun.js/install/bun-add.test.ts index 76c4f39c4..ada3c4b58 100644 --- a/test/bun.js/install/bun-add.test.ts +++ b/test/bun.js/install/bun-add.test.ts @@ -859,3 +859,123 @@ it("should handle Git URL in dependencies (SCP-style)", async () => { expect(urls.sort()).toEqual([]); expect(requested).toBe(0); }); + +it("should prefer optionalDependencies over dependencies of the same name", async () => { + const urls = []; + setHandler( + dummyRegistry(urls, { + "0.0.2": { + dependencies: { + baz: "0.0.3", + }, + optionalDependencies: { + baz: "0.0.5", + }, + }, + "0.0.3": {}, + "0.0.5": {}, + }), + ); + const { stdout, stderr, exited } = spawn({ + cmd: [bunExe(), "add", "bar@0.0.2", "--config", import.meta.dir + "/basic.toml"], + 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([ + "", + " installed bar@0.0.2", + "", + "", + " 2 packages installed", + ]); + expect(await exited).toBe(0); + expect(urls.sort()).toEqual([ + `${root_url}/bar`, + `${root_url}/bar-0.0.2.tgz`, + `${root_url}/baz`, + `${root_url}/baz-0.0.5.tgz`, + ]); + expect(requested).toBe(4); + expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".cache", "bar", "baz"]); + expect(await readdirSorted(join(package_dir, "node_modules", "bar"))).toEqual(["package.json"]); + expect(await readdirSorted(join(package_dir, "node_modules", "baz"))).toEqual(["index.js", "package.json"]); + expect(await file(join(package_dir, "node_modules", "bar", "package.json")).json()).toEqual({ + name: "bar", + version: "0.0.2", + }); + expect(await file(join(package_dir, "node_modules", "baz", "package.json")).json()).toEqual({ + name: "baz", + version: "0.0.5", + bin: { + "baz-exec": "index.js", + }, + }); +}); + +it("should prefer dependencies over peerDependencies of the same name", async () => { + const urls = []; + setHandler( + dummyRegistry(urls, { + "0.0.2": { + dependencies: { + baz: "0.0.3", + }, + peerDependencies: { + baz: "0.0.5", + }, + }, + "0.0.3": {}, + "0.0.5": {}, + }), + ); + const { stdout, stderr, exited } = spawn({ + cmd: [bunExe(), "add", "bar@0.0.2", "--config", import.meta.dir + "/basic.toml"], + 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([ + "", + " installed bar@0.0.2", + "", + "", + " 2 packages installed", + ]); + expect(await exited).toBe(0); + expect(urls.sort()).toEqual([ + `${root_url}/bar`, + `${root_url}/bar-0.0.2.tgz`, + `${root_url}/baz`, + `${root_url}/baz-0.0.3.tgz`, + ]); + expect(requested).toBe(4); + expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".cache", "bar", "baz"]); + expect(await readdirSorted(join(package_dir, "node_modules", "bar"))).toEqual(["package.json"]); + expect(await readdirSorted(join(package_dir, "node_modules", "baz"))).toEqual(["index.js", "package.json"]); + expect(await file(join(package_dir, "node_modules", "bar", "package.json")).json()).toEqual({ + name: "bar", + version: "0.0.2", + }); + expect(await file(join(package_dir, "node_modules", "baz", "package.json")).json()).toEqual({ + name: "baz", + version: "0.0.3", + bin: { + "baz-run": "index.js", + }, + }); +}); diff --git a/test/bun.js/install/bun-install.test.ts b/test/bun.js/install/bun-install.test.ts index df997bf25..6f7a13433 100644 --- a/test/bun.js/install/bun-install.test.ts +++ b/test/bun.js/install/bun-install.test.ts @@ -2425,3 +2425,115 @@ it("should de-duplicate committish in Git URLs", async () => { expect(ver_json.version).toBe("3.14.1"); await access(join(package_dir, "bun.lockb")); }); + +it("should prefer optionalDependencies over dependencies of the same name", async () => { + const urls = []; + setHandler( + dummyRegistry(urls, { + "0.0.3": {}, + "0.0.5": {}, + }), + ); + await writeFile( + join(package_dir, "package.json"), + JSON.stringify({ + name: "foo", + version: "0.0.1", + dependencies: { + "baz": "0.0.5", + }, + optionalDependencies: { + "baz": "0.0.3", + } + }), + ); + const { stdout, stderr, exited } = spawn({ + cmd: [bunExe(), "install", "--config", import.meta.dir + "/basic.toml"], + 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([ + " + baz@0.0.3", + "", + " 1 packages installed", + ]); + expect(await exited).toBe(0); + expect(urls.sort()).toEqual([ + `${root_url}/baz`, + `${root_url}/baz-0.0.3.tgz`, + ]); + expect(requested).toBe(2); + expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".cache", "baz"]); + expect(await readdirSorted(join(package_dir, "node_modules", "baz"))).toEqual(["index.js", "package.json"]); + expect(await file(join(package_dir, "node_modules", "baz", "package.json")).json()).toEqual({ + name: "baz", + version: "0.0.3", + bin: { + "baz-run": "index.js", + }, + }); +}); + +it("should prefer dependencies over peerDependencies of the same name", async () => { + const urls = []; + setHandler( + dummyRegistry(urls, { + "0.0.3": {}, + "0.0.5": {}, + }), + ); + await writeFile( + join(package_dir, "package.json"), + JSON.stringify({ + name: "foo", + version: "0.0.1", + dependencies: { + "baz": "0.0.5", + }, + peerDependencies: { + "baz": "0.0.3", + } + }), + ); + const { stdout, stderr, exited } = spawn({ + cmd: [bunExe(), "install", "--config", import.meta.dir + "/basic.toml"], + 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([ + " + baz@0.0.5", + "", + " 1 packages installed", + ]); + expect(await exited).toBe(0); + expect(urls.sort()).toEqual([ + `${root_url}/baz`, + `${root_url}/baz-0.0.5.tgz`, + ]); + expect(requested).toBe(2); + expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".cache", "baz"]); + expect(await readdirSorted(join(package_dir, "node_modules", "baz"))).toEqual(["index.js", "package.json"]); + expect(await file(join(package_dir, "node_modules", "baz", "package.json")).json()).toEqual({ + name: "baz", + version: "0.0.5", + bin: { + "baz-exec": "index.js", + }, + }); +}); |