nushell/tests/filters_test.rs

508 lines
13 KiB
Rust
Raw Normal View History

mod helpers;
2019-08-29 02:32:42 +02:00
use helpers as h;
2019-08-29 08:31:56 +02:00
use helpers::{Playground, Stub::*};
2019-07-21 09:08:05 +02:00
#[test]
fn can_convert_table_to_csv_text_and_from_csv_text_back_into_table() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats",
2019-07-22 04:23:02 +02:00
"open caco3_plastics.csv | to-csv | from-csv | first 1 | get origin | echo $it"
);
2019-07-21 09:08:05 +02:00
2019-08-29 02:32:42 +02:00
assert_eq!(actual, "SPAIN");
2019-07-21 09:08:05 +02:00
}
#[test]
fn converts_structured_table_to_csv_text() {
2019-08-29 02:32:42 +02:00
Playground::setup("filter_to_csv_test_1", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"csv_text_sample.txt",
r#"
2019-08-29 02:32:42 +02:00
importer,shipper,tariff_item,name,origin
Plasticos Rival,Reverte,2509000000,Calcium carbonate,Spain
Tigre Ecuador,OMYA Andina,3824909999,Calcium carbonate,Colombia
2019-08-27 23:45:18 +02:00
"#,
2019-08-29 02:32:42 +02:00
)]);
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: dirs.test(), h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open csv_text_sample.txt
| lines
| split-column "," a b c d origin
| last 1
| to-csv
| lines
| nth 1
| echo "$it"
"#
));
assert!(actual.contains("Tigre Ecuador,OMYA Andina,3824909999,Calcium carbonate,Colombia"));
})
}
#[test]
fn converts_structured_table_to_csv_text_skipping_headers_after_conversion() {
2019-08-29 02:32:42 +02:00
Playground::setup("filter_to_csv_test_2", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"csv_text_sample.txt",
r#"
2019-08-29 02:32:42 +02:00
importer,shipper,tariff_item,name,origin
Plasticos Rival,Reverte,2509000000,Calcium carbonate,Spain
Tigre Ecuador,OMYA Andina,3824909999,Calcium carbonate,Colombia
2019-08-27 23:45:18 +02:00
"#,
2019-08-29 02:32:42 +02:00
)]);
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: dirs.test(), h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open csv_text_sample.txt
| lines
| split-column "," a b c d origin
| last 1
| to-csv --headerless
| echo "$it"
"#
));
assert!(actual.contains("Tigre Ecuador,OMYA Andina,3824909999,Calcium carbonate,Colombia"));
})
}
#[test]
fn converts_from_csv_text_to_structured_table() {
2019-08-29 02:32:42 +02:00
Playground::setup("filter_from_csv_test_1", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"los_tres_amigos.txt",
r#"
2019-08-29 02:32:42 +02:00
first_name,last_name,rusty_luck
Andrés,Robalino,1
Jonathan,Turner,1
Yehuda,Katz,1
"#,
)]);
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: dirs.test(), h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open los_tres_amigos.txt
| from-csv
| get rusty_luck
| str --to-int
| sum
2019-08-29 04:01:35 +02:00
| echo $it
2019-08-29 02:32:42 +02:00
"#
));
assert_eq!(actual, "3");
})
}
#[test]
fn converts_from_csv_text_skipping_headers_to_structured_table() {
2019-08-29 02:32:42 +02:00
Playground::setup("filter_from_csv_test_2", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"los_tres_amigos.txt",
r#"
2019-08-29 02:32:42 +02:00
first_name,last_name,rusty_luck
Andrés,Robalino,1
Jonathan,Turner,1
Yehuda,Katz,1
"#,
)]);
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: dirs.test(), h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open los_tres_amigos.txt
| from-csv --headerless
| get Column3
| str --to-int
| sum
| echo $it
"#
));
assert_eq!(actual, "3");
})
}
#[test]
fn can_convert_table_to_json_text_and_from_json_text_back_into_table() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats", h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open sgml_description.json
| to-json
| from-json
| get glossary.GlossDiv.GlossList.GlossEntry.GlossSee
| echo $it
"#
));
assert_eq!(actual, "markup");
}
2019-08-27 13:05:51 +02:00
#[test]
fn converts_from_json_text_to_structured_table() {
2019-08-29 02:32:42 +02:00
Playground::setup("filter_from_json_test_1", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"katz.txt",
r#"
2019-08-29 02:32:42 +02:00
{
"katz": [
{"name": "Yehuda", "rusty_luck": 1},
{"name": "Jonathan", "rusty_luck": 1},
{"name": "Andres", "rusty_luck": 1},
{"name":"GorbyPuff", "rusty_luck": 1}
]
}
"#,
)]);
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: dirs.test(),
2019-08-29 02:32:42 +02:00
"open katz.txt | from-json | get katz | get rusty_luck | sum | echo $it"
);
assert_eq!(actual, "4");
})
2019-08-27 13:05:51 +02:00
}
#[test]
fn converts_from_json_text_recognizing_objects_independendtly_to_structured_table() {
2019-08-29 02:32:42 +02:00
Playground::setup("filter_from_json_test_2", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"katz.txt",
r#"
2019-08-29 02:32:42 +02:00
{"name": "Yehuda", "rusty_luck": 1}
{"name": "Jonathan", "rusty_luck": 1}
{"name": "Andres", "rusty_luck": 1}
{"name":"GorbyPuff", "rusty_luck": 3}
"#,
)]);
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: dirs.test(), h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open katz.txt
| from-json --objects
| where name == "GorbyPuff"
| get rusty_luck
| echo $it
"#
));
assert_eq!(actual, "3");
})
2019-08-27 13:05:51 +02:00
}
#[test]
fn converts_structured_table_to_json_text() {
2019-08-29 02:32:42 +02:00
Playground::setup("filter_to_json_test", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"sample.txt",
r#"
2019-08-29 02:32:42 +02:00
JonAndrehudaTZ,3
GorbyPuff,100
"#,
)]);
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: dirs.test(), h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open sample.txt
| lines
| split-column "," name luck
| pick name
| to-json
| nth 0
| from-json
| get name
| echo $it
"#
));
assert_eq!(actual, "JonAndrehudaTZ");
})
2019-08-27 13:05:51 +02:00
}
2019-08-29 11:02:16 +02:00
#[test]
fn can_convert_table_to_tsv_text_and_from_tsv_text_back_into_table() {
let actual = nu!(
cwd: "tests/fixtures/formats",
"open caco3_plastics.tsv | to-tsv | from-tsv | first 1 | get origin | echo $it"
);
assert_eq!(actual, "SPAIN");
}
#[test]
fn converts_structured_table_to_tsv_text() {
Playground::setup("filter_to_tsv_test_1", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"tsv_text_sample.txt",
r#"
2019-08-29 11:02:16 +02:00
importer shipper tariff_item name origin
Plasticos Rival Reverte 2509000000 Calcium carbonate Spain
Tigre Ecuador OMYA Andina 3824909999 Calcium carbonate Colombia
2019-08-27 23:45:18 +02:00
"#,
2019-08-29 11:02:16 +02:00
)]);
let actual = nu!(
cwd: dirs.test(), h::pipeline(
r#"
open tsv_text_sample.txt
| lines
| split-column "\t" a b c d origin
| last 1
| to-tsv
| lines
| nth 1
| echo "$it"
"#
));
assert!(actual.contains("Colombia"));
})
}
#[test]
fn converts_structured_table_to_tsv_text_skipping_headers_after_conversion() {
Playground::setup("filter_to_tsv_test_2", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"tsv_text_sample.txt",
r#"
2019-08-29 11:02:16 +02:00
importer shipper tariff_item name origin
Plasticos Rival Reverte 2509000000 Calcium carbonate Spain
Tigre Ecuador OMYA Andina 3824909999 Calcium carbonate Colombia
2019-08-27 23:45:18 +02:00
"#,
2019-08-29 11:02:16 +02:00
)]);
let actual = nu!(
cwd: dirs.test(), h::pipeline(
r#"
open tsv_text_sample.txt
| lines
| split-column "\t" a b c d origin
| last 1
| to-tsv --headerless
| echo "$it"
"#
));
assert!(actual.contains("Colombia"));
})
}
#[test]
fn converts_from_tsv_text_to_structured_table() {
Playground::setup("filter_from_tsv_test_1", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"los_tres_amigos.txt",
r#"
2019-08-29 11:02:16 +02:00
first Name Last Name rusty_luck
Andrés Robalino 1
Jonathan Turner 1
Yehuda Katz 1
"#,
)]);
let actual = nu!(
cwd: dirs.test(), h::pipeline(
r#"
open los_tres_amigos.txt
| from-tsv
| get rusty_luck
| str --to-int
| sum
| echo $it
"#
));
assert_eq!(actual, "3");
})
}
#[test]
fn converts_from_tsv_text_skipping_headers_to_structured_table() {
Playground::setup("filter_from_tsv_test_2", |dirs, sandbox| {
2019-08-27 23:45:18 +02:00
sandbox.with_files(vec![FileWithContentToBeTrimmed(
"los_tres_amigos.txt",
r#"
2019-08-29 11:02:16 +02:00
first Name Last Name rusty_luck
Andrés Robalino 1
Jonathan Turner 1
Yehuda Katz 1
"#,
)]);
let actual = nu!(
cwd: dirs.test(), h::pipeline(
r#"
2019-08-27 23:45:18 +02:00
open los_tres_amigos.txt
| from-tsv --headerless
| get Column3
| str --to-int
| sum
2019-08-29 11:02:16 +02:00
| echo $it
"#
));
assert_eq!(actual, "3");
})
}
2019-08-26 16:16:34 +02:00
#[test]
2019-08-27 23:45:18 +02:00
fn can_convert_table_to_bson_and_back_into_table() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-27 23:45:18 +02:00
cwd: "tests/fixtures/formats", h::pipeline(
r#"
open sample.bson
| to-bson
| from-bson
| get root
| nth 1
| get b
| echo $it"#
));
2019-08-26 16:16:34 +02:00
2019-08-29 02:32:42 +02:00
assert_eq!(actual, "whel");
2019-08-26 16:16:34 +02:00
}
2019-08-27 23:45:18 +02:00
#[test]
fn can_convert_table_to_sqlite_and_back_into_table() {
let actual = nu!(
cwd: "tests/fixtures/formats", h::pipeline(
r#"
open sample.db
| to-sqlite
| from-sqlite
| get table_values
| nth 2
| get x
| echo $it"#
));
assert_eq!(actual, "hello");
}
#[test]
fn can_convert_table_to_toml_text_and_from_toml_text_back_into_table() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-27 23:45:18 +02:00
cwd: "tests/fixtures/formats", h::pipeline(
r#"
open cargo_sample.toml
| to-toml
| from-toml
| get package.name
| echo $it"#
));
2019-08-29 02:32:42 +02:00
assert_eq!(actual, "nu");
}
#[test]
fn can_convert_table_to_yaml_text_and_from_yaml_text_back_into_table() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats", h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open appveyor.yml
| to-yaml
| from-yaml
| get environment.global.PROJECT_NAME
| echo $it
"#
));
assert_eq!(actual, "nushell");
}
#[test]
fn can_sort_by_column() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats", h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open cargo_sample.toml --raw
| lines
| skip 1
| first 4
| split-column "="
| sort-by Column1
| skip 1
| first 1
| get Column1
| trim
| echo $it
"#
));
assert_eq!(actual, "description");
2019-08-24 22:31:45 +02:00
}
#[test]
fn can_split_by_column() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats", h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open cargo_sample.toml --raw
| lines
| skip 1
| first 1
| split-column "="
| get Column1
| trim
| echo $it
"#
));
assert_eq!(actual, "name");
}
2019-07-26 20:40:00 +02:00
#[test]
fn can_sum() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats", h::pipeline(
2019-08-29 02:32:42 +02:00
r#"
open sgml_description.json
| get glossary.GlossDiv.GlossList.GlossEntry.Sections
| sum
| echo $it
"#
));
assert_eq!(actual, "203")
2019-07-26 20:40:00 +02:00
}
2019-08-10 11:11:38 +02:00
#[test]
fn can_filter_by_unit_size_comparison() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats",
2019-08-29 11:02:16 +02:00
"ls | where size > 1kb | sort-by size | get name | first 1 | trim | echo $it"
);
2019-08-29 11:02:16 +02:00
assert_eq!(actual, "cargo_sample.toml");
}
2019-08-24 23:55:42 +02:00
#[test]
fn can_get_last() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats",
2019-08-25 02:21:09 +02:00
"ls | sort-by name | last 1 | get name | trim | echo $it"
2019-08-24 23:55:42 +02:00
);
2019-08-29 02:32:42 +02:00
assert_eq!(actual, "utf16.ini");
2019-08-24 20:32:48 +02:00
}
2019-08-25 18:14:17 +02:00
#[test]
fn can_get_reverse_first() {
2019-08-29 02:32:42 +02:00
let actual = nu!(
2019-08-29 08:31:56 +02:00
cwd: "tests/fixtures/formats",
2019-08-25 18:14:17 +02:00
"ls | sort-by name | reverse | first 1 | get name | trim | echo $it"
);
2019-08-29 02:32:42 +02:00
assert_eq!(actual, "utf16.ini");
2019-08-25 18:14:17 +02:00
}