forked from extern/nushell
7221eb7f39
I have changed `assert!(a == b)` calls to `assert_eq!(a, b)`, which give better error messages. Similarly for `assert!(a != b)` and `assert_ne!(a, b)`. Basically all instances were comparing primitives (string slices or integers), so there is no loss of generality from special-case macros, I have also fixed a number of typos in comments, variable names, and a few user-facing messages.
35 lines
926 B
Rust
35 lines
926 B
Rust
use nu_test_support::nu;
|
|
|
|
#[test]
|
|
fn while_sum() {
|
|
let actual = nu!(
|
|
cwd: ".",
|
|
"mut total = 0; mut x = 0; while $x <= 10 { $total = $total + $x; $x = $x + 1 }; $total"
|
|
);
|
|
|
|
assert_eq!(actual.out, "55");
|
|
}
|
|
|
|
#[test]
|
|
fn while_auto_print_in_each_iteration() {
|
|
let actual = nu!(
|
|
cwd: ".",
|
|
"mut total = 0; while $total < 2 { $total = $total + 1; echo 1 }"
|
|
);
|
|
// Note: nu! macro auto replace "\n" and "\r\n" with ""
|
|
// so our output will be `11`
|
|
// that's ok, our main concern is it auto print value in each iteration.
|
|
assert_eq!(actual.out, "11");
|
|
}
|
|
|
|
#[test]
|
|
fn while_break_on_external_failed() {
|
|
let actual = nu!(
|
|
cwd: ".",
|
|
"mut total = 0; while $total < 2 { $total = $total + 1; echo 1; nu --testbin fail }"
|
|
);
|
|
// Note: nu! macro auto replace "\n" and "\r\n" with ""
|
|
// so our output will be `1`
|
|
assert_eq!(actual.out, "1");
|
|
}
|