Update tests Playground (#12134)

<!--
if this PR closes one or more issues, you can automatically link the PR
with
them by using one of the [*linking
keywords*](https://docs.github.com/en/issues/tracking-your-work-with-issues/linking-a-pull-request-to-an-issue#linking-a-pull-request-to-an-issue-using-a-keyword),
e.g.
- this PR should close #xxxx
- fixes #xxxx

you can also mention related issues, PRs or discussions!
-->

# Description
<!--
Thank you for improving Nushell. Please, check our [contributing
guide](../CONTRIBUTING.md) and talk to the core team before making major
changes.

Description of your pull request goes here. **Provide examples and/or
screenshots** if your changes affect the user experience.
-->

It looks like `Playground` and `Director` in nu-tests-support haven't
gotten much love recently, so this PR is for updating them to work with
newer Nushell versions.

- `Director` adds a `--skip-plugins` argument before running `nu`, but
that doesn't exist anymore, so I removed it.
- `Director` also adds a `--perf` argument, which also doesn't exist
anymore. I added `--log-level info` instead to get the performance
output.
- It doesn't seem like anyone was using `playground::matchers`, and it
used the [hamcrest2](https://github.com/Valloric/hamcrest2-rust) crate,
which appears to be unmaintained, so I got rid of that (and the
`hamcrest2` dependency).
- Inside `tests/fixtures/playground/config` were two files in the old
config format: `default.toml` and `startup.toml`. I removed those too.

# User-Facing Changes
<!-- List of all changes that impact the user experience here. This
helps us keep track of breaking changes. -->

None, these changes only mess with tests.

# Tests + Formatting
<!--
Don't forget to add tests that cover your changes.

Make sure you've run and fixed any issues with these commands:

- `cargo fmt --all -- --check` to check standard code formatting (`cargo
fmt --all` applies these changes)
- `cargo clippy --workspace -- -D warnings -D clippy::unwrap_used` to
check that you're using the standard code style
- `cargo test --workspace` to check that all tests pass (on Windows make
sure to [enable developer
mode](https://learn.microsoft.com/en-us/windows/apps/get-started/developer-mode-features-and-debugging))
- `cargo run -- -c "use std testing; testing run-tests --path
crates/nu-std"` to run the tests for the standard library

> **Note**
> from `nushell` you can also use the `toolkit` as follows
> ```bash
> use toolkit.nu # or use an `env_change` hook to activate it
automatically
> toolkit check pr
> ```
-->

# After Submitting
<!-- If your PR had any user-facing changes, update [the
documentation](https://github.com/nushell/nushell.github.io) after the
PR is merged, if necessary. This will help us keep the docs up to date.
-->
This commit is contained in:
Yash Thakur 2024-03-08 23:31:21 -05:00 committed by GitHub
parent af98b0219d
commit c90640411d
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
8 changed files with 15 additions and 187 deletions

68
Cargo.lock generated
View file

@ -1711,16 +1711,6 @@ dependencies = [
"serde", "serde",
] ]
[[package]]
name = "hamcrest2"
version = "0.3.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "49f837c62de05dc9cc71ff6486cd85de8856a330395ae338a04bfcefe5e91075"
dependencies = [
"num 0.2.1",
"regex",
]
[[package]] [[package]]
name = "hash32" name = "hash32"
version = "0.3.1" version = "0.3.1"
@ -2813,7 +2803,7 @@ dependencies = [
"nu-engine", "nu-engine",
"nu-parser", "nu-parser",
"nu-protocol", "nu-protocol",
"num 0.4.1", "num",
"polars", "polars",
"polars-arrow", "polars-arrow",
"polars-io", "polars-io",
@ -3171,7 +3161,6 @@ dependencies = [
name = "nu-test-support" name = "nu-test-support"
version = "0.91.1" version = "0.91.1"
dependencies = [ dependencies = [
"hamcrest2",
"nu-glob", "nu-glob",
"nu-path", "nu-path",
"nu-utils", "nu-utils",
@ -3262,42 +3251,17 @@ dependencies = [
"nu-protocol", "nu-protocol",
] ]
[[package]]
name = "num"
version = "0.2.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b8536030f9fea7127f841b45bb6243b27255787fb4eb83958aa1ef9d2fdc0c36"
dependencies = [
"num-bigint 0.2.6",
"num-complex 0.2.4",
"num-integer",
"num-iter",
"num-rational 0.2.4",
"num-traits",
]
[[package]] [[package]]
name = "num" name = "num"
version = "0.4.1" version = "0.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b05180d69e3da0e530ba2a1dae5110317e49e3b7f3d41be227dc5f92e49ee7af" checksum = "b05180d69e3da0e530ba2a1dae5110317e49e3b7f3d41be227dc5f92e49ee7af"
dependencies = [ dependencies = [
"num-bigint 0.4.4", "num-bigint",
"num-complex 0.4.4", "num-complex",
"num-integer", "num-integer",
"num-iter", "num-iter",
"num-rational 0.4.1", "num-rational",
"num-traits",
]
[[package]]
name = "num-bigint"
version = "0.2.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "090c7f9998ee0ff65aa5b723e4009f7b217707f1fb5ea551329cc4d6231fb304"
dependencies = [
"autocfg",
"num-integer",
"num-traits", "num-traits",
] ]
@ -3312,16 +3276,6 @@ dependencies = [
"num-traits", "num-traits",
] ]
[[package]]
name = "num-complex"
version = "0.2.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b6b19411a9719e753aff12e5187b74d60d3dc449ec3f4dc21e3989c3f554bc95"
dependencies = [
"autocfg",
"num-traits",
]
[[package]] [[package]]
name = "num-complex" name = "num-complex"
version = "0.4.4" version = "0.4.4"
@ -3362,18 +3316,6 @@ dependencies = [
"num-traits", "num-traits",
] ]
[[package]]
name = "num-rational"
version = "0.2.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5c000134b5dbf44adc5cb772486d335293351644b801551abe8f75c84cfa4aef"
dependencies = [
"autocfg",
"num-bigint 0.2.6",
"num-integer",
"num-traits",
]
[[package]] [[package]]
name = "num-rational" name = "num-rational"
version = "0.4.1" version = "0.4.1"
@ -3381,7 +3323,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0638a1c9d0a3c0914158145bc76cff373a75a627e6ecbfb71cbe6f453a5a19b0" checksum = "0638a1c9d0a3c0914158145bc76cff373a75a627e6ecbfb71cbe6f453a5a19b0"
dependencies = [ dependencies = [
"autocfg", "autocfg",
"num-bigint 0.4.4", "num-bigint",
"num-integer", "num-integer",
"num-traits", "num-traits",
] ]

View file

@ -19,4 +19,3 @@ nu-utils = { path = "../nu-utils", version = "0.91.1" }
num-format = "0.4" num-format = "0.4"
which = { workspace = true } which = { workspace = true }
tempfile = { workspace = true } tempfile = { workspace = true }
hamcrest2 = "0.3"

View file

@ -1,5 +1,4 @@
mod director; mod director;
pub mod matchers;
pub mod nu_process; pub mod nu_process;
mod play; mod play;
@ -7,6 +6,5 @@ mod play;
mod tests; mod tests;
pub use director::Director; pub use director::Director;
pub use matchers::says;
pub use nu_process::{Executable, NuProcess, NuResult, Outcome}; pub use nu_process::{Executable, NuProcess, NuResult, Outcome};
pub use play::{Dirs, EnvironmentVariable, Playground}; pub use play::{Dirs, EnvironmentVariable, Playground};

View file

@ -60,15 +60,14 @@ impl Director {
process.cwd(working_directory); process.cwd(working_directory);
} }
process.arg("--skip-plugins");
process.arg("--no-history"); process.arg("--no-history");
if let Some(config_file) = self.config.as_ref() { if let Some(config_file) = self.config.as_ref() {
process.args(&[ process.args(&[
"--config-file", "--config",
config_file.to_str().expect("failed to convert."), config_file.to_str().expect("failed to convert."),
]); ]);
} }
process.arg("--perf"); process.args(&["--log-level", "info"]);
director.executable = Some(process); director.executable = Some(process);
director director

View file

@ -1,102 +0,0 @@
use hamcrest2::core::{MatchResult, Matcher};
use std::fmt;
use std::str;
use super::nu_process::Outcome;
use super::{Director, Executable};
#[derive(Clone)]
pub struct Play {
stdout_expectation: Option<String>,
}
impl fmt::Display for Play {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "play")
}
}
impl fmt::Debug for Play {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "play")
}
}
pub fn says() -> Play {
Play {
stdout_expectation: None,
}
}
trait CheckerMatchers {
fn output(&self, actual: &Outcome) -> MatchResult;
fn std(&self, actual: &[u8], expected: Option<&str>, description: &str) -> MatchResult;
fn stdout(&self, actual: &Outcome) -> MatchResult;
}
impl CheckerMatchers for Play {
fn output(&self, actual: &Outcome) -> MatchResult {
self.stdout(actual)
}
fn stdout(&self, actual: &Outcome) -> MatchResult {
self.std(&actual.out, self.stdout_expectation.as_deref(), "stdout")
}
fn std(&self, actual: &[u8], expected: Option<&str>, description: &str) -> MatchResult {
let out = match expected {
Some(out) => out,
None => return Ok(()),
};
let actual =
str::from_utf8(actual).map_err(|_| format!("{description} was not utf8 encoded"))?;
if actual != out {
return Err(format!(
"not equal:\n actual: {actual}\n expected: {out}\n\n"
));
}
Ok(())
}
}
impl Matcher<Outcome> for Play {
fn matches(&self, output: Outcome) -> MatchResult {
self.output(&output)
}
}
impl Matcher<Director> for Play {
fn matches(&self, mut director: Director) -> MatchResult {
self.matches(&mut director)
}
}
impl<'a> Matcher<&'a mut Director> for Play {
fn matches(&self, director: &'a mut Director) -> MatchResult {
if director.executable().is_none() {
return Err(format!("no such process {director}"));
}
let res = director.execute();
match res {
Ok(out) => self.output(&out),
Err(err) => {
if let Some(out) = &err.output {
return self.output(out);
}
Err(format!("could not exec process {director}: {err:?}"))
}
}
}
}
impl Play {
pub fn stdout(mut self, expected: &str) -> Self {
self.stdout_expectation = Some(expected.to_string());
self
}
}

View file

@ -25,7 +25,7 @@ pub struct Playground<'a> {
root: TempDir, root: TempDir,
tests: String, tests: String,
cwd: PathBuf, cwd: PathBuf,
config: PathBuf, config: Option<PathBuf>,
environment_vars: Vec<EnvironmentVariable>, environment_vars: Vec<EnvironmentVariable>,
dirs: &'a Dirs, dirs: &'a Dirs,
} }
@ -42,10 +42,6 @@ impl Dirs {
self.fixtures.join("formats") self.fixtures.join("formats")
} }
pub fn config_fixtures(&self) -> PathBuf {
self.fixtures.join("playground/config")
}
pub fn root(&self) -> &Path { pub fn root(&self) -> &Path {
self.root.as_path() self.root.as_path()
} }
@ -97,7 +93,7 @@ impl<'a> Playground<'a> {
root, root,
tests: topic.to_string(), tests: topic.to_string(),
cwd: nuplay_dir, cwd: nuplay_dir,
config: fixtures.join("playground/config/default.toml"), config: None,
environment_vars: Vec::default(), environment_vars: Vec::default(),
dirs: &Dirs::default(), dirs: &Dirs::default(),
}; };
@ -135,7 +131,7 @@ impl<'a> Playground<'a> {
} }
pub fn with_config(&mut self, source_file: impl AsRef<Path>) -> &mut Self { pub fn with_config(&mut self, source_file: impl AsRef<Path>) -> &mut Self {
self.config = source_file.as_ref().to_path_buf(); self.config = Some(source_file.as_ref().to_path_buf());
self self
} }
@ -145,14 +141,16 @@ impl<'a> Playground<'a> {
self self
} }
pub fn get_config(&self) -> &str { pub fn get_config(&self) -> Option<&str> {
self.config.to_str().expect("could not convert path.") self.config
.as_ref()
.map(|cfg| cfg.to_str().expect("could not convert path."))
} }
pub fn build(&mut self) -> Director { pub fn build(&mut self) -> Director {
Director { Director {
cwd: Some(self.dirs.test().into()), cwd: Some(self.dirs.test().into()),
config: Some(self.config.clone().into()), config: self.config.clone().map(|cfg| cfg.into()),
environment_vars: self.environment_vars.clone(), environment_vars: self.environment_vars.clone(),
..Default::default() ..Default::default()
} }

View file

@ -1,3 +0,0 @@
skip_welcome_message = true
filesize_format = "auto"
rm_always_trash = false

View file

@ -1,3 +0,0 @@
skip_welcome_message = true
startup = ["def hello-world [] { echo 'Nu World' }"]