diff options
| author | 2023-02-22 05:32:35 +0200 | |
|---|---|---|
| committer | 2023-02-21 19:32:35 -0800 | |
| commit | 2dc85c4e452c9f5faf9f12f16616e36a7b10fbee (patch) | |
| tree | 6de11c58e769e55b782252cd9caa2bf79fc96cb7 /test | |
| parent | 88c238dc5c125228f11940cbb65b7ae7b6aac6df (diff) | |
| download | bun-2dc85c4e452c9f5faf9f12f16616e36a7b10fbee.tar.gz bun-2dc85c4e452c9f5faf9f12f16616e36a7b10fbee.tar.zst bun-2dc85c4e452c9f5faf9f12f16616e36a7b10fbee.zip | |
[install] support SCP-style `git` dependencies (#2124)
- try HTTPS first before SSH
- improve package name resolution
- improve report messages
fixes #2119
Diffstat (limited to 'test')
| -rw-r--r-- | test/bun.js/install/bun-add.test.ts | 102 | ||||
| -rw-r--r-- | test/bun.js/install/bun-install.test.ts | 61 | 
2 files changed, 160 insertions, 3 deletions
| diff --git a/test/bun.js/install/bun-add.test.ts b/test/bun.js/install/bun-add.test.ts index ef8025a6a..76c4f39c4 100644 --- a/test/bun.js/install/bun-add.test.ts +++ b/test/bun.js/install/bun-add.test.ts @@ -63,7 +63,7 @@ it("should add existing package", async () => {    const out = await new Response(stdout).text();    expect(out.replace(/\s*\[[0-9\.]+m?s\]\s*$/, "").split(/\r?\n/)).toEqual([      "", -    ` installed file:${add_path}@${add_path}`, +    ` installed foo@${add_path}`,      "",      "",      " 1 packages installed", @@ -99,7 +99,7 @@ it("should reject missing package", async () => {    const err = await new Response(stderr).text();    expect(err.replace(/^(.*?) v[^\n]+/, "$1").split(/\r?\n/)).toEqual([      "bun add", -    `error: file:${add_path}@file:${add_path} failed to resolve`, +    `error: file:${add_path} failed to resolve`,      "",    ]);    expect(stdout).toBeDefined(); @@ -140,7 +140,7 @@ it("should reject invalid path without segfault", async () => {    const err = await new Response(stderr).text();    expect(err.replace(/^(.*?) v[^\n]+/, "$1").split(/\r?\n/)).toEqual([      "bun add", -    `error: file://${add_path}@file://${add_path} failed to resolve`, +    `error: file://${add_path} failed to resolve`,      "",    ]);    expect(stdout).toBeDefined(); @@ -763,3 +763,99 @@ it("should install version tagged with `latest` by default", async () => {    });    await access(join(package_dir, "bun.lockb"));  }); + +it("should handle Git URL in dependencies (SCP-style)", async () => { +  const urls: string[] = []; +  setHandler(dummyRegistry(urls)); +  await writeFile( +    join(package_dir, "package.json"), +    JSON.stringify({ +      name: "foo", +      version: "0.0.1", +    }), +  ); +  const { +    stdout: stdout1, +    stderr: stderr1, +    exited: exited1, +  } = spawn({ +    cmd: [bunExe(), "add", "bun@github.com:mishoo/UglifyJS.git", "--config", import.meta.dir + "/basic.toml"], +    cwd: package_dir, +    stdout: null, +    stdin: "pipe", +    stderr: "pipe", +    env, +  }); +  expect(stderr1).toBeDefined(); +  const err1 = await new Response(stderr1).text(); +  expect(err1).toContain("Saved lockfile"); +  expect(stdout1).toBeDefined(); +  let out1 = await new Response(stdout1).text(); +  out1 = out1.replace(/\s*\[[0-9\.]+m?s\]\s*$/, ""); +  out1 = out1.replace(/(\.git)#[a-f0-9]+/, "$1"); +  expect(out1.replace(/\s*\[[0-9\.]+m?s\]\s*$/, "").split(/\r?\n/)).toEqual([ +    "", +    " installed uglify-js@git+ssh://bun@github.com:mishoo/UglifyJS.git with binaries:", +    "  - uglifyjs", +    "", +    "", +    " 1 packages installed", +  ]); +  expect(await exited1).toBe(0); +  expect(urls.sort()).toEqual([]); +  expect(requested).toBe(0); +  expect(await file(join(package_dir, "package.json")).json()).toEqual({ +    name: "foo", +    version: "0.0.1", +    dependencies: { +      "uglify-js": "bun@github.com:mishoo/UglifyJS.git", +    }, +  }); +  expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".bin", ".cache", "uglify-js"]); +  expect(await readdirSorted(join(package_dir, "node_modules", ".bin"))).toEqual(["uglifyjs"]); +  expect(await readlink(join(package_dir, "node_modules", ".bin", "uglifyjs"))).toBe( +    join("..", "uglify-js", "bin", "uglifyjs"), +  ); +  expect((await readdirSorted(join(package_dir, "node_modules", ".cache")))[0]).toBe("9d05c118f06c3b4c.git"); +  expect(await readdirSorted(join(package_dir, "node_modules", "uglify-js"))).toEqual([ +    ".bun-tag", +    ".gitattributes", +    ".github", +    ".gitignore", +    "CONTRIBUTING.md", +    "LICENSE", +    "README.md", +    "bin", +    "lib", +    "package.json", +    "test", +    "tools", +  ]); +  const package_json = await file(join(package_dir, "node_modules", "uglify-js", "package.json")).json(); +  expect(package_json.name).toBe("uglify-js"); +  await access(join(package_dir, "bun.lockb")); +  const { +    stdout: stdout2, +    stderr: stderr2, +    exited: exited2, +  } = spawn({ +    cmd: [bunExe(), "install", "--config", import.meta.dir + "/basic.toml"], +    cwd: package_dir, +    stdout: null, +    stdin: "pipe", +    stderr: "pipe", +    env, +  }); +  expect(stderr2).toBeDefined(); +  const err2 = await new Response(stderr2).text(); +  expect(err2).not.toContain("Saved lockfile"); +  expect(stdout2).toBeDefined(); +  const out2 = await new Response(stdout2).text(); +  expect(out2.replace(/\s*\[[0-9\.]+m?s\]\s*$/, "").split(/\r?\n/)).toEqual([ +    "", +    "Checked 1 installs across 2 packages (no changes)", +  ]); +  expect(await exited2).toBe(0); +  expect(urls.sort()).toEqual([]); +  expect(requested).toBe(0); +}); diff --git a/test/bun.js/install/bun-install.test.ts b/test/bun.js/install/bun-install.test.ts index 360ab41ae..df997bf25 100644 --- a/test/bun.js/install/bun-install.test.ts +++ b/test/bun.js/install/bun-install.test.ts @@ -2137,6 +2137,67 @@ it("should handle Git URL in dependencies", async () => {    await access(join(package_dir, "bun.lockb"));  }); +it("should handle Git URL in dependencies (SCP-style)", async () => { +  const urls: string[] = []; +  setHandler(dummyRegistry(urls)); +  await writeFile( +    join(package_dir, "package.json"), +    JSON.stringify({ +      name: "foo", +      version: "0.0.1", +      dependencies: { +        uglify: "github.com:mishoo/UglifyJS.git", +      }, +    }), +  ); +  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(); +  let out = await new Response(stdout).text(); +  out = out.replace(/\s*\[[0-9\.]+m?s\]\s*$/, ""); +  out = out.replace(/(\.git)#[a-f0-9]+/, "$1"); +  expect(out.replace(/\s*\[[0-9\.]+m?s\]\s*$/, "").split(/\r?\n/)).toEqual([ +    " + uglify@git+ssh://github.com:mishoo/UglifyJS.git", +    "", +    " 1 packages installed", +  ]); +  expect(await exited).toBe(0); +  expect(urls.sort()).toEqual([]); +  expect(requested).toBe(0); +  expect(await readdirSorted(join(package_dir, "node_modules"))).toEqual([".bin", ".cache", "uglify"]); +  expect(await readdirSorted(join(package_dir, "node_modules", ".bin"))).toEqual(["uglifyjs"]); +  expect(await readlink(join(package_dir, "node_modules", ".bin", "uglifyjs"))).toBe( +    join("..", "uglify", "bin", "uglifyjs"), +  ); +  expect((await readdirSorted(join(package_dir, "node_modules", ".cache")))[0]).toBe("87d55589eb4217d2.git"); +  expect(await readdirSorted(join(package_dir, "node_modules", "uglify"))).toEqual([ +    ".bun-tag", +    ".gitattributes", +    ".github", +    ".gitignore", +    "CONTRIBUTING.md", +    "LICENSE", +    "README.md", +    "bin", +    "lib", +    "package.json", +    "test", +    "tools", +  ]); +  const package_json = await file(join(package_dir, "node_modules", "uglify", "package.json")).json(); +  expect(package_json.name).toBe("uglify-js"); +  await access(join(package_dir, "bun.lockb")); +}); +  it("should handle Git URL with committish in dependencies", async () => {    const urls: string[] = [];    setHandler(dummyRegistry(urls)); | 
