2022-01-30 13:23:28 +00:00
|
|
|
use crate::tests::{run_test, TestResult};
|
2021-12-25 19:39:42 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn cell_path_subexpr1() -> TestResult {
|
|
|
|
run_test("([[lang, gems]; [nu, 100]]).lang | get 0", "nu")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn cell_path_subexpr2() -> TestResult {
|
|
|
|
run_test("([[lang, gems]; [nu, 100]]).lang.0", "nu")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn cell_path_var1() -> TestResult {
|
|
|
|
run_test("let x = [[lang, gems]; [nu, 100]]; $x.lang | get 0", "nu")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn cell_path_var2() -> TestResult {
|
|
|
|
run_test("let x = [[lang, gems]; [nu, 100]]; $x.lang.0", "nu")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn flatten_simple_list() -> TestResult {
|
2022-02-09 10:58:54 +00:00
|
|
|
run_test(
|
|
|
|
"[[N, u, s, h, e, l, l]] | flatten | str collect (char nl)",
|
|
|
|
"N\nu\ns\nh\ne\nl\nl",
|
|
|
|
)
|
2021-12-25 19:39:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn flatten_get_simple_list() -> TestResult {
|
|
|
|
run_test("[[N, u, s, h, e, l, l]] | flatten | get 0", "N")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn flatten_table_get() -> TestResult {
|
|
|
|
run_test(
|
2022-02-09 10:58:54 +00:00
|
|
|
"[[origin, people]; [Ecuador, ([[name, meal]; ['Andres', 'arepa']])]] | flatten | get meal.0",
|
2021-12-25 19:39:42 +00:00
|
|
|
"arepa",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn flatten_table_column_get_last() -> TestResult {
|
|
|
|
run_test(
|
2022-02-09 10:58:54 +00:00
|
|
|
"[[origin, crate, versions]; [World, ([[name]; ['nu-cli']]), ['0.21', '0.22']]] | flatten versions | last | get versions.0",
|
2021-12-25 19:39:42 +00:00
|
|
|
"0.22",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn get_table_columns_1() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
"[[name, age, grade]; [paul,21,a]] | columns | first",
|
|
|
|
"name",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn get_table_columns_2() -> TestResult {
|
2022-02-09 10:58:54 +00:00
|
|
|
run_test("[[name, age, grade]; [paul,21,a]] | columns | get 1", "age")
|
2021-12-25 19:39:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn flatten_should_flatten_inner_table() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
"[[[name, value]; [abc, 123]]] | flatten | get value.0",
|
|
|
|
"123",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn command_filter_reject_1() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
"[[lang, gems]; [nu, 100]] | reject gems | to json",
|
|
|
|
r#"[
|
|
|
|
{
|
|
|
|
"lang": "nu"
|
|
|
|
}
|
|
|
|
]"#,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn command_filter_reject_2() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
"[[lang, gems, grade]; [nu, 100, a]] | reject gems grade | to json",
|
|
|
|
r#"[
|
|
|
|
{
|
|
|
|
"lang": "nu"
|
|
|
|
}
|
|
|
|
]"#,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn command_filter_reject_3() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
"[[lang, gems, grade]; [nu, 100, a]] | reject grade gems | to json",
|
|
|
|
r#"[
|
|
|
|
{
|
|
|
|
"lang": "nu"
|
|
|
|
}
|
|
|
|
]"#,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-01-29 17:45:16 +00:00
|
|
|
#[test]
|
|
|
|
#[rustfmt::skip]
|
|
|
|
fn command_filter_reject_4() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
"[[lang, gems, grade]; [nu, 100, a]] | reject gems | to json -r",
|
|
|
|
r#"[{"lang": "nu","grade": "a"}]"#,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-12-25 19:39:42 +00:00
|
|
|
#[test]
|
|
|
|
fn command_drop_column_1() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
"[[lang, gems, grade]; [nu, 100, a]] | drop column 2 | to json",
|
|
|
|
r#"[
|
|
|
|
{
|
|
|
|
"lang": "nu"
|
|
|
|
}
|
|
|
|
]"#,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn record_1() -> TestResult {
|
|
|
|
run_test(r#"{'a': 'b'} | get a"#, "b")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn record_2() -> TestResult {
|
|
|
|
run_test(r#"{'b': 'c'}.b"#, "c")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn where_on_ranges() -> TestResult {
|
|
|
|
run_test(r#"1..10 | where $it > 8 | math sum"#, "19")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn index_on_list() -> TestResult {
|
|
|
|
run_test(r#"[1, 2, 3].1"#, "2")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn update_cell_path_1() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
r#"[[name, size]; [a, 1.1]] | into int size | get size.0"#,
|
|
|
|
"1",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2022-01-30 13:23:28 +00:00
|
|
|
fn missing_column_fills_in_nothing() -> TestResult {
|
|
|
|
// The empty value will be replaced with $nothing when fetching a column
|
|
|
|
run_test(
|
|
|
|
r#"[ { name: ABC, size: 20 }, { name: HIJ } ].size.1 == $nothing"#,
|
|
|
|
"true",
|
2021-12-25 19:39:42 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn string_cell_path() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
r#"let x = "name"; [["name", "score"]; [a, b], [c, d]] | get $x | get 1"#,
|
|
|
|
"c",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn split_row() -> TestResult {
|
|
|
|
run_test(r#""hello world" | split row " " | get 1"#, "world")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn split_column() -> TestResult {
|
|
|
|
run_test(
|
2022-02-20 00:26:47 +00:00
|
|
|
r#""hello world" | split column " " | get "column1".0"#,
|
2021-12-25 19:39:42 +00:00
|
|
|
"hello",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn wrap() -> TestResult {
|
|
|
|
run_test(r#"([1, 2, 3] | wrap foo).foo.1"#, "2")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn get() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
r#"[[name, grade]; [Alice, A], [Betty, B]] | get grade.1"#,
|
|
|
|
"B",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2022-01-10 21:29:52 +00:00
|
|
|
fn select_1() -> TestResult {
|
2021-12-25 19:39:42 +00:00
|
|
|
run_test(
|
|
|
|
r#"([[name, age]; [a, 1], [b, 2]]) | select name | get 1 | get name"#,
|
|
|
|
"b",
|
|
|
|
)
|
|
|
|
}
|
2021-12-27 23:11:20 +00:00
|
|
|
|
2022-01-10 21:29:52 +00:00
|
|
|
#[test]
|
|
|
|
fn select_2() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
r#"[[name, age]; [a, 1] [b, 2]] | get 1 | select age | get age"#,
|
|
|
|
"2",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-12-27 23:11:20 +00:00
|
|
|
#[test]
|
|
|
|
fn update_will_insert() -> TestResult {
|
|
|
|
run_test(r#"{} | update a b | get a"#, "b")
|
|
|
|
}
|
2022-01-01 04:27:20 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn length_for_columns() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
r#"[[name,age,grade]; [bill,20,a] [a b c]] | length -c"#,
|
|
|
|
"3",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn length_for_rows() -> TestResult {
|
|
|
|
run_test(r#"[[name,age,grade]; [bill,20,a] [a b c]] | length"#, "2")
|
|
|
|
}
|
2022-01-02 02:18:39 +00:00
|
|
|
|
2022-02-13 10:38:46 +00:00
|
|
|
#[test]
|
|
|
|
fn length_defaulted_columns() -> TestResult {
|
|
|
|
run_test(
|
|
|
|
r#"echo [[name, age]; [test, 10]] | default age 11 | get 0 | columns | length"#,
|
|
|
|
"2",
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-01-02 02:18:39 +00:00
|
|
|
#[test]
|
|
|
|
fn get_fuzzy() -> TestResult {
|
|
|
|
run_test("(ls | get -i foo) == $nothing", "true")
|
|
|
|
}
|