forked from extern/nushell
f1000a17b4
# Description When running `nu script.nu`, the `$env.FILE_PWD` will be set to the directory where the script is. Also makes the error message a bit nicer: ``` > target/debug/nu asdihga Error: nu:🐚:file_not_found (link) × File not found ╭─[source:1:1] 1 │ nu · ▲ · ╰── Could not access file 'asdihga': "No such file or directory (os error 2)" ╰──── ``` # User-Facing Changes `FILE_PWD` environment variable is available when running a script as `nu script.nu`. # Tests + Formatting Don't forget to add tests that cover your changes. Make sure you've run and fixed any issues with these commands: - `cargo fmt --all -- --check` to check standard code formatting (`cargo fmt --all` applies these changes) - `cargo clippy --workspace -- -D warnings -D clippy::unwrap_used -A clippy::needless_collect` to check that you're using the standard code style - `cargo test --workspace` to check that all tests pass # After Submitting If your PR had any user-facing changes, update [the documentation](https://github.com/nushell/nushell.github.io) after the PR is merged, if necessary. This will help us keep the docs up to date.
154 lines
3.7 KiB
Rust
154 lines
3.7 KiB
Rust
use super::support::Trusted;
|
|
|
|
use nu_test_support::fs::Stub::FileWithContent;
|
|
use nu_test_support::nu;
|
|
use nu_test_support::playground::Playground;
|
|
|
|
use serial_test::serial;
|
|
|
|
#[test]
|
|
fn env_shorthand() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
FOO=bar echo $env.FOO
|
|
"#);
|
|
assert_eq!(actual.out, "bar");
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_with_equals() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
RUST_LOG=my_module=info $env.RUST_LOG
|
|
"#);
|
|
assert_eq!(actual.out, "my_module=info");
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_with_interpolation() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
let num = 123
|
|
FOO=$"($num) bar" echo $env.FOO
|
|
"#);
|
|
assert_eq!(actual.out, "123 bar");
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_with_comma_equals() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
RUST_LOG=info,my_module=info $env.RUST_LOG
|
|
"#);
|
|
assert_eq!(actual.out, "info,my_module=info");
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_with_comma_colons_equals() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
RUST_LOG=info,my_module=info,lib_crate::lib_mod=trace $env.RUST_LOG
|
|
"#);
|
|
assert_eq!(actual.out, "info,my_module=info,lib_crate::lib_mod=trace");
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_multi_second_with_comma_colons_equals() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
FOO=bar RUST_LOG=info,my_module=info,lib_crate::lib_mod=trace $env.FOO + $env.RUST_LOG
|
|
"#);
|
|
assert_eq!(
|
|
actual.out,
|
|
"barinfo,my_module=info,lib_crate::lib_mod=trace"
|
|
);
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_multi_first_with_comma_colons_equals() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
RUST_LOG=info,my_module=info,lib_crate::lib_mod=trace FOO=bar $env.FOO + $env.RUST_LOG
|
|
"#);
|
|
assert_eq!(
|
|
actual.out,
|
|
"barinfo,my_module=info,lib_crate::lib_mod=trace"
|
|
);
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_multi() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
FOO=bar BAR=baz $env.FOO + $env.BAR
|
|
"#);
|
|
assert_eq!(actual.out, "barbaz");
|
|
}
|
|
|
|
#[test]
|
|
fn env_assignment() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
$env.FOOBAR = "barbaz"; $env.FOOBAR
|
|
"#);
|
|
assert_eq!(actual.out, "barbaz");
|
|
}
|
|
|
|
#[test]
|
|
fn let_env_file_pwd_env_var_fails() {
|
|
let actual = nu!(cwd: ".", r#"let-env FILE_PWD = 'foo'"#);
|
|
|
|
assert!(actual.err.contains("automatic_env_var_set_manually"));
|
|
}
|
|
|
|
#[test]
|
|
fn load_env_file_pwd_env_var_fails() {
|
|
let actual = nu!(cwd: ".", r#"load-env { FILE_PWD : 'foo' }"#);
|
|
|
|
assert!(actual.err.contains("automatic_env_var_set_manually"));
|
|
}
|
|
|
|
// FIXME: for some reason Nu is attempting to execute foo in `let-env FOO = foo`
|
|
#[ignore]
|
|
#[test]
|
|
fn passes_let_env_env_var_to_external_process() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
let-env FOO = foo
|
|
nu --testbin echo_env FOO
|
|
"#);
|
|
assert_eq!(actual.out, "foo");
|
|
}
|
|
|
|
#[test]
|
|
fn passes_with_env_env_var_to_external_process() {
|
|
let actual = nu!(cwd: ".", r#"
|
|
with-env [FOO foo] {nu --testbin echo_env FOO}
|
|
"#);
|
|
assert_eq!(actual.out, "foo");
|
|
}
|
|
|
|
#[test]
|
|
fn has_file_pwd() {
|
|
Playground::setup("has_file_pwd", |dirs, sandbox| {
|
|
sandbox.with_files(vec![FileWithContent("spam.nu", "$env.FILE_PWD")]);
|
|
|
|
let actual = nu!(cwd: dirs.test(), "nu spam.nu");
|
|
|
|
assert!(actual.out.ends_with("has_file_pwd"));
|
|
})
|
|
}
|
|
|
|
// FIXME: autoenv not currently implemented
|
|
#[ignore]
|
|
#[test]
|
|
#[serial]
|
|
fn passes_env_from_local_cfg_to_external_process() {
|
|
Playground::setup("autoenv_dir", |dirs, sandbox| {
|
|
sandbox.with_files(vec![FileWithContent(
|
|
".nu-env",
|
|
r#"[env]
|
|
FOO = "foo"
|
|
"#,
|
|
)]);
|
|
|
|
let actual = Trusted::in_path(&dirs, || {
|
|
nu!(cwd: dirs.test(), r#"
|
|
nu --testbin echo_env FOO
|
|
"#)
|
|
});
|
|
|
|
assert_eq!(actual.out, "foo");
|
|
})
|
|
}
|