forked from extern/nushell
21ad06b1e1
The original intent of this patch was to remove more unwraps to reduce panics. I then lost a ton of time to the fact that the playground isn't in a temp directory (because of permissions issues on Windows). This commit improves the test facilities to: - use a tempdir for the playground - change the playground API so you instantiate it with a block that encloses the lifetime of the tempdir - the block is called with a `dirs` argument that has `dirs.test()` and other important directories that we were computing by hand all the time - the block is also called with a `playground` argument that you can use to construct files (it's the same `Playground` as before) - change the nu! and nu_error! macros to produce output instead of taking a variable binding - change the nu! and nu_error! macros to do the cwd() transformation internally - change the nu! and nu_error! macros to take varargs at the end that get interpolated into the running command I didn't manage to finish porting all of the tests, so a bunch of tests are currently commented out. That will need to change before we land this patch.
140 lines
3.6 KiB
Rust
140 lines
3.6 KiB
Rust
mod helpers;
|
|
|
|
use h::{in_directory as cwd, Playground, Stub::*};
|
|
use helpers as h;
|
|
|
|
#[test]
|
|
fn can_only_apply_one() {
|
|
let output = nu_error!(
|
|
cwd("tests/fixtures/formats"),
|
|
"open caco3_plastics.csv | first 1 | str origin --downcase --upcase"
|
|
);
|
|
|
|
assert!(
|
|
output.contains("Usage: str field [--downcase|--upcase|--to-int|--replace|--find-replace]")
|
|
);
|
|
}
|
|
|
|
#[test]
|
|
fn acts_without_passing_field() {
|
|
Playground::setup_for("plugin_str_acts_without_passing_field_test").with_files(vec![
|
|
FileWithContent(
|
|
"sample.yml",
|
|
r#"
|
|
environment:
|
|
global:
|
|
PROJECT_NAME: nushell
|
|
"#,
|
|
),
|
|
]);
|
|
|
|
let output = nu!(
|
|
cwd("tests/fixtures/nuplayground/plugin_str_acts_without_passing_field_test"),
|
|
"open sample.yml | get environment.global.PROJECT_NAME | str --upcase | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "NUSHELL");
|
|
}
|
|
|
|
#[test]
|
|
fn downcases() {
|
|
Playground::setup_for("plugin_str_downcases_test").with_files(vec![FileWithContent(
|
|
"sample.toml",
|
|
r#"
|
|
[dependency]
|
|
name = "LIGHT"
|
|
"#,
|
|
)]);
|
|
|
|
let output = nu!(
|
|
cwd("tests/fixtures/nuplayground/plugin_str_downcases_test"),
|
|
"open sample.toml | str dependency.name --downcase | get dependency.name | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "light");
|
|
}
|
|
|
|
#[test]
|
|
fn upcases() {
|
|
Playground::setup_for("plugin_str_upcases_test").with_files(vec![FileWithContent(
|
|
"sample.toml",
|
|
r#"
|
|
[package]
|
|
name = "nushell"
|
|
"#,
|
|
)]);
|
|
|
|
let output = nu!(
|
|
cwd("tests/fixtures/nuplayground/plugin_str_upcases_test"),
|
|
"open sample.toml | str package.name --upcase | get package.name | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "NUSHELL");
|
|
}
|
|
|
|
#[test]
|
|
fn converts_to_int() {
|
|
let output = nu!(
|
|
cwd("tests/fixtures/formats"),
|
|
"open caco3_plastics.csv | first 1 | str tariff_item --to-int | where tariff_item == 2509000000 | get tariff_item | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "2509000000");
|
|
}
|
|
|
|
#[test]
|
|
fn replaces() {
|
|
Playground::setup_for("plugin_str_replaces_test").with_files(vec![FileWithContent(
|
|
"sample.toml",
|
|
r#"
|
|
[package]
|
|
name = "nushell"
|
|
"#,
|
|
)]);
|
|
|
|
let output = nu!(
|
|
cwd("tests/fixtures/nuplayground/plugin_str_replaces_test"),
|
|
"open sample.toml | str package.name --replace wykittenshell | get package.name | echo $it"
|
|
);
|
|
|
|
assert_eq!(output, "wykittenshell");
|
|
}
|
|
|
|
#[test]
|
|
fn find_and_replaces() {
|
|
Playground::setup_for("plugin_str_find_and_replaces_test").with_files(vec![FileWithContent(
|
|
"sample.toml",
|
|
r#"
|
|
[fortune.teller]
|
|
phone = "1-800-KATZ"
|
|
"#,
|
|
)]);
|
|
|
|
let output = nu!(
|
|
cwd("tests/fixtures/nuplayground/plugin_str_find_and_replaces_test"),
|
|
r#"open sample.toml | str fortune.teller.phone --find-replace KATZ "5289" | get fortune.teller.phone | echo $it"#
|
|
);
|
|
|
|
assert_eq!(output, "1-800-5289");
|
|
}
|
|
|
|
#[test]
|
|
fn find_and_replaces_without_passing_field() {
|
|
Playground::setup_for("plugin_str_find_and_replaces_without_passing_field_test").with_files(
|
|
vec![FileWithContent(
|
|
"sample.toml",
|
|
r#"
|
|
[fortune.teller]
|
|
phone = "1-800-KATZ"
|
|
"#,
|
|
)],
|
|
);
|
|
|
|
let output = nu!(
|
|
cwd("tests/fixtures/nuplayground/plugin_str_find_and_replaces_without_passing_field_test"),
|
|
r#"open sample.toml | get fortune.teller.phone | str --find-replace KATZ "5289" | echo $it"#
|
|
);
|
|
|
|
assert_eq!(output, "1-800-5289");
|
|
}
|