mirror of
https://github.com/lune-org/lune.git
synced 2025-01-07 20:09:09 +00:00
Fix failing test cases on Windows (#111)
This commit is contained in:
parent
8c853fb99e
commit
83ac971792
4 changed files with 54 additions and 19 deletions
3
.gitattributes
vendored
3
.gitattributes
vendored
|
@ -7,3 +7,6 @@
|
||||||
# Ensure all lua files use LF
|
# Ensure all lua files use LF
|
||||||
*.lua eol=lf
|
*.lua eol=lf
|
||||||
*.luau eol=lf
|
*.luau eol=lf
|
||||||
|
|
||||||
|
# Ensure all txt files within tests use LF
|
||||||
|
tests/**/*.txt eol=lf
|
||||||
|
|
|
@ -98,7 +98,7 @@ impl<'lua> FromLua<'lua> for ProcessSpawnOptions {
|
||||||
LuaValue::Boolean(true) => {
|
LuaValue::Boolean(true) => {
|
||||||
this.shell = match env::consts::FAMILY {
|
this.shell = match env::consts::FAMILY {
|
||||||
"unix" => Some("/bin/sh".to_string()),
|
"unix" => Some("/bin/sh".to_string()),
|
||||||
"windows" => Some("/bin/sh".to_string()),
|
"windows" => Some("powershell".to_string()),
|
||||||
_ => None,
|
_ => None,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,7 +52,8 @@ if not success then
|
||||||
assert(
|
assert(
|
||||||
string.find(message, "Connection reset")
|
string.find(message, "Connection reset")
|
||||||
or string.find(message, "Connection closed")
|
or string.find(message, "Connection closed")
|
||||||
or string.find(message, "Connection refused"),
|
or string.find(message, "Connection refused")
|
||||||
|
or string.find(message, "No connection could be made"), -- Windows Request Error
|
||||||
"Server did not stop responding to requests"
|
"Server did not stop responding to requests"
|
||||||
)
|
)
|
||||||
else
|
else
|
||||||
|
|
|
@ -10,9 +10,17 @@ local thread = task.delay(1, function()
|
||||||
process.exit(1)
|
process.exit(1)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
local result = process.spawn("ls", {
|
local isWindows = process.os == "windows";
|
||||||
"-a",
|
|
||||||
})
|
-- To run windows command, we need to launch cmd.exe and pass the command as an argument.
|
||||||
|
local result = process.spawn(
|
||||||
|
if isWindows then "cmd" else "ls",
|
||||||
|
if isWindows then {
|
||||||
|
"/c", "dir"
|
||||||
|
} else {
|
||||||
|
"-a"
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
task.cancel(thread)
|
task.cancel(thread)
|
||||||
|
|
||||||
|
@ -27,7 +35,7 @@ assert(string.find(result.stdout, ".gitignore") ~= nil, "Missing .gitignore in o
|
||||||
-- It should also work the same when spawned using a shell
|
-- It should also work the same when spawned using a shell
|
||||||
|
|
||||||
local shellResult = process.spawn("ls", {
|
local shellResult = process.spawn("ls", {
|
||||||
"-a",
|
if isWindows then "-Force" else "-a"
|
||||||
}, {
|
}, {
|
||||||
shell = true,
|
shell = true,
|
||||||
})
|
})
|
||||||
|
@ -40,30 +48,34 @@ assert(shellResult.stdout ~= "", "Stdout was empty (shell)")
|
||||||
assert(string.find(shellResult.stdout, "Cargo.toml") ~= nil, "Missing Cargo.toml in output (shell)")
|
assert(string.find(shellResult.stdout, "Cargo.toml") ~= nil, "Missing Cargo.toml in output (shell)")
|
||||||
assert(string.find(shellResult.stdout, ".gitignore") ~= nil, "Missing .gitignore in output (shell)")
|
assert(string.find(shellResult.stdout, ".gitignore") ~= nil, "Missing .gitignore in output (shell)")
|
||||||
|
|
||||||
|
local pwdCommand = if isWindows then "cmd" else "pwd"
|
||||||
|
local pwdArgs = if isWindows then { "/c", "cd" } else {}
|
||||||
-- Make sure the cwd option actually uses the directory we want
|
-- Make sure the cwd option actually uses the directory we want
|
||||||
local rootPwd = process.spawn("pwd", {}, {
|
local rootPwd = process.spawn(pwdCommand, pwdArgs, {
|
||||||
cwd = "/",
|
cwd = "/",
|
||||||
}).stdout
|
}).stdout
|
||||||
rootPwd = string.gsub(rootPwd, "^%s+", "")
|
rootPwd = string.gsub(rootPwd, "^%s+", "")
|
||||||
rootPwd = string.gsub(rootPwd, "%s+$", "")
|
rootPwd = string.gsub(rootPwd, "%s+$", "")
|
||||||
if rootPwd ~= "/" then
|
-- Windows: <Drive Letter>:\, Unix: /
|
||||||
|
local expectedRootPwd = if isWindows then string.sub(rootPwd, 1, 1) .. ":\\" else "/"
|
||||||
|
if rootPwd ~= expectedRootPwd then
|
||||||
error(
|
error(
|
||||||
string.format(
|
string.format(
|
||||||
"Current working directory for child process was not set correctly!"
|
"Current working directory for child process was not set correctly!"
|
||||||
.. "\nExpected '/', got '%s'",
|
.. "\nExpected '%s', got '%s'",
|
||||||
rootPwd
|
expectedRootPwd, rootPwd
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Setting cwd should not change the cwd of this process
|
-- Setting cwd should not change the cwd of this process
|
||||||
|
|
||||||
local pwdBefore = process.spawn("pwd").stdout
|
local pwdBefore = process.spawn(pwdCommand, pwdArgs).stdout
|
||||||
process.spawn("ls", {}, {
|
process.spawn("ls", {}, {
|
||||||
cwd = "/",
|
cwd = "/",
|
||||||
shell = true,
|
shell = true,
|
||||||
})
|
})
|
||||||
local pwdAfter = process.spawn("pwd").stdout
|
local pwdAfter = process.spawn(pwdCommand, pwdArgs).stdout
|
||||||
assert(pwdBefore == pwdAfter, "Current working directory changed after running child process")
|
assert(pwdBefore == pwdAfter, "Current working directory changed after running child process")
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
|
@ -74,7 +86,10 @@ assert(pwdBefore == pwdAfter, "Current working directory changed after running c
|
||||||
local homeDir1 = process.spawn("echo $HOME", nil, {
|
local homeDir1 = process.spawn("echo $HOME", nil, {
|
||||||
shell = true,
|
shell = true,
|
||||||
}).stdout
|
}).stdout
|
||||||
local homeDir2 = process.spawn("pwd", nil, {
|
|
||||||
|
-- Powershell for windows uses `$pwd.Path` instead of `pwd` as pwd would return a PathInfo object,
|
||||||
|
-- using $pwd.Path gets the Path property of the PathInfo object.
|
||||||
|
local homeDir2 = process.spawn(if isWindows then "$pwd.Path" else "pwd", nil, {
|
||||||
shell = true,
|
shell = true,
|
||||||
cwd = "~",
|
cwd = "~",
|
||||||
}).stdout
|
}).stdout
|
||||||
|
@ -94,7 +109,10 @@ assert(homeDir1 == homeDir2, "Home dirs did not match when performing tilde subs
|
||||||
local SLEEP_DURATION = 1 / 4
|
local SLEEP_DURATION = 1 / 4
|
||||||
local SLEEP_SAMPLES = 2
|
local SLEEP_SAMPLES = 2
|
||||||
|
|
||||||
local thread2 = task.delay(SLEEP_DURATION * 1.5, function()
|
-- Windows tend to have a higher execution time
|
||||||
|
local yieldTolarance = if isWindows then 25 else SLEEP_DURATION * 1.5;
|
||||||
|
|
||||||
|
local thread2 = task.delay(yieldTolarance, function()
|
||||||
stdio.ewrite("Spawning a sleep process should take a reasonable amount of time\n")
|
stdio.ewrite("Spawning a sleep process should take a reasonable amount of time\n")
|
||||||
task.wait(1)
|
task.wait(1)
|
||||||
process.exit(1)
|
process.exit(1)
|
||||||
|
@ -104,7 +122,16 @@ local sleepStart = os.clock()
|
||||||
local sleepCounter = 0
|
local sleepCounter = 0
|
||||||
for i = 1, SLEEP_SAMPLES, 1 do
|
for i = 1, SLEEP_SAMPLES, 1 do
|
||||||
task.spawn(function()
|
task.spawn(function()
|
||||||
process.spawn("sleep", { tostring(SLEEP_DURATION) })
|
local args = {
|
||||||
|
-- Sleep command on Windows in Seconds has some weird behavior with decimals...
|
||||||
|
tostring(SLEEP_DURATION * (isWindows and 1000 or 1))
|
||||||
|
};
|
||||||
|
if isWindows then
|
||||||
|
-- ... so we use milliseconds instead.
|
||||||
|
table.insert(args, 1, "-Milliseconds");
|
||||||
|
end
|
||||||
|
-- Windows does not have `sleep` as a process, so we use powershell instead.
|
||||||
|
process.spawn("sleep", args, if isWindows then { shell = true } else nil)
|
||||||
sleepCounter += 1
|
sleepCounter += 1
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
@ -115,12 +142,13 @@ end
|
||||||
task.cancel(thread2)
|
task.cancel(thread2)
|
||||||
|
|
||||||
local sleepElapsed = os.clock() - sleepStart
|
local sleepElapsed = os.clock() - sleepStart
|
||||||
|
|
||||||
assert(
|
assert(
|
||||||
sleepElapsed >= SLEEP_DURATION,
|
sleepElapsed >= SLEEP_DURATION,
|
||||||
"Spawning a process that does blocking sleep did not sleep enough"
|
"Spawning a process that does blocking sleep did not sleep enough"
|
||||||
)
|
)
|
||||||
assert(
|
assert(
|
||||||
sleepElapsed < SLEEP_DURATION * 1.5,
|
sleepElapsed < yieldTolarance,
|
||||||
"Coroutine yielded the main lua thread during process yield"
|
"Coroutine yielded the main lua thread during process yield"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -128,13 +156,16 @@ assert(
|
||||||
|
|
||||||
local echoMessage = "Hello from child process!"
|
local echoMessage = "Hello from child process!"
|
||||||
local echoResult = process.spawn("echo", {
|
local echoResult = process.spawn("echo", {
|
||||||
'"$TEST_VAR"',
|
if isWindows then '"$Env:TEST_VAR"' else '"$TEST_VAR"',
|
||||||
}, {
|
}, {
|
||||||
env = { TEST_VAR = echoMessage },
|
env = { TEST_VAR = echoMessage },
|
||||||
shell = "bash",
|
shell = if isWindows then "powershell" else "bash", -- "bash" does not exist on Windows, using "powershell" instead.
|
||||||
stdio = "inherit",
|
stdio = "inherit",
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- Windows echo adds a \r before the newline
|
||||||
|
local trailingAddition = if isWindows then "\r\n" else "\n"
|
||||||
assert(
|
assert(
|
||||||
echoResult.stdout == (echoMessage .. "\n"), -- Note that echo adds a newline
|
echoResult.stdout == (echoMessage .. trailingAddition), -- Note that echo adds a newline
|
||||||
"Inheriting stdio did not return proper output"
|
"Inheriting stdio did not return proper output"
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in a new issue