mirror of
https://github.com/nushell/nushell.git
synced 2025-01-23 23:00:01 +01:00
154 lines
3.6 KiB
Rust
154 lines
3.6 KiB
Rust
mod helpers;
|
|
|
|
use helpers::in_directory as cwd;
|
|
|
|
#[test]
|
|
fn can_convert_table_to_csv_text_and_from_csv_text_back_into_table() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open caco3_plastics.csv | to-csv | from-csv | first 1 | get origin | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "SPAIN");
|
|
}
|
|
|
|
#[test]
|
|
fn can_convert_table_to_json_text_and_from_json_text_back_into_table() {
|
|
nu!(output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open sgml_description.json | to-json | from-json | get glossary.GlossDiv.GlossList.GlossEntry.GlossSee | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "markup");
|
|
}
|
|
|
|
#[test]
|
|
fn can_convert_table_to_toml_text_and_from_toml_text_back_into_table() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open cargo_sample.toml | to-toml | from-toml | get package.name | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "nu");
|
|
}
|
|
|
|
#[test]
|
|
fn can_convert_table_to_yaml_text_and_from_yaml_text_back_into_table() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open appveyor.yml | to-yaml | from-yaml | get environment.global.PROJECT_NAME | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "nushell");
|
|
}
|
|
|
|
#[test]
|
|
fn can_sort_by_column() {
|
|
nu!(output,
|
|
cwd("tests/fixtures/formats"),
|
|
"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!(output, "description");
|
|
}
|
|
|
|
#[test]
|
|
fn can_split_by_column() {
|
|
nu!(output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open cargo_sample.toml --raw | lines | skip 1 | first 1 | split-column \"=\" | get Column1 | trim | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "name");
|
|
}
|
|
|
|
#[test]
|
|
fn str_can_only_apply_one() {
|
|
nu_error!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open caco3_plastics.csv | first 1 | str origin --downcase --upcase"
|
|
);
|
|
|
|
assert!(output.contains("Usage: str field [--downcase|--upcase|--to-int]"));
|
|
}
|
|
|
|
#[test]
|
|
fn str_downcases() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open caco3_plastics.csv | first 1 | str origin --downcase | get origin | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "spain");
|
|
}
|
|
|
|
#[test]
|
|
fn str_upcases() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open appveyor.yml | str environment.global.PROJECT_NAME --upcase | get environment.global.PROJECT_NAME | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "NUSHELL");
|
|
}
|
|
|
|
#[test]
|
|
fn str_converts_to_int() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open caco3_plastics.csv | get 0 | str tariff_item --to-int | where tariff_item == 2509000000 | get tariff_item | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "2509000000");
|
|
}
|
|
|
|
#[test]
|
|
fn can_inc_version() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open cargo_sample.toml | inc package.version --minor | get package.version | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "0.2.0");
|
|
}
|
|
|
|
#[test]
|
|
fn can_inc_field() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open cargo_sample.toml | inc package.edition | get package.edition | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "2019");
|
|
}
|
|
|
|
#[test]
|
|
fn can_sum() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"open sgml_description.json | get glossary.GlossDiv.GlossList.GlossEntry.Sections | sum | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "203")
|
|
}
|
|
#[test]
|
|
fn can_filter_by_unit_size_comparison() {
|
|
nu!(
|
|
output,
|
|
cwd("tests/fixtures/formats"),
|
|
"ls | where size > 1kb | get name | skip 1 | trim | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "cargo_sample.toml");
|
|
}
|