2019-07-16 12:28:55 +02:00
|
|
|
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;
|
2019-07-16 12:28:55 +02:00
|
|
|
|
2019-07-24 06:10:48 +02:00
|
|
|
use nu::AbsolutePath;
|
|
|
|
|
2019-07-16 12:28:55 +02:00
|
|
|
#[test]
|
|
|
|
fn lines() {
|
|
|
|
nu!(output,
|
|
|
|
cwd("tests/fixtures/formats"),
|
|
|
|
"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");
|
|
|
|
}
|
|
|
|
|
2019-07-19 22:11:49 +02:00
|
|
|
#[test]
|
2019-07-21 09:08:05 +02:00
|
|
|
fn open_can_parse_csv() {
|
2019-07-20 03:18:27 +02:00
|
|
|
nu!(
|
|
|
|
output,
|
2019-07-19 22:11:49 +02:00
|
|
|
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
|
|
|
);
|
2019-07-19 22:11:49 +02:00
|
|
|
|
|
|
|
assert_eq!(output, "SPAIN");
|
|
|
|
}
|
|
|
|
|
2019-07-16 12:28:55 +02:00
|
|
|
#[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"
|
|
|
|
);
|
2019-07-16 12:28:55 +02:00
|
|
|
|
|
|
|
assert_eq!(output, "2018");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2019-07-21 09:08:05 +02:00
|
|
|
fn open_can_parse_json() {
|
2019-07-16 12:28:55 +02:00
|
|
|
nu!(output,
|
|
|
|
cwd("tests/fixtures/formats"),
|
|
|
|
"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,
|
2019-07-16 12:28:55 +02:00
|
|
|
cwd("tests/fixtures/formats"),
|
2019-07-20 03:18:27 +02:00
|
|
|
"open jonathan.xml | get rss.channel.item.link | echo $it"
|
|
|
|
);
|
2019-07-16 12:28:55 +02:00
|
|
|
|
2019-07-20 03:18:27 +02:00
|
|
|
assert_eq!(
|
|
|
|
output,
|
|
|
|
"http://www.jonathanturner.org/2015/10/off-to-new-adventures.html"
|
|
|
|
)
|
2019-07-16 12:28:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2019-07-21 09:08:05 +02:00
|
|
|
fn open_can_parse_ini() {
|
2019-07-20 03:18:27 +02:00
|
|
|
nu!(
|
|
|
|
output,
|
2019-07-16 12:28:55 +02:00
|
|
|
cwd("tests/fixtures/formats"),
|
2019-07-20 03:18:27 +02:00
|
|
|
"open sample.ini | get SectionOne.integer | echo $it"
|
|
|
|
);
|
2019-07-16 12:28:55 +02:00
|
|
|
|
|
|
|
assert_eq!(output, "1234")
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn open_error_if_file_not_found() {
|
2019-07-20 03:18:27 +02:00
|
|
|
nu_error!(
|
|
|
|
output,
|
2019-07-16 12:28:55 +02:00
|
|
|
cwd("tests/fixtures/formats"),
|
2019-07-20 03:18:27 +02:00
|
|
|
"open i_dont_exist.txt | echo $it"
|
|
|
|
);
|
2019-07-16 12:28:55 +02:00
|
|
|
|
2019-07-21 09:08:05 +02:00
|
|
|
assert!(output.contains("File could not be opened"));
|
2019-07-16 12:28:55 +02:00
|
|
|
}
|
|
|
|
|
2019-07-17 21:51:18 +02:00
|
|
|
#[test]
|
2019-07-24 06:10:48 +02:00
|
|
|
fn save_can_write_out_csv() -> Result<(), std::io::Error> {
|
2019-08-02 21:15:07 +02:00
|
|
|
let (playground, tmp, _dir) = h::setup_playground_for("save_test")?;
|
2019-07-21 09:08:05 +02:00
|
|
|
|
2019-08-02 21:15:07 +02:00
|
|
|
let expected_file = tmp.as_ref().join("cargo_sample.csv");
|
2019-07-21 09:08:05 +02:00
|
|
|
|
2019-08-02 21:15:07 +02:00
|
|
|
let root = &AbsolutePath::new(std::env::current_dir()?);
|
2019-07-24 06:10:48 +02:00
|
|
|
|
2019-08-02 21:15:07 +02:00
|
|
|
let path = root / "tests/fixtures/formats/cargo_sample.toml";
|
2019-07-24 06:10:48 +02:00
|
|
|
|
|
|
|
let command = format!(
|
2019-08-02 21:15:07 +02:00
|
|
|
"open {} | inc package.version --minor | get package | save {}",
|
2019-07-24 06:10:48 +02:00
|
|
|
path.as_ref().display(),
|
2019-08-02 21:15:07 +02:00
|
|
|
"cargo_sample.csv"
|
2019-07-21 09:08:05 +02:00
|
|
|
);
|
|
|
|
|
2019-08-02 21:15:07 +02:00
|
|
|
for item in std::fs::read_dir(tmp.as_ref()) {
|
|
|
|
println!("item :: {:?}", item);
|
|
|
|
}
|
|
|
|
|
|
|
|
nu!(_output, tmp.as_ref().display(), command);
|
2019-07-24 06:10:48 +02:00
|
|
|
|
2019-07-21 09:08:05 +02:00
|
|
|
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-24 06:10:48 +02:00
|
|
|
|
2019-08-02 21:15:07 +02:00
|
|
|
drop(playground);
|
|
|
|
drop(tmp);
|
|
|
|
|
2019-07-24 06:10:48 +02:00
|
|
|
Ok(())
|
2019-07-21 09:08:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2019-07-24 06:10:48 +02:00
|
|
|
fn rm_can_remove_a_file() -> Result<(), std::io::Error> {
|
|
|
|
let _ = pretty_env_logger::try_init();
|
|
|
|
|
|
|
|
let (_playground, tmp, _) = h::setup_playground_for("remove_file")?;
|
2019-07-17 21:51:18 +02:00
|
|
|
|
2019-08-02 21:15:07 +02:00
|
|
|
let file = &AbsolutePath::new(&tmp) / "rm_test.txt";
|
2019-07-17 21:51:18 +02:00
|
|
|
|
2019-07-24 06:10:48 +02:00
|
|
|
h::create_file_at(&file)?;
|
2019-07-17 21:51:18 +02:00
|
|
|
|
2019-07-24 06:10:48 +02:00
|
|
|
nu!(_output, tmp.path().display(), "rm rm_test.txt");
|
|
|
|
|
|
|
|
assert!(!file.as_ref().exists());
|
|
|
|
|
|
|
|
Ok(())
|
2019-07-17 21:51:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2019-07-24 06:10:48 +02:00
|
|
|
fn rm_can_remove_directory_contents_with_recursive_flag() -> Result<(), std::io::Error> {
|
|
|
|
let _ = pretty_env_logger::try_init();
|
|
|
|
|
|
|
|
let (playground, tmp, 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-24 06:10:48 +02:00
|
|
|
h::create_file_at(&tmp.path().join(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-24 06:10:48 +02:00
|
|
|
playground.path().display(),
|
|
|
|
format!("rm {} --recursive", dir)
|
2019-07-20 03:18:27 +02:00
|
|
|
);
|
2019-07-17 21:51:18 +02:00
|
|
|
|
2019-07-24 06:10:48 +02:00
|
|
|
assert!(!tmp.path().exists());
|
|
|
|
|
|
|
|
Ok(())
|
2019-07-17 21:51:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2019-07-24 06:10:48 +02:00
|
|
|
fn rm_error_if_attempting_to_delete_a_directory_without_recursive_flag(
|
|
|
|
) -> Result<(), std::io::Error> {
|
|
|
|
let (playground, tmp, dir) = h::setup_playground_for("rm_test_2")?;
|
2019-07-17 21:51:18 +02:00
|
|
|
|
2019-07-24 06:10:48 +02:00
|
|
|
nu_error!(output, playground.path().display(), format!("rm {}", dir));
|
2019-07-17 21:51:18 +02:00
|
|
|
|
2019-07-24 06:10:48 +02:00
|
|
|
assert!(tmp.path().exists());
|
2019-07-17 21:51:18 +02:00
|
|
|
assert!(output.contains("is a directory"));
|
2019-07-24 06:10:48 +02:00
|
|
|
h::delete_directory_at(tmp.path());
|
|
|
|
|
|
|
|
Ok(())
|
2019-07-17 21:51:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2019-07-24 06:10:48 +02:00
|
|
|
fn rm_error_if_attempting_to_delete_single_dot_as_argument() -> Result<(), std::io::Error> {
|
|
|
|
let (_playground, tmp, _) = h::setup_playground_for("rm_test_2")?;
|
|
|
|
|
|
|
|
nu_error!(output, tmp.path().display(), "rm .");
|
2019-07-17 21:51:18 +02:00
|
|
|
|
|
|
|
assert!(output.contains("may not be removed"));
|
2019-07-24 06:10:48 +02:00
|
|
|
|
|
|
|
Ok(())
|
2019-07-17 21:51:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2019-07-24 06:10:48 +02:00
|
|
|
fn rm_error_if_attempting_to_delete_two_dot_as_argument() -> Result<(), std::io::Error> {
|
|
|
|
let (_playground, tmp, _) = h::setup_playground_for("rm_test_2")?;
|
|
|
|
|
|
|
|
nu_error!(output, tmp.path().display(), "rm ..");
|
2019-07-17 21:51:18 +02:00
|
|
|
|
|
|
|
assert!(output.contains("may not be removed"));
|
2019-07-24 06:10:48 +02:00
|
|
|
|
|
|
|
Ok(())
|
2019-07-17 21:51:18 +02:00
|
|
|
}
|