diff options
| author | William Boman <william@redwill.se> | 2025-02-22 01:26:53 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-02-22 01:26:53 +0100 |
| commit | c8fa5dfaa3ecd104aa1a8c5f77de9c6287adbde3 (patch) | |
| tree | e9482aecc0677975b000f739047f5d0dd9031016 /tests | |
| parent | style: fix stylua and selene errors (diff) | |
| download | mason-c8fa5dfaa3ecd104aa1a8c5f77de9c6287adbde3.tar mason-c8fa5dfaa3ecd104aa1a8c5f77de9c6287adbde3.tar.gz mason-c8fa5dfaa3ecd104aa1a8c5f77de9c6287adbde3.tar.bz2 mason-c8fa5dfaa3ecd104aa1a8c5f77de9c6287adbde3.tar.lz mason-c8fa5dfaa3ecd104aa1a8c5f77de9c6287adbde3.tar.xz mason-c8fa5dfaa3ecd104aa1a8c5f77de9c6287adbde3.tar.zst mason-c8fa5dfaa3ecd104aa1a8c5f77de9c6287adbde3.zip | |
fix(spawn): expand executable paths on Windows before passing to uv_spawn (#1885)
This fixes issues on Windows where uv_spawn fails to locate certain
types of executables in PATH.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/mason-core/spawn_spec.lua | 106 |
1 files changed, 71 insertions, 35 deletions
diff --git a/tests/mason-core/spawn_spec.lua b/tests/mason-core/spawn_spec.lua index 9fc91200..db8f9575 100644 --- a/tests/mason-core/spawn_spec.lua +++ b/tests/mason-core/spawn_spec.lua @@ -1,5 +1,6 @@ local a = require "mason-core.async" local match = require "luassert.match" +local platform = require "mason-core.platform" local process = require "mason-core.process" local spawn = require "mason-core.spawn" local spy = require "luassert.spy" @@ -146,46 +147,81 @@ describe("async spawn", function() ) end) - it("should check whether command is executable", function() - local result = a.run_blocking(spawn.my_cmd, {}) - assert.is_true(result:is_failure()) - assert.equals( - "spawn: my_cmd failed with exit code - and signal -. my_cmd is not executable", - tostring(result:err_or_nil()) - ) - end) + describe("Windows", function() + before_each(function() + platform.is.win = true + end) - it("should skip checking whether command is executable", function() - stub(process, "spawn", function(_, _, callback) - callback(false, 127) + after_each(function() + platform.is.win = nil end) - local result = a.run_blocking(spawn.my_cmd, { "arg1", check_executable = false }) - assert.is_true(result:is_failure()) - assert.spy(process.spawn).was_called(1) - assert.spy(process.spawn).was_called_with( - "my_cmd", - match.tbl_containing { - args = match.same { "arg1" }, - }, - match.is_function() - ) - end) + it("should use exepath to get absolute path to executable", function() + stub(process, "spawn", function(_, _, callback) + callback(true, 0, 0) + end) - it("should skip checking whether command is executable if with_paths is provided", function() - stub(process, "spawn", function(_, _, callback) - callback(false, 127) + local result = a.run_blocking(spawn.bash, { "arg1" }) + assert.is_true(result:is_success()) + assert.spy(process.spawn).was_called(1) + assert.spy(process.spawn).was_called_with( + vim.fn.exepath "bash", + match.tbl_containing { + args = match.same { "arg1" }, + }, + match.is_function() + ) end) - local result = a.run_blocking(spawn.my_cmd, { "arg1", with_paths = {} }) - assert.is_true(result:is_failure()) - assert.spy(process.spawn).was_called(1) - assert.spy(process.spawn).was_called_with( - "my_cmd", - match.tbl_containing { - args = match.same { "arg1" }, - }, - match.is_function() - ) + it("should not use exepath if env.PATH is set", function() + stub(process, "spawn", function(_, _, callback) + callback(true, 0, 0) + end) + + local result = a.run_blocking(spawn.bash, { "arg1", env = { PATH = "C:\\some\\path" } }) + assert.is_true(result:is_success()) + assert.spy(process.spawn).was_called(1) + assert.spy(process.spawn).was_called_with( + "bash", + match.tbl_containing { + args = match.same { "arg1" }, + }, + match.is_function() + ) + end) + + it("should not use exepath if env_raw.PATH is set", function() + stub(process, "spawn", function(_, _, callback) + callback(true, 0, 0) + end) + + local result = a.run_blocking(spawn.bash, { "arg1", env_raw = { "PATH=C:\\some\\path" } }) + assert.is_true(result:is_success()) + assert.spy(process.spawn).was_called(1) + assert.spy(process.spawn).was_called_with( + "bash", + match.tbl_containing { + args = match.same { "arg1" }, + }, + match.is_function() + ) + end) + + it("should not use exepath if with_paths is provided", function() + stub(process, "spawn", function(_, _, callback) + callback(true, 0, 0) + end) + + local result = a.run_blocking(spawn.bash, { "arg1", with_paths = { "C:\\some\\path" } }) + assert.is_true(result:is_success()) + assert.spy(process.spawn).was_called(1) + assert.spy(process.spawn).was_called_with( + "bash", + match.tbl_containing { + args = match.same { "arg1" }, + }, + match.is_function() + ) + end) end) end) |
