diff --git a/crates/nu-command/src/env/load_env.rs b/crates/nu-command/src/env/load_env.rs index 9c9dff82a8..4040a5b1dc 100644 --- a/crates/nu-command/src/env/load_env.rs +++ b/crates/nu-command/src/env/load_env.rs @@ -47,10 +47,7 @@ impl Command for LoadEnv { } if env_var == "PWD" { - let cwd = current_dir(engine_state, stack)?; - let rhs = rhs.as_string()?; - let rhs = nu_path::expand_path_with(rhs, cwd); - stack.add_env_var(env_var, Value::string(rhs.to_string_lossy(), call.head)); + return Err(ShellError::AutomaticEnvVarSetManually(env_var, call.head)); } else { stack.add_env_var(env_var, rhs); } diff --git a/tests/shell/environment/env.rs b/tests/shell/environment/env.rs index 8bf5ee854b..0cad3caed2 100644 --- a/tests/shell/environment/env.rs +++ b/tests/shell/environment/env.rs @@ -99,6 +99,13 @@ fn load_env_file_pwd_env_var_fails() { assert!(actual.err.contains("automatic_env_var_set_manually")); } +#[test] +fn load_env_pwd_env_var_fails() { + let actual = nu!(cwd: ".", r#"load-env { 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]