2020-05-07 13:03:43 +02:00
|
|
|
use nu_test_support::{nu, pipeline};
|
2019-12-15 17:15:06 +01:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn groups() {
|
2023-11-29 23:21:34 +01:00
|
|
|
let sample = r#"
|
|
|
|
[[first_name, last_name, rusty_at, type];
|
|
|
|
[Andrés, Robalino, "10/11/2013", A],
|
|
|
|
[JT, Turner, "10/12/2013", B],
|
|
|
|
[Yehuda, Katz, "10/11/2013", A]]
|
|
|
|
"#;
|
2019-12-15 17:15:06 +01:00
|
|
|
|
2023-11-29 23:21:34 +01:00
|
|
|
let actual = nu!(pipeline(&format!(
|
|
|
|
r#"
|
|
|
|
{sample}
|
2019-12-15 17:15:06 +01:00
|
|
|
| group-by rusty_at
|
|
|
|
| get "10/11/2013"
|
2021-03-13 22:46:40 +01:00
|
|
|
| length
|
2019-12-15 17:15:06 +01:00
|
|
|
"#
|
2023-11-29 23:21:34 +01:00
|
|
|
)));
|
2019-12-15 17:15:06 +01:00
|
|
|
|
2023-11-29 23:21:34 +01:00
|
|
|
assert_eq!(actual.out, "2");
|
2019-12-15 17:15:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2020-07-14 15:45:19 +02:00
|
|
|
fn errors_if_given_unknown_column_name() {
|
2023-11-29 23:21:34 +01:00
|
|
|
let sample = r#"
|
2020-07-14 15:45:19 +02:00
|
|
|
{
|
|
|
|
"nu": {
|
|
|
|
"committers": [
|
|
|
|
{"name": "Andrés N. Robalino"},
|
2023-03-15 06:54:55 +01:00
|
|
|
{"name": "JT Turner"},
|
2020-07-14 15:45:19 +02:00
|
|
|
{"name": "Yehuda Katz"}
|
|
|
|
],
|
|
|
|
"releases": [
|
|
|
|
{"version": "0.2"}
|
|
|
|
{"version": "0.8"},
|
|
|
|
{"version": "0.9999999"}
|
|
|
|
],
|
|
|
|
"0xATYKARNU": [
|
|
|
|
["Th", "e", " "],
|
|
|
|
["BIG", " ", "UnO"],
|
|
|
|
["punto", "cero"]
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
2023-11-29 23:21:34 +01:00
|
|
|
"#;
|
2020-07-14 15:45:19 +02:00
|
|
|
|
2023-11-29 23:21:34 +01:00
|
|
|
let actual = nu!(pipeline(&format!(
|
|
|
|
r#"
|
|
|
|
'{sample}'
|
|
|
|
| from json
|
|
|
|
| group-by {{|| get nu.releases.version }}
|
2020-07-14 15:45:19 +02:00
|
|
|
"#
|
2023-11-29 23:21:34 +01:00
|
|
|
)));
|
2020-07-14 15:45:19 +02:00
|
|
|
|
2023-11-29 23:21:34 +01:00
|
|
|
assert!(actual
|
|
|
|
.err
|
|
|
|
.contains("requires a table with one value for grouping"));
|
2020-07-14 15:45:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2023-05-18 01:34:44 +02:00
|
|
|
fn errors_if_column_not_found() {
|
2023-11-29 23:21:34 +01:00
|
|
|
let sample = r#"
|
|
|
|
[[first_name, last_name, rusty_at, type];
|
|
|
|
[Andrés, Robalino, "10/11/2013", A],
|
|
|
|
[JT, Turner, "10/12/2013", B],
|
|
|
|
[Yehuda, Katz, "10/11/2013", A]]
|
|
|
|
"#;
|
2019-12-15 17:15:06 +01:00
|
|
|
|
2023-11-29 23:21:34 +01:00
|
|
|
let actual = nu!(pipeline(&format!("{sample} | group-by ttype")));
|
2019-12-15 17:15:06 +01:00
|
|
|
|
2023-11-29 23:21:34 +01:00
|
|
|
assert!(actual.err.contains("did you mean 'type'"),);
|
2019-12-15 17:15:06 +01:00
|
|
|
}
|
2022-02-09 15:47:47 +01:00
|
|
|
|
|
|
|
#[test]
|
2023-10-19 12:20:52 +02:00
|
|
|
fn group_by_on_empty_list_returns_empty_record() {
|
|
|
|
let actual = nu!("[[a b]; [1 2]] | where false | group-by a");
|
|
|
|
assert!(actual.err.is_empty());
|
|
|
|
assert!(actual.out.contains("empty record"));
|
2023-05-18 01:34:44 +02:00
|
|
|
}
|
2022-02-09 15:47:47 +01:00
|
|
|
|
2023-05-18 01:34:44 +02:00
|
|
|
#[test]
|
|
|
|
fn optional_cell_path_works() {
|
|
|
|
let actual = nu!("[{foo: 123}, {foo: 234}, {bar: 345}] | group-by foo? | to nuon");
|
|
|
|
let expected = r#"{"123": [[foo]; [123]], "234": [[foo]; [234]]}"#;
|
|
|
|
assert_eq!(actual.out, expected)
|
2022-02-09 15:47:47 +01:00
|
|
|
}
|