mirror of
https://github.com/nushell/nushell
synced 2025-01-28 04:45:18 +00:00
Fix(tests/nu-command): remove unnecessary cwd() and pipeline(), etc (#8711)
# Description This PR aims to cover the tests under nu-command as part of this issue #8670 to clean up any unnecessary wrapping funcs like `cwd(".")` or `pipeline()`, etc. This PR is still WIP and opening as draft to get first impressions and feedback on a few tests before I go on changing more. # User-Facing Changes None # Tests + Formatting None # After Submitting None --------- Signed-off-by: Harshal Chaudhari <harshal.chaudhary@gmail.com> Co-authored-by: Reilly Wood <reilly.wood@icloud.com>
This commit is contained in:
parent
61fa826159
commit
3fab427383
4 changed files with 35 additions and 156 deletions
|
@ -49,47 +49,23 @@ fn alias_hiding_2() {
|
||||||
#[test]
|
#[test]
|
||||||
fn alias_fails_with_invalid_name() {
|
fn alias_fails_with_invalid_name() {
|
||||||
let err_msg = "name can't be a number, a filesize, or contain a hash # or caret ^";
|
let err_msg = "name can't be a number, a filesize, or contain a hash # or caret ^";
|
||||||
let actual = nu!(
|
let actual = nu!(r#" alias 1234 = echo "test" "#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
|
||||||
alias 1234 = echo "test"
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
assert!(actual.err.contains(err_msg));
|
assert!(actual.err.contains(err_msg));
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!(r#" alias 5gib = echo "test" "#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
|
||||||
alias 5gib = echo "test"
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
assert!(actual.err.contains(err_msg));
|
assert!(actual.err.contains(err_msg));
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!(r#" alias "te#t" = echo "test" "#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
|
||||||
alias "te#t" = echo "test"
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
assert!(actual.err.contains(err_msg));
|
assert!(actual.err.contains(err_msg));
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!(r#" alias ^foo = echo "bar" "#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
|
||||||
alias ^foo = echo "bar"
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
assert!(actual.err.contains(err_msg));
|
assert!(actual.err.contains(err_msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn cant_alias_keyword() {
|
fn cant_alias_keyword() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#" alias ou = let "#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
|
||||||
alias ou = let
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
assert!(actual.err.contains("cant_alias_keyword"));
|
assert!(actual.err.contains("cant_alias_keyword"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,8 +2,7 @@ use nu_test_support::{nu, pipeline};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn checks_all_rows_are_true() {
|
fn checks_all_rows_are_true() {
|
||||||
let actual = nu!(
|
let actual = nu!(pipeline(
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
r#"
|
||||||
echo [ "Andrés", "Andrés", "Andrés" ]
|
echo [ "Andrés", "Andrés", "Andrés" ]
|
||||||
| all {|it| $it == "Andrés" }
|
| all {|it| $it == "Andrés" }
|
||||||
|
@ -15,32 +14,21 @@ fn checks_all_rows_are_true() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn checks_all_rows_are_false_with_param() {
|
fn checks_all_rows_are_false_with_param() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#" [1, 2, 3, 4] | all { |a| $a >= 5 } "#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
|
||||||
[1, 2, 3, 4] | all { |a| $a >= 5 }
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "false");
|
assert_eq!(actual.out, "false");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn checks_all_rows_are_true_with_param() {
|
fn checks_all_rows_are_true_with_param() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#" [1, 2, 3, 4] | all { |a| $a < 5 } "#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
|
||||||
[1, 2, 3, 4] | all { |a| $a < 5 }
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "true");
|
assert_eq!(actual.out, "true");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn checks_all_columns_of_a_table_is_true() {
|
fn checks_all_columns_of_a_table_is_true() {
|
||||||
let actual = nu!(
|
let actual = nu!(pipeline(
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
r#"
|
||||||
echo [
|
echo [
|
||||||
[ first_name, last_name, rusty_at, likes ];
|
[ first_name, last_name, rusty_at, likes ];
|
||||||
|
@ -59,8 +47,7 @@ fn checks_all_columns_of_a_table_is_true() {
|
||||||
#[test]
|
#[test]
|
||||||
fn checks_if_all_returns_error_with_invalid_command() {
|
fn checks_if_all_returns_error_with_invalid_command() {
|
||||||
// Using `with-env` to remove `st` possibly being an external program
|
// Using `with-env` to remove `st` possibly being an external program
|
||||||
let actual = nu!(
|
let actual = nu!(pipeline(
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
r#"
|
||||||
with-env {PATH: ""} {
|
with-env {PATH: ""} {
|
||||||
[red orange yellow green blue purple] | all {|it| ($it | st length) > 4 }
|
[red orange yellow green blue purple] | all {|it| ($it | st length) > 4 }
|
||||||
|
@ -73,50 +60,35 @@ fn checks_if_all_returns_error_with_invalid_command() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn works_with_1_param_blocks() {
|
fn works_with_1_param_blocks() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[1 2 3] | all {|e| print $e | true }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[1 2 3] | all {|e| print $e | true }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "123true");
|
assert_eq!(actual.out, "123true");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn works_with_0_param_blocks() {
|
fn works_with_0_param_blocks() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[1 2 3] | all {|| print $in | true }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[1 2 3] | all {|| print $in | true }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "123true");
|
assert_eq!(actual.out, "123true");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn early_exits_with_1_param_blocks() {
|
fn early_exits_with_1_param_blocks() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[1 2 3] | all {|e| print $e | false }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[1 2 3] | all {|e| print $e | false }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "1false");
|
assert_eq!(actual.out, "1false");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn early_exits_with_0_param_blocks() {
|
fn early_exits_with_0_param_blocks() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[1 2 3] | all {|| print $in | false }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[1 2 3] | all {|| print $in | false }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "1false");
|
assert_eq!(actual.out, "1false");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn all_uses_enumerate_index() {
|
fn all_uses_enumerate_index() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[7 8 9] | enumerate | all {|el| print $el.index | true }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[7 8 9] | enumerate | all {|el| print $el.index | true }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "012true");
|
assert_eq!(actual.out, "012true");
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,8 +2,7 @@ use nu_test_support::{nu, pipeline};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn checks_any_row_is_true() {
|
fn checks_any_row_is_true() {
|
||||||
let actual = nu!(
|
let actual = nu!(pipeline(
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
r#"
|
||||||
echo [ "Ecuador", "USA", "New Zealand" ]
|
echo [ "Ecuador", "USA", "New Zealand" ]
|
||||||
| any {|it| $it == "New Zealand" }
|
| any {|it| $it == "New Zealand" }
|
||||||
|
@ -15,8 +14,7 @@ fn checks_any_row_is_true() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn checks_any_column_of_a_table_is_true() {
|
fn checks_any_column_of_a_table_is_true() {
|
||||||
let actual = nu!(
|
let actual = nu!(pipeline(
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
r#"
|
||||||
echo [
|
echo [
|
||||||
[ first_name, last_name, rusty_at, likes ];
|
[ first_name, last_name, rusty_at, likes ];
|
||||||
|
@ -35,8 +33,7 @@ fn checks_any_column_of_a_table_is_true() {
|
||||||
#[test]
|
#[test]
|
||||||
fn checks_if_any_returns_error_with_invalid_command() {
|
fn checks_if_any_returns_error_with_invalid_command() {
|
||||||
// Using `with-env` to remove `st` possibly being an external program
|
// Using `with-env` to remove `st` possibly being an external program
|
||||||
let actual = nu!(
|
let actual = nu!(pipeline(
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"
|
r#"
|
||||||
with-env {PATH: ""} {
|
with-env {PATH: ""} {
|
||||||
[red orange yellow green blue purple] | any {|it| ($it | st length) > 4 }
|
[red orange yellow green blue purple] | any {|it| ($it | st length) > 4 }
|
||||||
|
@ -49,50 +46,35 @@ fn checks_if_any_returns_error_with_invalid_command() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn works_with_1_param_blocks() {
|
fn works_with_1_param_blocks() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[1 2 3] | any {|e| print $e | false }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[1 2 3] | any {|e| print $e | false }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "123false");
|
assert_eq!(actual.out, "123false");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn works_with_0_param_blocks() {
|
fn works_with_0_param_blocks() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[1 2 3] | any {|| print $in | false }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[1 2 3] | any {|| print $in | false }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "123false");
|
assert_eq!(actual.out, "123false");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn early_exits_with_1_param_blocks() {
|
fn early_exits_with_1_param_blocks() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[1 2 3] | any {|e| print $e | true }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[1 2 3] | any {|e| print $e | true }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "1true");
|
assert_eq!(actual.out, "1true");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn early_exits_with_0_param_blocks() {
|
fn early_exits_with_0_param_blocks() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[1 2 3] | any {|| print $in | true }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[1 2 3] | any {|| print $in | true }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "1true");
|
assert_eq!(actual.out, "1true");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn any_uses_enumerate_index() {
|
fn any_uses_enumerate_index() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[7 8 9] | enumerate | any {|el| print $el.index | false }"#);
|
||||||
cwd: ".", pipeline(
|
|
||||||
r#"[7 8 9] | enumerate | any {|el| print $el.index | false }"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "012false");
|
assert_eq!(actual.out, "012false");
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,13 +24,7 @@ fn fetches_a_row() {
|
||||||
"#,
|
"#,
|
||||||
)]);
|
)]);
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!( cwd: dirs.test(), "open sample.toml | get nu_party_venue");
|
||||||
cwd: dirs.test(), pipeline(
|
|
||||||
r#"
|
|
||||||
open sample.toml
|
|
||||||
| get nu_party_venue
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "zion");
|
assert_eq!(actual.out, "zion");
|
||||||
})
|
})
|
||||||
|
@ -50,13 +44,7 @@ fn fetches_by_index() {
|
||||||
"#,
|
"#,
|
||||||
)]);
|
)]);
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!( cwd: dirs.test(), "open sample.toml | get package.authors.2");
|
||||||
cwd: dirs.test(), pipeline(
|
|
||||||
r#"
|
|
||||||
open sample.toml
|
|
||||||
| get package.authors.2
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "Andrés N. Robalino <andres@androbtech.com>");
|
assert_eq!(actual.out, "Andrés N. Robalino <andres@androbtech.com>");
|
||||||
})
|
})
|
||||||
|
@ -73,13 +61,7 @@ fn fetches_by_column_path() {
|
||||||
"#,
|
"#,
|
||||||
)]);
|
)]);
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!( cwd: dirs.test(), "open sample.toml | get package.name");
|
||||||
cwd: dirs.test(), pipeline(
|
|
||||||
r#"
|
|
||||||
open sample.toml
|
|
||||||
| get package.name
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "nu");
|
assert_eq!(actual.out, "nu");
|
||||||
})
|
})
|
||||||
|
@ -97,14 +79,7 @@ fn column_paths_are_either_double_quoted_or_regular_unquoted_words_separated_by_
|
||||||
"#,
|
"#,
|
||||||
)]);
|
)]);
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!( cwd: dirs.test(), r#"open sample.toml | get package."9999" | length"#);
|
||||||
cwd: dirs.test(), pipeline(
|
|
||||||
r#"
|
|
||||||
open sample.toml
|
|
||||||
| get package."9999"
|
|
||||||
| length
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "3");
|
assert_eq!(actual.out, "3");
|
||||||
})
|
})
|
||||||
|
@ -132,11 +107,11 @@ fn fetches_more_than_one_column_path() {
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!(
|
||||||
cwd: dirs.test(), pipeline(
|
cwd: dirs.test(), pipeline(
|
||||||
r#"
|
"
|
||||||
open sample.toml
|
open sample.toml
|
||||||
| get fortune_tellers.2.name fortune_tellers.0.name fortune_tellers.1.name
|
| get fortune_tellers.2.name fortune_tellers.0.name fortune_tellers.1.name
|
||||||
| get 2
|
| get 2
|
||||||
"#
|
"
|
||||||
));
|
));
|
||||||
|
|
||||||
assert_eq!(actual.out, "JT");
|
assert_eq!(actual.out, "JT");
|
||||||
|
@ -156,13 +131,7 @@ fn errors_fetching_by_column_not_present() {
|
||||||
"#,
|
"#,
|
||||||
)]);
|
)]);
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!( cwd: dirs.test(), "open sample.toml | get taco");
|
||||||
cwd: dirs.test(), pipeline(
|
|
||||||
r#"
|
|
||||||
open sample.toml
|
|
||||||
| get taco
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert!(actual.err.contains("Name not found"),);
|
assert!(actual.err.contains("Name not found"),);
|
||||||
assert!(actual.err.contains("did you mean 'tacos'"),);
|
assert!(actual.err.contains("did you mean 'tacos'"),);
|
||||||
|
@ -180,13 +149,7 @@ fn errors_fetching_by_column_using_a_number() {
|
||||||
"#,
|
"#,
|
||||||
)]);
|
)]);
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!( cwd: dirs.test(), "open sample.toml | get spanish_lesson.0");
|
||||||
cwd: dirs.test(), pipeline(
|
|
||||||
r#"
|
|
||||||
open sample.toml
|
|
||||||
| get spanish_lesson.0
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert!(actual.err.contains("Type mismatch"),);
|
assert!(actual.err.contains("Type mismatch"),);
|
||||||
})
|
})
|
||||||
|
@ -204,12 +167,7 @@ fn errors_fetching_by_index_out_of_bounds() {
|
||||||
)]);
|
)]);
|
||||||
|
|
||||||
let actual = nu!(
|
let actual = nu!(
|
||||||
cwd: dirs.test(), pipeline(
|
cwd: dirs.test(), " open sample.toml | get spanish_lesson.sentence_words.3 ");
|
||||||
r#"
|
|
||||||
open sample.toml
|
|
||||||
| get spanish_lesson.sentence_words.3
|
|
||||||
"#
|
|
||||||
));
|
|
||||||
|
|
||||||
assert!(actual.err.contains("Row number too large (max: 2)"),);
|
assert!(actual.err.contains("Row number too large (max: 2)"),);
|
||||||
assert!(actual.err.contains("too large"),);
|
assert!(actual.err.contains("too large"),);
|
||||||
|
@ -234,23 +192,14 @@ fn quoted_column_access() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn get_does_not_delve_too_deep_in_nested_lists() {
|
fn get_does_not_delve_too_deep_in_nested_lists() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#"[[{foo: bar}]] | get foo"#);
|
||||||
cwd: ".",
|
|
||||||
r#"[[{foo: bar}]] | get foo"#
|
|
||||||
);
|
|
||||||
|
|
||||||
assert!(actual.err.contains("cannot find column"));
|
assert!(actual.err.contains("cannot find column"));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn ignore_errors_works() {
|
fn ignore_errors_works() {
|
||||||
let actual = nu!(
|
let actual = nu!(r#" let path = "foo"; {} | get -i $path | to nuon "#);
|
||||||
cwd: ".",
|
|
||||||
r#"
|
|
||||||
let path = "foo";
|
|
||||||
{} | get -i $path | to nuon
|
|
||||||
"#
|
|
||||||
);
|
|
||||||
|
|
||||||
assert_eq!(actual.out, "null");
|
assert_eq!(actual.out, "null");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue