mirror of
https://github.com/nushell/nushell
synced 2025-01-28 21:05:48 +00:00
48a34ffe6d
<!-- if this PR closes one or more issues, you can automatically link the PR with them by using one of the [*linking keywords*](https://docs.github.com/en/issues/tracking-your-work-with-issues/linking-a-pull-request-to-an-issue#linking-a-pull-request-to-an-issue-using-a-keyword), e.g. - this PR should close #xxxx - fixes #xxxx you can also mention related issues, PRs or discussions! --> # Description <!-- Thank you for improving Nushell. Please, check our [contributing guide](../CONTRIBUTING.md) and talk to the core team before making major changes. Description of your pull request goes here. **Provide examples and/or screenshots** if your changes affect the user experience. --> Test was failing with “did you mean” due to the `NEXTEST` env var being present when running tests via `cargo nextest run`. # User-Facing Changes <!-- List of all changes that impact the user experience here. This helps us keep track of breaking changes. --> # 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` to check that you're using the standard code style - `cargo test --workspace` to check that all tests pass (on Windows make sure to [enable developer mode](https://learn.microsoft.com/en-us/windows/apps/get-started/developer-mode-features-and-debugging)) - `cargo run -- -c "use toolkit.nu; toolkit test stdlib"` to run the tests for the standard library > **Note** > from `nushell` you can also use the `toolkit` as follows > ```bash > use toolkit.nu # or use an `env_change` hook to activate it automatically > toolkit check pr > ``` --> # 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. -->
217 lines
5.1 KiB
Rust
217 lines
5.1 KiB
Rust
use super::support::Trusted;
|
|
|
|
use nu_test_support::fs::Stub::FileWithContent;
|
|
use nu_test_support::playground::Playground;
|
|
use nu_test_support::{nu, nu_repl_code};
|
|
use pretty_assertions::assert_eq;
|
|
use serial_test::serial;
|
|
|
|
#[test]
|
|
fn env_shorthand() {
|
|
let actual = nu!("
|
|
FOO=bar echo $env.FOO
|
|
");
|
|
assert_eq!(actual.out, "bar");
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_with_equals() {
|
|
let actual = nu!("
|
|
RUST_LOG=my_module=info $env.RUST_LOG
|
|
");
|
|
assert_eq!(actual.out, "my_module=info");
|
|
}
|
|
|
|
#[test]
|
|
fn env_shorthand_with_interpolation() {
|
|
let actual = nu!(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!("
|
|
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!("
|
|
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!("
|
|
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!("
|
|
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!("
|
|
FOO=bar BAR=baz $env.FOO + $env.BAR
|
|
");
|
|
assert_eq!(actual.out, "barbaz");
|
|
}
|
|
|
|
#[test]
|
|
fn env_assignment() {
|
|
let actual = nu!(r#"
|
|
$env.FOOBAR = "barbaz"; $env.FOOBAR
|
|
"#);
|
|
assert_eq!(actual.out, "barbaz");
|
|
}
|
|
|
|
#[test]
|
|
fn env_assignment_with_if() {
|
|
let actual = nu!(r#"$env.FOOBAR = if 3 == 4 { "bar" } else { "baz" }; $env.FOOBAR"#);
|
|
assert_eq!(actual.out, "baz");
|
|
}
|
|
|
|
#[test]
|
|
fn env_assignment_with_match() {
|
|
let actual = nu!(r#"$env.FOOBAR = match 1 { 1 => { 'yes!' }, _ => { 'no!' } }; $env.FOOBAR"#);
|
|
assert_eq!(actual.out, "yes!");
|
|
}
|
|
|
|
#[test]
|
|
fn mutate_env_file_pwd_env_var_fails() {
|
|
let actual = nu!("$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!("load-env { FILE_PWD : 'foo' }");
|
|
|
|
assert!(actual.err.contains("automatic_env_var_set_manually"));
|
|
}
|
|
|
|
#[test]
|
|
fn load_env_pwd_env_var_fails() {
|
|
let actual = nu!("load-env { PWD : 'foo' }");
|
|
|
|
assert!(actual.err.contains("automatic_env_var_set_manually"));
|
|
}
|
|
|
|
#[test]
|
|
fn passes_with_env_env_var_to_external_process() {
|
|
let actual = nu!("
|
|
with-env { FOO: foo } {nu --testbin echo_env FOO}
|
|
");
|
|
assert_eq!(actual.out, "foo");
|
|
}
|
|
|
|
#[test]
|
|
fn hides_environment_from_child() {
|
|
let actual = nu!(r#"
|
|
$env.TEST = 1; ^$nu.current-exe -c "hide-env TEST; ^$nu.current-exe -c '$env.TEST'"
|
|
"#);
|
|
assert!(actual.out.is_empty());
|
|
assert!(actual.err.contains("column_not_found") || actual.err.contains("name_not_found"));
|
|
}
|
|
|
|
#[test]
|
|
fn has_file_pwd() {
|
|
Playground::setup("has_file_pwd", |dirs, sandbox| {
|
|
sandbox.with_files(&[FileWithContent("spam.nu", "$env.FILE_PWD")]);
|
|
|
|
let actual = nu!(cwd: dirs.test(), "nu spam.nu");
|
|
|
|
assert!(actual.out.ends_with("has_file_pwd"));
|
|
})
|
|
}
|
|
|
|
#[test]
|
|
fn has_file_loc() {
|
|
Playground::setup("has_file_pwd", |dirs, sandbox| {
|
|
sandbox.with_files(&[FileWithContent("spam.nu", "$env.CURRENT_FILE")]);
|
|
|
|
let actual = nu!(cwd: dirs.test(), "nu spam.nu");
|
|
|
|
assert!(actual.out.ends_with("spam.nu"));
|
|
})
|
|
}
|
|
|
|
// 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(&[FileWithContent(
|
|
".nu-env",
|
|
r#"[env]
|
|
FOO = "foo"
|
|
"#,
|
|
)]);
|
|
|
|
let actual = Trusted::in_path(&dirs, || {
|
|
nu!(cwd: dirs.test(), "
|
|
nu --testbin echo_env FOO
|
|
")
|
|
});
|
|
|
|
assert_eq!(actual.out, "foo");
|
|
})
|
|
}
|
|
|
|
#[test]
|
|
fn hides_env_in_block() {
|
|
let inp = &[
|
|
"$env.foo = 'foo'",
|
|
"hide-env foo",
|
|
"let b = {|| $env.foo }",
|
|
"do $b",
|
|
];
|
|
|
|
let actual = nu!(&inp.join("; "));
|
|
let actual_repl = nu!(nu_repl_code(inp));
|
|
|
|
assert!(actual.err.contains("column_not_found"));
|
|
assert!(actual_repl.err.contains("column_not_found"));
|
|
}
|
|
|
|
#[test]
|
|
fn env_var_not_var() {
|
|
let actual = nu!("
|
|
echo $PWD
|
|
");
|
|
assert!(actual.err.contains("use $env.PWD instead of $PWD"));
|
|
}
|
|
|
|
#[test]
|
|
fn env_var_case_insensitive() {
|
|
let actual = nu!("
|
|
$env.foo = 111
|
|
print $env.Foo
|
|
$env.FOO = 222
|
|
print $env.foo
|
|
");
|
|
assert!(actual.out.contains("111"));
|
|
assert!(actual.out.contains("222"));
|
|
}
|