mirror of
https://github.com/nushell/nushell
synced 2025-01-23 18:35:17 +00:00
b6bdadbc6f
# Description * As discussed in the comments in #11954, this suppresses the index column on `cal` output. It does that by running `table -i false` on the results by default. * Added new `--as-table/-t` flag to revert to the old behavior and output the calendar as structured data * Updated existing tests to use `--as-table` * Added new tests against the string output * Updated `length` test which also used `cal` * Added new example for `--as-table`, with result # User-Facing Changes ## Breaking change The *default* `cal` output has changed from a `list` to a `string`. To obtain structured data from `cal`, use the new `--as-table/-t` flag. # Tests + Formatting - 🟢 `toolkit fmt` - 🟢 `toolkit clippy` - 🟢 `toolkit test` - 🟢 `toolkit test stdlib` # 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. -->
105 lines
3 KiB
Rust
105 lines
3 KiB
Rust
use nu_test_support::{nu, pipeline};
|
|
|
|
// Tests against table/structured data
|
|
#[test]
|
|
fn cal_full_year() {
|
|
let actual = nu!("cal -t -y --full-year 2010 | first | to json -r");
|
|
|
|
let first_week_2010_json =
|
|
r#"{"year":2010,"su":null,"mo":null,"tu":null,"we":null,"th":null,"fr":1,"sa":2}"#;
|
|
|
|
assert_eq!(actual.out, first_week_2010_json);
|
|
}
|
|
|
|
#[test]
|
|
fn cal_february_2020_leap_year() {
|
|
let actual = nu!(pipeline(
|
|
r#"
|
|
cal --as-table -ym --full-year 2020 --month-names | where month == "february" | to json -r
|
|
"#
|
|
));
|
|
|
|
let cal_february_json = r#"[{"year":2020,"month":"february","su":null,"mo":null,"tu":null,"we":null,"th":null,"fr":null,"sa":1},{"year":2020,"month":"february","su":2,"mo":3,"tu":4,"we":5,"th":6,"fr":7,"sa":8},{"year":2020,"month":"february","su":9,"mo":10,"tu":11,"we":12,"th":13,"fr":14,"sa":15},{"year":2020,"month":"february","su":16,"mo":17,"tu":18,"we":19,"th":20,"fr":21,"sa":22},{"year":2020,"month":"february","su":23,"mo":24,"tu":25,"we":26,"th":27,"fr":28,"sa":29}]"#;
|
|
|
|
assert_eq!(actual.out, cal_february_json);
|
|
}
|
|
|
|
#[test]
|
|
fn cal_fr_the_thirteenths_in_2015() {
|
|
let actual = nu!(pipeline(
|
|
r#"
|
|
cal --as-table --full-year 2015 | default 0 fr | where fr == 13 | length
|
|
"#
|
|
));
|
|
|
|
assert!(actual.out.contains('3'));
|
|
}
|
|
|
|
#[test]
|
|
fn cal_rows_in_2020() {
|
|
let actual = nu!(pipeline(
|
|
r#"
|
|
cal --as-table --full-year 2020 | length
|
|
"#
|
|
));
|
|
|
|
assert!(actual.out.contains("62"));
|
|
}
|
|
|
|
#[test]
|
|
fn cal_week_day_start_mo() {
|
|
let actual = nu!(pipeline(
|
|
r#"
|
|
cal --as-table --full-year 2020 -m --month-names --week-start mo | where month == january | to json -r
|
|
"#
|
|
));
|
|
|
|
let cal_january_json = r#"[{"month":"january","mo":null,"tu":null,"we":1,"th":2,"fr":3,"sa":4,"su":5},{"month":"january","mo":6,"tu":7,"we":8,"th":9,"fr":10,"sa":11,"su":12},{"month":"january","mo":13,"tu":14,"we":15,"th":16,"fr":17,"sa":18,"su":19},{"month":"january","mo":20,"tu":21,"we":22,"th":23,"fr":24,"sa":25,"su":26},{"month":"january","mo":27,"tu":28,"we":29,"th":30,"fr":31,"sa":null,"su":null}]"#;
|
|
|
|
assert_eq!(actual.out, cal_january_json);
|
|
}
|
|
|
|
#[test]
|
|
fn cal_sees_pipeline_year() {
|
|
let actual = nu!(pipeline(
|
|
r#"
|
|
cal --as-table --full-year 1020 | get mo | first 4 | to json -r
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "[null,3,10,17]");
|
|
}
|
|
|
|
// Tests against default string output
|
|
#[test]
|
|
fn cal_is_string() {
|
|
let actual = nu!(pipeline(
|
|
r#"
|
|
cal | describe
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "string (stream)");
|
|
}
|
|
|
|
#[test]
|
|
fn cal_year_num_lines() {
|
|
let actual = nu!(pipeline(
|
|
r#"
|
|
cal --full-year 2024 | lines | length
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "68");
|
|
}
|
|
|
|
#[test]
|
|
fn cal_week_start_string() {
|
|
let actual = nu!(pipeline(
|
|
r#"
|
|
cal --week-start fr | lines | get 1 | split row '│' | get 2 | ansi strip | str trim
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "sa");
|
|
}
|