nushell/tests/commands_test.rs

200 lines
5.1 KiB
Rust
Raw Normal View History

mod helpers;
2019-07-17 21:51:18 +02:00
use h::in_directory as cwd;
2019-07-20 03:18:27 +02:00
use helpers as h;
#[test]
fn lines() {
nu!(output,
cwd("tests/fixtures/formats"),
2019-07-22 04:23:02 +02:00
"open cargo_sample.toml --raw | lines | skip-while $it != \"[dependencies]\" | skip 1 | first 1 | split-column \"=\" | get Column1 | trim | echo $it"
);
assert_eq!(output, "rustyline");
}
#[test]
2019-07-21 09:08:05 +02:00
fn open_can_parse_csv() {
2019-07-20 03:18:27 +02:00
nu!(
output,
cwd("tests/fixtures/formats"),
2019-07-20 08:44:21 +02:00
"open caco3_plastics.csv | first 1 | get origin | echo $it"
2019-07-20 03:18:27 +02:00
);
assert_eq!(output, "SPAIN");
}
#[test]
2019-07-21 09:08:05 +02:00
fn open_can_parse_toml() {
2019-07-20 03:18:27 +02:00
nu!(
output,
cwd("tests/fixtures/formats"),
"open cargo_sample.toml | get package.edition | echo $it"
);
assert_eq!(output, "2018");
}
#[test]
2019-07-21 09:08:05 +02:00
fn open_can_parse_json() {
nu!(output,
cwd("tests/fixtures/formats"),
2019-07-22 04:23:02 +02:00
"open sgml_description.json | get glossary.GlossDiv.GlossList.GlossEntry.GlossSee | echo $it"
);
assert_eq!(output, "markup")
}
#[test]
2019-07-21 09:08:05 +02:00
fn open_can_parse_xml() {
2019-07-20 03:18:27 +02:00
nu!(
output,
cwd("tests/fixtures/formats"),
2019-07-20 03:18:27 +02:00
"open jonathan.xml | get rss.channel.item.link | echo $it"
);
2019-07-20 03:18:27 +02:00
assert_eq!(
output,
"http://www.jonathanturner.org/2015/10/off-to-new-adventures.html"
)
}
#[test]
2019-07-21 09:08:05 +02:00
fn open_can_parse_ini() {
2019-07-20 03:18:27 +02:00
nu!(
output,
cwd("tests/fixtures/formats"),
2019-07-20 03:18:27 +02:00
"open sample.ini | get SectionOne.integer | echo $it"
);
assert_eq!(output, "1234")
}
#[test]
fn open_error_if_file_not_found() {
2019-07-20 03:18:27 +02:00
nu_error!(
output,
cwd("tests/fixtures/formats"),
2019-07-20 03:18:27 +02:00
"open i_dont_exist.txt | echo $it"
);
2019-07-21 09:08:05 +02:00
assert!(output.contains("File could not be opened"));
}
2019-07-17 21:51:18 +02:00
#[test]
2019-07-21 09:08:05 +02:00
fn save_can_write_out_csv() {
let (playground_path, tests_dir) = h::setup_playground_for("save_test");
let full_path = format!("{}/{}", playground_path, tests_dir );
let expected_file = format!("{}/{}", full_path , "cargo_sample.csv");
nu!(
_output,
cwd(&playground_path),
"open ../formats/cargo_sample.toml | inc package.version --minor | get package | save save_test/cargo_sample.csv"
);
let actual = h::file_contents(&expected_file);
assert!(actual.contains("[list list],A shell for the GitHub era,2018,ISC,nu,0.2.0"));
}
2019-07-22 04:23:02 +02:00
#[test]
fn cp_can_copy_a_file() {
let (playground_path, tests_dir) = h::setup_playground_for("cp_test");
let full_path = format!("{}/{}", playground_path, tests_dir );
let expected_file = format!("{}/{}", full_path , "sample.ini" );
nu!(
_output,
cwd(&playground_path),
"cp ../formats/sample.ini cp_test/sample.ini"
);
assert!(h::file_exists_at(&expected_file));
}
#[test]
fn cp_copies_the_file_inside_directory_if_path_to_copy_is_directory() {
let (playground_path, tests_dir) = h::setup_playground_for("cp_test_2");
let full_path = format!("{}/{}", playground_path, tests_dir );
let expected_file = format!("{}/{}", full_path , "sample.ini" );
nu!(
_output,
cwd(&playground_path),
"cp ../formats/sample.ini cp_test_2"
);
assert!(h::file_exists_at(&expected_file));
}
#[test]
fn cp_error_if_attempting_to_copy_a_directory_to_another_directory() {
let (playground_path, _) = h::setup_playground_for("cp_test_3");
nu_error!(
output,
cwd(&playground_path),
"cp ../formats cp_test_3"
);
assert!(output.contains("../formats"));
assert!(output.contains("is a directory (not copied)"));
}
2019-07-21 09:08:05 +02:00
#[test]
fn rm_can_remove_a_file() {
2019-07-17 21:51:18 +02:00
let directory = "tests/fixtures/nuplayground";
let file = format!("{}/rm_test.txt", directory);
h::create_file_at(&file);
2019-07-20 03:18:27 +02:00
nu!(_output, cwd(directory), "rm rm_test.txt");
2019-07-17 21:51:18 +02:00
assert!(!h::file_exists_at(&file));
}
#[test]
2019-07-21 09:08:05 +02:00
fn rm_can_remove_directory_contents_with_recursive_flag() {
let (playground_path, tests_dir) = h::setup_playground_for("rm_test");
2019-07-17 21:51:18 +02:00
for f in ["yehuda.txt", "jonathan.txt", "andres.txt"].iter() {
2019-07-21 09:08:05 +02:00
h::create_file_at(&format!("{}/{}/{}", playground_path, tests_dir, f));
2019-07-20 03:18:27 +02:00
}
2019-07-17 21:51:18 +02:00
2019-07-20 03:18:27 +02:00
nu!(
_output,
2019-07-17 21:51:18 +02:00
cwd("tests/fixtures/nuplayground"),
2019-07-20 03:18:27 +02:00
"rm rm_test --recursive"
);
2019-07-17 21:51:18 +02:00
2019-07-21 09:08:05 +02:00
assert!(!h::file_exists_at(&format!("{}/{}", playground_path, tests_dir)));
2019-07-17 21:51:18 +02:00
}
#[test]
fn rm_error_if_attempting_to_delete_a_directory_without_recursive_flag() {
2019-07-21 09:08:05 +02:00
let (playground_path, tests_dir) = h::setup_playground_for("rm_test_2");
let full_path = format!("{}/{}", playground_path, tests_dir);
2019-07-17 21:51:18 +02:00
2019-07-20 03:18:27 +02:00
nu_error!(output, cwd("tests/fixtures/nuplayground"), "rm rm_test_2");
2019-07-17 21:51:18 +02:00
2019-07-21 09:08:05 +02:00
assert!(h::file_exists_at(&full_path));
2019-07-17 21:51:18 +02:00
assert!(output.contains("is a directory"));
2019-07-21 09:08:05 +02:00
h::delete_directory_at(&full_path);
2019-07-17 21:51:18 +02:00
}
#[test]
fn rm_error_if_attempting_to_delete_single_dot_as_argument() {
2019-07-20 03:18:27 +02:00
nu_error!(output, cwd("tests/fixtures/nuplayground"), "rm .");
2019-07-17 21:51:18 +02:00
assert!(output.contains("may not be removed"));
}
#[test]
fn rm_error_if_attempting_to_delete_two_dot_as_argument() {
2019-07-20 03:18:27 +02:00
nu_error!(output, cwd("tests/fixtures/nuplayground"), "rm ..");
2019-07-17 21:51:18 +02:00
assert!(output.contains("may not be removed"));
2019-07-22 04:23:02 +02:00
}