mirror of
https://github.com/lune-org/lune.git
synced 2025-04-04 10:30:54 +01:00
Merge branch 'main' into terrain-material-enum-name-fromstr
This commit is contained in:
commit
d763ac6b40
11 changed files with 202 additions and 185 deletions
|
@ -52,6 +52,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||
print(now:toUniversalTime())
|
||||
```
|
||||
|
||||
- Added support for passing `stdin` in `process.spawn` ([#106])
|
||||
- Added support for setting a custom environment in load options for `luau.load`, not subject to `getfenv` / `setfenv` deoptimizations
|
||||
- Added [Terrain:GetMaterialColor](https://create.roblox.com/docs/reference/engine/classes/Terrain#GetMaterialColor) and [Terrain:SetMaterialColor](https://create.roblox.com/docs/reference/engine/classes/Terrain#SetMaterialColor) ([#93])
|
||||
- Added support for a variable number of arguments for CFrame methods ([#85])
|
||||
|
@ -71,12 +72,15 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||
- Fixed missing trailing newline when using the `warn` global.
|
||||
- Fixed constructor for `CFrame` in the `roblox` built-in library not parsing the 12-arg overload correctly. ([#102])
|
||||
- Fixed various functions for `CFrame` in the `roblox` built-in library being incorrect, specifically row-column ordering and some flipped signs. ([#103])
|
||||
- Fixed cross-service Instance references disappearing when using the `roblox` built-in library ([#117])
|
||||
|
||||
[#85]: https://github.com/filiptibell/lune/pull/85
|
||||
[#93]: https://github.com/filiptibell/lune/pull/93
|
||||
[#94]: https://github.com/filiptibell/lune/pull/94
|
||||
[#102]: https://github.com/filiptibell/lune/pull/102
|
||||
[#103]: https://github.com/filiptibell/lune/pull/103
|
||||
[#106]: https://github.com/filiptibell/lune/pull/106
|
||||
[#117]: https://github.com/filiptibell/lune/pull/117
|
||||
|
||||
## `0.7.7` - August 23rd, 2023
|
||||
|
||||
|
|
|
@ -48,9 +48,9 @@ async fn read_or_create_vscode_settings_json() -> Result<JsonValue, SetupError>
|
|||
// let the user choose their editor for interactive setup
|
||||
match fs::create_dir_all(path_dir).await {
|
||||
Err(_) => Err(SetupError::Write),
|
||||
Ok(_) => match fs::write(path_file, "{}").await {
|
||||
Ok(()) => match fs::write(path_file, "{}").await {
|
||||
Err(_) => Err(SetupError::Write),
|
||||
Ok(_) => Ok(JsonValue::Object(serde_json::Map::new())),
|
||||
Ok(()) => Ok(JsonValue::Object(serde_json::Map::new())),
|
||||
},
|
||||
}
|
||||
}
|
||||
|
@ -67,7 +67,7 @@ async fn write_vscode_settings_json(value: JsonValue) -> Result<(), SetupError>
|
|||
Err(_) => Err(SetupError::Serialize),
|
||||
Ok(json) => match fs::write(vscode_path(), json).await {
|
||||
Err(_) => Err(SetupError::Write),
|
||||
Ok(_) => Ok(()),
|
||||
Ok(()) => Ok(()),
|
||||
},
|
||||
}
|
||||
}
|
||||
|
@ -112,7 +112,7 @@ pub async fn run_setup() {
|
|||
}
|
||||
.await;
|
||||
let message = match res {
|
||||
Ok(_) => "These settings have been added to your workspace for Visual Studio Code:",
|
||||
Ok(()) => "These settings have been added to your workspace for Visual Studio Code:",
|
||||
Err(_) => "To finish setting up your editor, add these settings to your workspace:",
|
||||
};
|
||||
let version_string = lune_version();
|
||||
|
|
|
@ -291,7 +291,7 @@ impl<'lua> LuaToDomValue<'lua> for LuaAnyUserData<'lua> {
|
|||
}
|
||||
|
||||
ty => {
|
||||
return Err(DomConversionError::ToDomValue {
|
||||
Err(DomConversionError::ToDomValue {
|
||||
to: ty.variant_name().unwrap_or("???"),
|
||||
from: "userdata",
|
||||
detail: Some("Type not supported".to_string()),
|
||||
|
|
|
@ -75,7 +75,12 @@ create_tests! {
|
|||
process_cwd: "process/cwd",
|
||||
process_env: "process/env",
|
||||
process_exit: "process/exit",
|
||||
process_spawn: "process/spawn",
|
||||
process_spawn_async: "process/spawn/async",
|
||||
process_spawn_basic: "process/spawn/basic",
|
||||
process_spawn_cwd: "process/spawn/cwd",
|
||||
process_spawn_shell: "process/spawn/shell",
|
||||
process_spawn_stdin: "process/spawn/stdin",
|
||||
process_spawn_stdio: "process/spawn/stdio",
|
||||
|
||||
require_async: "require/tests/async",
|
||||
require_async_background: "require/tests/async_background",
|
||||
|
|
|
@ -1,179 +0,0 @@
|
|||
local process = require("@lune/process")
|
||||
local stdio = require("@lune/stdio")
|
||||
local task = require("@lune/task")
|
||||
|
||||
-- Spawning a child process should work, with options
|
||||
|
||||
local thread = task.delay(1, function()
|
||||
stdio.ewrite("Spawning a process should take a reasonable amount of time\n")
|
||||
task.wait(1)
|
||||
process.exit(1)
|
||||
end)
|
||||
|
||||
local IS_WINDOWS = process.os == "windows"
|
||||
|
||||
local result = process.spawn(
|
||||
if IS_WINDOWS then "cmd" else "ls",
|
||||
if IS_WINDOWS then { "/c", "dir" } else { "-a" }
|
||||
)
|
||||
|
||||
task.cancel(thread)
|
||||
|
||||
assert(result.ok, "Failed to spawn child process")
|
||||
|
||||
assert(result.stderr == "", "Stderr was not empty")
|
||||
assert(result.stdout ~= "", "Stdout was empty")
|
||||
|
||||
assert(string.find(result.stdout, "Cargo.toml") ~= nil, "Missing Cargo.toml in output")
|
||||
assert(string.find(result.stdout, ".gitignore") ~= nil, "Missing .gitignore in output")
|
||||
|
||||
-- It should also work the same when spawned using a shell
|
||||
-- Note that the default on Windows is Powershell which has different flags / behavior
|
||||
|
||||
local shellResult = process.spawn("ls", {
|
||||
if IS_WINDOWS then "-Force" else "-a",
|
||||
}, {
|
||||
shell = true,
|
||||
})
|
||||
|
||||
assert(shellResult.ok, "Failed to spawn child process (shell)")
|
||||
|
||||
assert(shellResult.stderr == "", "Stderr was not empty (shell)")
|
||||
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, ".gitignore") ~= nil, "Missing .gitignore in output (shell)")
|
||||
|
||||
local pwdCommand = if IS_WINDOWS then "cmd" else "pwd"
|
||||
local pwdArgs = if IS_WINDOWS then { "/c", "cd" } else {}
|
||||
|
||||
-- Make sure the cwd option actually uses the directory we want
|
||||
local rootPwd = process.spawn(pwdCommand, pwdArgs, {
|
||||
cwd = "/",
|
||||
}).stdout
|
||||
rootPwd = string.gsub(rootPwd, "^%s+", "")
|
||||
rootPwd = string.gsub(rootPwd, "%s+$", "")
|
||||
|
||||
-- Windows: <Drive Letter>:\, Unix: /
|
||||
local expectedRootPwd = if IS_WINDOWS then string.sub(rootPwd, 1, 1) .. ":\\" else "/"
|
||||
if rootPwd ~= expectedRootPwd then
|
||||
error(
|
||||
string.format(
|
||||
"Current working directory for child process was not set correctly!"
|
||||
.. "\nExpected '%s', got '%s'",
|
||||
expectedRootPwd,
|
||||
rootPwd
|
||||
)
|
||||
)
|
||||
end
|
||||
|
||||
-- Setting cwd should not change the cwd of this process
|
||||
|
||||
local pwdBefore = process.spawn(pwdCommand, pwdArgs).stdout
|
||||
process.spawn("ls", {}, {
|
||||
cwd = "/",
|
||||
shell = true,
|
||||
})
|
||||
local pwdAfter = process.spawn(pwdCommand, pwdArgs).stdout
|
||||
assert(pwdBefore == pwdAfter, "Current working directory changed after running child process")
|
||||
|
||||
--[[
|
||||
Setting the cwd on a child process should properly
|
||||
replace any leading ~ with the users real home dir
|
||||
]]
|
||||
|
||||
local homeDir1 = process.spawn("echo $HOME", nil, {
|
||||
shell = true,
|
||||
}).stdout
|
||||
|
||||
-- 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 IS_WINDOWS then "$pwd.Path" else "pwd", nil, {
|
||||
shell = true,
|
||||
cwd = "~",
|
||||
}).stdout
|
||||
|
||||
assert(#homeDir1 > 0, "Home dir from echo was empty")
|
||||
assert(#homeDir2 > 0, "Home dir from pwd was empty")
|
||||
assert(homeDir1 == homeDir2, "Home dirs did not match when performing tilde substitution")
|
||||
|
||||
--[[
|
||||
Spawning a process should not block any lua thread(s)
|
||||
|
||||
We test this by sleeping more than once concurrently
|
||||
and then ensuring that the total time slept is more
|
||||
than a single sleep but also less than 1.5 sleeps
|
||||
]]
|
||||
|
||||
local SLEEP_DURATION = 1 / 4
|
||||
local SLEEP_SAMPLES = 2
|
||||
|
||||
-- Unfortunately we
|
||||
local thread2 = task.delay(30, function()
|
||||
stdio.ewrite("Spawning a sleep process should take a reasonable amount of time\n")
|
||||
task.wait(1)
|
||||
process.exit(1)
|
||||
end)
|
||||
|
||||
local sleepStart = os.clock()
|
||||
local sleepCounter = 0
|
||||
for i = 1, SLEEP_SAMPLES, 1 do
|
||||
task.spawn(function()
|
||||
local args = {
|
||||
-- Sleep command on Windows in Seconds has some weird behavior with decimals ...
|
||||
tostring(SLEEP_DURATION * (IS_WINDOWS and 1000 or 1)),
|
||||
}
|
||||
if IS_WINDOWS 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 IS_WINDOWS then { shell = true } else nil)
|
||||
sleepCounter += 1
|
||||
end)
|
||||
end
|
||||
while sleepCounter < SLEEP_SAMPLES do
|
||||
task.wait()
|
||||
end
|
||||
|
||||
task.cancel(thread2)
|
||||
|
||||
assert(
|
||||
(os.clock() - sleepStart) >= SLEEP_DURATION,
|
||||
"Spawning a process that does blocking sleep did not sleep enough"
|
||||
)
|
||||
|
||||
-- Inheriting stdio & environment variables should work
|
||||
|
||||
local echoMessage = "Hello from child process!"
|
||||
local echoResult = process.spawn("echo", {
|
||||
if IS_WINDOWS then '"$Env:TEST_VAR"' else '"$TEST_VAR"',
|
||||
}, {
|
||||
env = { TEST_VAR = echoMessage },
|
||||
shell = if IS_WINDOWS then "powershell" else "bash",
|
||||
stdio = "inherit",
|
||||
})
|
||||
|
||||
-- Windows echo adds \r\n (CRLF) and unix adds \n (LF)
|
||||
local trailingAddition = if IS_WINDOWS then "\r\n" else "\n"
|
||||
assert(
|
||||
echoResult.stdout == (echoMessage .. trailingAddition),
|
||||
"Inheriting stdio did not return proper output"
|
||||
)
|
||||
|
||||
-- Passing stdin strings should work
|
||||
|
||||
local stdinChild = process.spawn(not IS_WINDOWS and "xargs" or "powershell", {
|
||||
"echo",
|
||||
}, {
|
||||
stdin = echoMessage .. (IS_WINDOWS and "\n\n" or ""),
|
||||
})
|
||||
|
||||
local stdinChildOut = stdinChild.stdout
|
||||
if IS_WINDOWS then
|
||||
stdinChildOut = stdinChildOut:sub(#stdinChildOut - #echoMessage - 1, #stdinChildOut)
|
||||
end
|
||||
assert(
|
||||
stdinChildOut == echoMessage .. trailingAddition,
|
||||
"Stdin passing did not return proper output"
|
||||
)
|
44
tests/process/spawn/async.luau
Normal file
44
tests/process/spawn/async.luau
Normal file
|
@ -0,0 +1,44 @@
|
|||
local process = require("@lune/process")
|
||||
local stdio = require("@lune/stdio")
|
||||
local task = require("@lune/task")
|
||||
|
||||
local IS_WINDOWS = process.os == "windows"
|
||||
|
||||
-- Spawning a process should not block any lua thread(s)
|
||||
|
||||
local SLEEP_DURATION = 1 / 4
|
||||
local SLEEP_SAMPLES = 2
|
||||
|
||||
local thread2 = task.delay(30, function()
|
||||
stdio.ewrite("Spawning a sleep process should take a reasonable amount of time\n")
|
||||
task.wait(1)
|
||||
process.exit(1)
|
||||
end)
|
||||
|
||||
local sleepStart = os.clock()
|
||||
local sleepCounter = 0
|
||||
for i = 1, SLEEP_SAMPLES, 1 do
|
||||
task.spawn(function()
|
||||
local args = {
|
||||
-- Sleep command on Windows in Seconds has some weird behavior with decimals ...
|
||||
tostring(SLEEP_DURATION * (IS_WINDOWS and 1000 or 1)),
|
||||
}
|
||||
if IS_WINDOWS 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 IS_WINDOWS then { shell = true } else nil)
|
||||
sleepCounter += 1
|
||||
end)
|
||||
end
|
||||
while sleepCounter < SLEEP_SAMPLES do
|
||||
task.wait()
|
||||
end
|
||||
|
||||
task.cancel(thread2)
|
||||
|
||||
assert(
|
||||
(os.clock() - sleepStart) >= SLEEP_DURATION,
|
||||
"Spawning a process that does blocking sleep did not sleep enough"
|
||||
)
|
28
tests/process/spawn/basic.luau
Normal file
28
tests/process/spawn/basic.luau
Normal file
|
@ -0,0 +1,28 @@
|
|||
local process = require("@lune/process")
|
||||
local stdio = require("@lune/stdio")
|
||||
local task = require("@lune/task")
|
||||
|
||||
-- Spawning a child process should work, with options
|
||||
|
||||
local thread = task.delay(1, function()
|
||||
stdio.ewrite("Spawning a process should take a reasonable amount of time\n")
|
||||
task.wait(1)
|
||||
process.exit(1)
|
||||
end)
|
||||
|
||||
local IS_WINDOWS = process.os == "windows"
|
||||
|
||||
local result = process.spawn(
|
||||
if IS_WINDOWS then "cmd" else "ls",
|
||||
if IS_WINDOWS then { "/c", "dir" } else { "-a" }
|
||||
)
|
||||
|
||||
task.cancel(thread)
|
||||
|
||||
assert(result.ok, "Failed to spawn child process")
|
||||
|
||||
assert(result.stderr == "", "Stderr was not empty")
|
||||
assert(result.stdout ~= "", "Stdout was empty")
|
||||
|
||||
assert(string.find(result.stdout, "Cargo.toml") ~= nil, "Missing Cargo.toml in output")
|
||||
assert(string.find(result.stdout, ".gitignore") ~= nil, "Missing .gitignore in output")
|
54
tests/process/spawn/cwd.luau
Normal file
54
tests/process/spawn/cwd.luau
Normal file
|
@ -0,0 +1,54 @@
|
|||
local process = require("@lune/process")
|
||||
|
||||
local IS_WINDOWS = process.os == "windows"
|
||||
|
||||
local pwdCommand = if IS_WINDOWS then "cmd" else "pwd"
|
||||
local pwdArgs = if IS_WINDOWS then { "/c", "cd" } else {}
|
||||
|
||||
-- Make sure the cwd option actually uses the directory we want
|
||||
local rootPwd = process.spawn(pwdCommand, pwdArgs, {
|
||||
cwd = "/",
|
||||
}).stdout
|
||||
rootPwd = string.gsub(rootPwd, "^%s+", "")
|
||||
rootPwd = string.gsub(rootPwd, "%s+$", "")
|
||||
|
||||
-- Windows: <Drive Letter>:\, Unix: /
|
||||
local expectedRootPwd = if IS_WINDOWS then string.sub(rootPwd, 1, 1) .. ":\\" else "/"
|
||||
if rootPwd ~= expectedRootPwd then
|
||||
error(
|
||||
string.format(
|
||||
"Current working directory for child process was not set correctly!"
|
||||
.. "\nExpected '%s', got '%s'",
|
||||
expectedRootPwd,
|
||||
rootPwd
|
||||
)
|
||||
)
|
||||
end
|
||||
|
||||
-- Setting cwd should not change the cwd of this process
|
||||
|
||||
local pwdBefore = process.spawn(pwdCommand, pwdArgs).stdout
|
||||
process.spawn("ls", {}, {
|
||||
cwd = "/",
|
||||
shell = true,
|
||||
})
|
||||
local pwdAfter = process.spawn(pwdCommand, pwdArgs).stdout
|
||||
assert(pwdBefore == pwdAfter, "Current working directory changed after running child process")
|
||||
|
||||
-- Setting the cwd on a child process should properly
|
||||
-- replace any leading ~ with the users real home dir
|
||||
|
||||
local homeDir1 = process.spawn("echo $HOME", nil, {
|
||||
shell = true,
|
||||
}).stdout
|
||||
|
||||
-- NOTE: 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 IS_WINDOWS then "$pwd.Path" else "pwd", nil, {
|
||||
shell = true,
|
||||
cwd = "~",
|
||||
}).stdout
|
||||
|
||||
assert(#homeDir1 > 0, "Home dir from echo was empty")
|
||||
assert(#homeDir2 > 0, "Home dir from pwd was empty")
|
||||
assert(homeDir1 == homeDir2, "Home dirs did not match when performing tilde substitution")
|
20
tests/process/spawn/shell.luau
Normal file
20
tests/process/spawn/shell.luau
Normal file
|
@ -0,0 +1,20 @@
|
|||
local process = require("@lune/process")
|
||||
|
||||
local IS_WINDOWS = process.os == "windows"
|
||||
|
||||
-- Default shell should be /bin/sh on unix and powershell on Windows,
|
||||
-- note that powershell needs slightly different command flags for ls
|
||||
|
||||
local shellResult = process.spawn("ls", {
|
||||
if IS_WINDOWS then "-Force" else "-a",
|
||||
}, {
|
||||
shell = true,
|
||||
})
|
||||
|
||||
assert(shellResult.ok, "Failed to spawn child process (shell)")
|
||||
|
||||
assert(shellResult.stderr == "", "Stderr was not empty (shell)")
|
||||
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, ".gitignore") ~= nil, "Missing .gitignore in output (shell)")
|
19
tests/process/spawn/stdin.luau
Normal file
19
tests/process/spawn/stdin.luau
Normal file
|
@ -0,0 +1,19 @@
|
|||
local process = require("@lune/process")
|
||||
|
||||
local IS_WINDOWS = process.os == "windows"
|
||||
|
||||
-- Windows uses \r\n (CRLF) and unix uses \n (LF)
|
||||
|
||||
local echoTrail = if IS_WINDOWS then "\r\n" else "\n"
|
||||
local echoMessage = "Hello from child process!"
|
||||
|
||||
-- When passing stdin to powershell on windows we must "accept" using the double newline
|
||||
|
||||
local result = if IS_WINDOWS
|
||||
then process.spawn("powershell", { "echo" }, { stdin = echoMessage .. "\n\n" })
|
||||
else process.spawn("xargs", { "echo" }, { stdin = echoMessage })
|
||||
|
||||
local resultStdout = if IS_WINDOWS
|
||||
then string.sub(result.stdout, #result.stdout - #echoMessage - 1)
|
||||
else result.stdout
|
||||
assert(resultStdout == echoMessage .. echoTrail, "Stdin passing did not return proper output")
|
22
tests/process/spawn/stdio.luau
Normal file
22
tests/process/spawn/stdio.luau
Normal file
|
@ -0,0 +1,22 @@
|
|||
local process = require("@lune/process")
|
||||
|
||||
local IS_WINDOWS = process.os == "windows"
|
||||
|
||||
-- Inheriting stdio & environment variables should work
|
||||
|
||||
local echoMessage = "Hello from child process!"
|
||||
local echoResult = process.spawn("echo", {
|
||||
if IS_WINDOWS then '"$Env:TEST_VAR"' else '"$TEST_VAR"',
|
||||
}, {
|
||||
env = { TEST_VAR = echoMessage },
|
||||
shell = if IS_WINDOWS then "powershell" else "bash",
|
||||
stdio = "inherit",
|
||||
})
|
||||
|
||||
-- Windows uses \r\n (CRLF) and unix uses \n (LF)
|
||||
|
||||
local echoTrail = if IS_WINDOWS then "\r\n" else "\n"
|
||||
assert(
|
||||
echoResult.stdout == (echoMessage .. echoTrail),
|
||||
"Inheriting stdio did not return proper output"
|
||||
)
|
Loading…
Add table
Reference in a new issue