mirror of
https://github.com/nushell/nushell
synced 2025-01-13 21:55:07 +00:00
Add example tests (nu-plugin-test-support) for plugins in repo (#12281)
# Description Uses the new `nu-plugin-test-support` crate to test the examples of commands provided by plugins in the repo. Also fixed some of the examples to pass. # User-Facing Changes - Examples that are more guaranteed to work # Tests + Formatting - 🟢 `toolkit fmt` - 🟢 `toolkit clippy` - 🟢 `toolkit test` - 🟢 `toolkit test stdlib`
This commit is contained in:
parent
efe1c99a3b
commit
2ae4408ced
19 changed files with 139 additions and 6 deletions
4
Cargo.lock
generated
4
Cargo.lock
generated
|
@ -3214,6 +3214,7 @@ name = "nu_plugin_custom_values"
|
|||
version = "0.1.0"
|
||||
dependencies = [
|
||||
"nu-plugin",
|
||||
"nu-plugin-test-support",
|
||||
"nu-protocol",
|
||||
"serde",
|
||||
"typetag",
|
||||
|
@ -3223,7 +3224,9 @@ dependencies = [
|
|||
name = "nu_plugin_example"
|
||||
version = "0.91.1"
|
||||
dependencies = [
|
||||
"nu-cmd-lang",
|
||||
"nu-plugin",
|
||||
"nu-plugin-test-support",
|
||||
"nu-protocol",
|
||||
]
|
||||
|
||||
|
@ -3235,6 +3238,7 @@ dependencies = [
|
|||
"ical",
|
||||
"indexmap",
|
||||
"nu-plugin",
|
||||
"nu-plugin-test-support",
|
||||
"nu-protocol",
|
||||
"rust-ini",
|
||||
]
|
||||
|
|
|
@ -61,6 +61,19 @@ impl PluginTest {
|
|||
&mut self.engine_state
|
||||
}
|
||||
|
||||
/// Make additional command declarations available for use by tests.
|
||||
///
|
||||
/// This can be used to pull in commands from `nu-cmd-lang` for example, as required.
|
||||
pub fn add_decl(
|
||||
&mut self,
|
||||
decl: Box<dyn nu_protocol::engine::Command>,
|
||||
) -> Result<&mut Self, ShellError> {
|
||||
let mut working_set = StateWorkingSet::new(&self.engine_state);
|
||||
working_set.add_decl(decl);
|
||||
self.engine_state.merge_delta(working_set.render())?;
|
||||
Ok(self)
|
||||
}
|
||||
|
||||
/// Evaluate some Nushell source code with the plugin commands in scope with the given input to
|
||||
/// the pipeline.
|
||||
///
|
||||
|
|
|
@ -14,3 +14,6 @@ nu-plugin = { path = "../nu-plugin", version = "0.91.1" }
|
|||
nu-protocol = { path = "../nu-protocol", version = "0.91.1", features = ["plugin"] }
|
||||
serde = { workspace = true, default-features = false }
|
||||
typetag = "0.2"
|
||||
|
||||
[dev-dependencies]
|
||||
nu-plugin-test-support = { path = "../nu-plugin-test-support", version = "0.91.1" }
|
||||
|
|
|
@ -29,3 +29,11 @@ impl SimplePluginCommand for Generate {
|
|||
Ok(CoolCustomValue::new("abc").into_value(call.head))
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
|
||||
PluginTest::new("custom_values", crate::CustomValuePlugin.into())?
|
||||
.test_command_examples(&Generate)
|
||||
}
|
||||
|
|
|
@ -54,3 +54,11 @@ impl SimplePluginCommand for Generate2 {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
|
||||
PluginTest::new("custom_values", crate::CustomValuePlugin.into())?
|
||||
.test_command_examples(&Generate2)
|
||||
}
|
||||
|
|
|
@ -1,7 +1,9 @@
|
|||
use std::cmp::Ordering;
|
||||
|
||||
use nu_protocol::{CustomValue, ShellError, Span, Value};
|
||||
use serde::{Deserialize, Serialize};
|
||||
|
||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||
#[derive(Clone, Debug, Serialize, Deserialize, PartialEq, Eq, PartialOrd, Ord)]
|
||||
pub struct SecondCustomValue {
|
||||
pub(crate) something: String,
|
||||
}
|
||||
|
@ -59,6 +61,16 @@ impl CustomValue for SecondCustomValue {
|
|||
))
|
||||
}
|
||||
|
||||
fn partial_cmp(&self, other: &Value) -> Option<Ordering> {
|
||||
if let Value::CustomValue { val, .. } = other {
|
||||
val.as_any()
|
||||
.downcast_ref()
|
||||
.and_then(|other: &SecondCustomValue| PartialOrd::partial_cmp(self, other))
|
||||
} else {
|
||||
None
|
||||
}
|
||||
}
|
||||
|
||||
fn as_any(&self) -> &dyn std::any::Any {
|
||||
self
|
||||
}
|
||||
|
|
|
@ -23,9 +23,9 @@ impl SimplePluginCommand for Update {
|
|||
result: Some(CoolCustomValue::new("abcxyz").into_value(Span::test_data())),
|
||||
},
|
||||
PluginExample {
|
||||
example: "custom-value generate | custom-value update".into(),
|
||||
example: "custom-value generate2 | custom-value update".into(),
|
||||
description: "Update a SecondCustomValue".into(),
|
||||
result: Some(CoolCustomValue::new("xyzabc").into_value(Span::test_data())),
|
||||
result: Some(SecondCustomValue::new("xyzabc").into_value(Span::test_data())),
|
||||
},
|
||||
])
|
||||
}
|
||||
|
@ -56,3 +56,11 @@ impl SimplePluginCommand for Update {
|
|||
.into())
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
|
||||
PluginTest::new("custom_values", crate::CustomValuePlugin.into())?
|
||||
.test_command_examples(&Update)
|
||||
}
|
||||
|
|
|
@ -17,3 +17,7 @@ bench = false
|
|||
[dependencies]
|
||||
nu-plugin = { path = "../nu-plugin", version = "0.91.1" }
|
||||
nu-protocol = { path = "../nu-protocol", version = "0.91.1", features = ["plugin"] }
|
||||
|
||||
[dev-dependencies]
|
||||
nu-plugin-test-support = { path = "../nu-plugin-test-support", version = "0.91.1" }
|
||||
nu-cmd-lang = { path = "../nu-cmd-lang", version = "0.91.1" }
|
||||
|
|
|
@ -51,3 +51,9 @@ impl PluginCommand for CollectExternal {
|
|||
})
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
PluginTest::new("example", Example.into())?.test_command_examples(&CollectExternal)
|
||||
}
|
||||
|
|
|
@ -45,3 +45,9 @@ impl PluginCommand for ForEach {
|
|||
Ok(PipelineData::Empty)
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
PluginTest::new("example", Example.into())?.test_command_examples(&ForEach)
|
||||
}
|
||||
|
|
|
@ -76,3 +76,12 @@ impl PluginCommand for Generate {
|
|||
.into_pipeline_data(None))
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_cmd_lang::If;
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
PluginTest::new("example", Example.into())?
|
||||
.add_decl(Box::new(If))?
|
||||
.test_command_examples(&Generate)
|
||||
}
|
||||
|
|
|
@ -41,3 +41,9 @@ impl SimplePluginCommand for One {
|
|||
Ok(Value::nothing(call.head))
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
PluginTest::new("example", Example.into())?.test_command_examples(&One)
|
||||
}
|
||||
|
|
|
@ -46,3 +46,9 @@ impl PluginCommand for Seq {
|
|||
Ok(PipelineData::ListStream(list_stream, None))
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
PluginTest::new("example", Example.into())?.test_command_examples(&Seq)
|
||||
}
|
||||
|
|
|
@ -20,7 +20,7 @@ impl PluginCommand for Sum {
|
|||
(Type::List(Type::Float.into()), Type::Float),
|
||||
])
|
||||
.plugin_examples(vec![PluginExample {
|
||||
example: "seq 1 5 | example sum".into(),
|
||||
example: "example seq 1 5 | example sum".into(),
|
||||
description: "sum values from 1 to 5".into(),
|
||||
result: Some(Value::test_int(15)),
|
||||
}])
|
||||
|
@ -88,3 +88,9 @@ impl IntOrFloat {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
PluginTest::new("example", Example.into())?.test_command_examples(&Sum)
|
||||
}
|
||||
|
|
|
@ -16,3 +16,6 @@ indexmap = { workspace = true }
|
|||
eml-parser = "0.1"
|
||||
ical = "0.10"
|
||||
rust-ini = "0.20.0"
|
||||
|
||||
[dev-dependencies]
|
||||
nu-plugin-test-support = { path = "../nu-plugin-test-support", version = "0.91.1" }
|
||||
|
|
|
@ -53,6 +53,7 @@ pub fn examples() -> Vec<PluginExample> {
|
|||
example: "'From: test@email.com
|
||||
Subject: Welcome
|
||||
To: someone@somewhere.com
|
||||
|
||||
Test' | from eml"
|
||||
.into(),
|
||||
result: Some(Value::test_record(record! {
|
||||
|
@ -73,6 +74,7 @@ Test' | from eml"
|
|||
example: "'From: test@email.com
|
||||
Subject: Welcome
|
||||
To: someone@somewhere.com
|
||||
|
||||
Test' | from eml -b 1"
|
||||
.into(),
|
||||
result: Some(Value::test_record(record! {
|
||||
|
@ -164,3 +166,10 @@ fn from_eml(input: &Value, body_preview: usize, head: Span) -> Result<Value, Lab
|
|||
|
||||
Ok(Value::record(collected.into_iter().collect(), head))
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
|
||||
PluginTest::new("formats", crate::FromCmds.into())?.test_command_examples(&FromEml)
|
||||
}
|
||||
|
|
|
@ -75,7 +75,8 @@ impl SimplePluginCommand for FromIcs {
|
|||
|
||||
pub fn examples() -> Vec<PluginExample> {
|
||||
vec![PluginExample {
|
||||
example: "'BEGIN:VCALENDAR
|
||||
example: "
|
||||
'BEGIN:VCALENDAR
|
||||
END:VCALENDAR' | from ics"
|
||||
.into(),
|
||||
description: "Converts ics formatted string to table".into(),
|
||||
|
@ -263,3 +264,10 @@ fn params_to_value(params: Vec<(String, Vec<String>)>, span: Span) -> Value {
|
|||
|
||||
Value::record(row.into_iter().collect(), span)
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
|
||||
PluginTest::new("formats", crate::FromCmds.into())?.test_command_examples(&FromIcs)
|
||||
}
|
||||
|
|
|
@ -89,3 +89,10 @@ b=2' | from ini"
|
|||
})),
|
||||
}]
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
|
||||
PluginTest::new("formats", crate::FromCmds.into())?.test_command_examples(&FromIni)
|
||||
}
|
||||
|
|
|
@ -153,3 +153,10 @@ fn params_to_value(params: Vec<(String, Vec<String>)>, span: Span) -> Value {
|
|||
|
||||
Value::record(row.into_iter().collect(), span)
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_examples() -> Result<(), nu_protocol::ShellError> {
|
||||
use nu_plugin_test_support::PluginTest;
|
||||
|
||||
PluginTest::new("formats", crate::FromCmds.into())?.test_command_examples(&FromVcf)
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue