Add trim option to Script Extension. Fix #295
This commit is contained in:
parent
fe745ae815
commit
7d694494e5
|
@ -88,7 +88,7 @@ impl super::Extension for ScriptExtension {
|
||||||
|
|
||||||
match output {
|
match output {
|
||||||
Ok(output) => {
|
Ok(output) => {
|
||||||
let output_str = String::from_utf8_lossy(output.stdout.as_slice());
|
let mut output_str = String::from_utf8_lossy(output.stdout.as_slice()).to_string();
|
||||||
let error_str = String::from_utf8_lossy(output.stderr.as_slice());
|
let error_str = String::from_utf8_lossy(output.stderr.as_slice());
|
||||||
let error_str = error_str.to_string();
|
let error_str = error_str.to_string();
|
||||||
let error_str = error_str.trim();
|
let error_str = error_str.trim();
|
||||||
|
@ -98,7 +98,20 @@ impl super::Extension for ScriptExtension {
|
||||||
warn!("Script command reported error: \n{}", error_str);
|
warn!("Script command reported error: \n{}", error_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
return Some(output_str.into_owned());
|
// If specified, trim the output
|
||||||
|
let trim_opt = params.get(&Value::from("trim"));
|
||||||
|
let should_trim = if let Some(value) = trim_opt {
|
||||||
|
let val = value.as_bool();
|
||||||
|
val.unwrap_or(true)
|
||||||
|
}else{
|
||||||
|
true
|
||||||
|
};
|
||||||
|
|
||||||
|
if should_trim {
|
||||||
|
output_str = output_str.trim().to_owned()
|
||||||
|
}
|
||||||
|
|
||||||
|
return Some(output_str);
|
||||||
}
|
}
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
error!("Could not execute script '{:?}', error: {}", args, e);
|
error!("Could not execute script '{:?}', error: {}", args, e);
|
||||||
|
@ -129,6 +142,26 @@ mod tests {
|
||||||
let extension = ScriptExtension::new();
|
let extension = ScriptExtension::new();
|
||||||
let output = extension.calculate(¶ms, &vec![]);
|
let output = extension.calculate(¶ms, &vec![]);
|
||||||
|
|
||||||
|
assert!(output.is_some());
|
||||||
|
assert_eq!(output.unwrap(), "hello world");
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
#[cfg(not(target_os = "windows"))]
|
||||||
|
fn test_script_basic_no_trim() {
|
||||||
|
let mut params = Mapping::new();
|
||||||
|
params.insert(
|
||||||
|
Value::from("args"),
|
||||||
|
Value::from(vec!["echo", "hello world"]),
|
||||||
|
);
|
||||||
|
params.insert(
|
||||||
|
Value::from("trim"),
|
||||||
|
Value::from(false),
|
||||||
|
);
|
||||||
|
|
||||||
|
let extension = ScriptExtension::new();
|
||||||
|
let output = extension.calculate(¶ms, &vec![]);
|
||||||
|
|
||||||
assert!(output.is_some());
|
assert!(output.is_some());
|
||||||
assert_eq!(output.unwrap(), "hello world\n");
|
assert_eq!(output.unwrap(), "hello world\n");
|
||||||
}
|
}
|
||||||
|
@ -146,7 +179,7 @@ mod tests {
|
||||||
let output = extension.calculate(¶ms, &vec!["jon".to_owned()]);
|
let output = extension.calculate(¶ms, &vec!["jon".to_owned()]);
|
||||||
|
|
||||||
assert!(output.is_some());
|
assert!(output.is_some());
|
||||||
assert_eq!(output.unwrap(), "hello world\n");
|
assert_eq!(output.unwrap(), "hello world");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -163,6 +196,6 @@ mod tests {
|
||||||
let output = extension.calculate(¶ms, &vec!["jon".to_owned()]);
|
let output = extension.calculate(¶ms, &vec!["jon".to_owned()]);
|
||||||
|
|
||||||
assert!(output.is_some());
|
assert!(output.is_some());
|
||||||
assert_eq!(output.unwrap(), "hello world jon\n");
|
assert_eq!(output.unwrap(), "hello world jon");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user