diff --git a/examples/termination/main.rs b/examples/termination/main.rs index d3b2bf9c..797aa6d6 100755 --- a/examples/termination/main.rs +++ b/examples/termination/main.rs @@ -46,6 +46,7 @@ fn system_main() -> AnyhowResult<()> { "--variable".into(), format!("RESOURCE:{resource_file}"), ], + envs_rendered_obfuscated: vec![], retry_strategy: RetryStrategy::Complete, }; let token = CancellationToken::new(); @@ -100,6 +101,7 @@ fn rcc_main(rcc_binary_path: Utf8PathBuf) -> AnyhowResult<()> { "--variable".into(), format!("RESOURCE:{resource_file}"), ], + envs_rendered_obfuscated: vec![], retry_strategy: RetryStrategy::Complete, }; let rcc_environment = Environment::Rcc(RCCEnvironment { diff --git a/src/bin/scheduler/internal_config.rs b/src/bin/scheduler/internal_config.rs index ac2bae7a..a21d94ad 100644 --- a/src/bin/scheduler/internal_config.rs +++ b/src/bin/scheduler/internal_config.rs @@ -133,6 +133,9 @@ pub fn from_external_config( .map(|f| plan_source_dir.join(f)) .collect(), exit_on_failure: plan_config.robot_config.exit_on_failure, + environment_variables_rendered_obfuscated: plan_config + .robot_config + .environment_variables_rendered_obfuscated, }, plan_config.execution_config.n_attempts_max, plan_config.execution_config.retry_strategy, @@ -200,6 +203,7 @@ mod tests { variable_files: vec![], argument_files: vec!["args.txt".into(), "more_args.txt".into()], exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![], }, execution_config: ExecutionConfig { n_attempts_max: 1, @@ -235,6 +239,7 @@ mod tests { variable_files: vec!["vars.txt".into()], argument_files: vec![], exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![], }, execution_config: ExecutionConfig { n_attempts_max: 1, @@ -317,6 +322,7 @@ mod tests { "--variablefile".into(), "/synthetic_tests/rcc/vars.txt".into() ], + envs_rendered_obfuscated: vec![], n_attempts_max: 1, retry_strategy: RetryStrategy::Complete, } @@ -378,6 +384,7 @@ mod tests { "--argumentfile".into(), "/synthetic_tests/system/more_args.txt".into() ], + envs_rendered_obfuscated: vec![], n_attempts_max: 1, retry_strategy: RetryStrategy::Incremental, } diff --git a/src/config.rs b/src/config.rs index fa2e20d3..b2baae10 100644 --- a/src/config.rs +++ b/src/config.rs @@ -78,6 +78,7 @@ pub struct RobotConfig { pub variable_files: Vec, pub argument_files: Vec, pub exit_on_failure: bool, + pub environment_variables_rendered_obfuscated: Vec, } #[derive(Clone, Debug, Deserialize, PartialEq, Serialize)] @@ -86,6 +87,12 @@ pub struct RobotFrameworkVariable { pub value: String, } +#[derive(Clone, Debug, Deserialize, PartialEq, Serialize)] +pub struct RobotFrameworkObfuscatedEnvVar { + pub name: String, + pub value: String, +} + #[derive(Clone, Debug, Deserialize, PartialEq, Serialize)] pub struct ExecutionConfig { pub n_attempts_max: usize, diff --git a/src/rf/robot.rs b/src/rf/robot.rs index c538550f..9bcf7657 100644 --- a/src/rf/robot.rs +++ b/src/rf/robot.rs @@ -9,6 +9,7 @@ pub const PYTHON_EXECUTABLE: &str = "python"; pub struct Robot { pub robot_target: Utf8PathBuf, pub command_line_args: Vec, + pub envs_rendered_obfuscated: Vec<(String, String)>, pub n_attempts_max: usize, pub retry_strategy: RetryStrategy, } @@ -28,6 +29,11 @@ impl Robot { ) -> Self { Self { robot_target: robot_config.robot_target.clone(), + envs_rendered_obfuscated: robot_config + .environment_variables_rendered_obfuscated + .iter() + .map(|var| (var.name.clone(), var.value.clone())) + .collect(), command_line_args: Self::config_to_command_line_args(robot_config), n_attempts_max, retry_strategy, @@ -74,6 +80,9 @@ impl Robot { .add_argument("--report") .add_argument("NONE") .add_argument(&self.robot_target); + for (k, v) in &self.envs_rendered_obfuscated { + command_spec.add_obfuscated_env(k, v); + } command_spec } @@ -121,10 +130,10 @@ impl Robot { #[cfg(test)] mod tests { use super::*; - use crate::config::RobotFrameworkVariable; + use crate::config::{RobotFrameworkObfuscatedEnvVar, RobotFrameworkVariable}; #[test] - fn test_command_line_args_empty() { + fn test_new_command_line_args_empty() { assert!(Robot::new( RobotConfig { robot_target: "/suite/tasks.robot".into(), @@ -137,6 +146,7 @@ mod tests { variable_files: vec![], argument_files: vec![], exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![] }, 1, RetryStrategy::Incremental @@ -146,7 +156,7 @@ mod tests { } #[test] - fn test_command_line_args_non_empty() { + fn test_new_command_line_args_non_empty() { assert_eq!( Robot::new( RobotConfig { @@ -175,6 +185,7 @@ mod tests { "/suite/argfile2.txt".into() ], exit_on_failure: true, + environment_variables_rendered_obfuscated: vec![], }, 1, RetryStrategy::Incremental @@ -216,6 +227,36 @@ mod tests { ); } + #[test] + fn test_new_obfuscated_env_vars() { + assert_eq!( + Robot::new( + RobotConfig { + robot_target: "/suite/tasks.robot".into(), + top_level_suite_name: None, + suites: vec![], + tests: vec![], + test_tags_include: vec![], + test_tags_exclude: vec![], + variables: vec![], + variable_files: vec![], + argument_files: vec![], + exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![ + RobotFrameworkObfuscatedEnvVar { + name: "NAME".into(), + value: "value".into() + } + ] + }, + 1, + RetryStrategy::Incremental + ) + .envs_rendered_obfuscated, + vec![("NAME".into(), "value".into())] + ); + } + #[test] fn create_complete_command_spec() { // Assemble @@ -228,6 +269,7 @@ mod tests { "--variable".into(), "k:v".into(), ], + envs_rendered_obfuscated: vec![], retry_strategy: RetryStrategy::Complete, }; let output_directory = @@ -267,6 +309,7 @@ mod tests { "top_suite".into(), "--exitonfailure".into(), ], + envs_rendered_obfuscated: vec![], retry_strategy: RetryStrategy::Incremental, }; let output_directory = @@ -301,6 +344,7 @@ mod tests { robot_target: "~/calculator_test/calculator.robot".into(), n_attempts_max: 2, command_line_args: vec![], + envs_rendered_obfuscated: vec![], retry_strategy: RetryStrategy::Incremental, }; let output_directory = @@ -327,6 +371,26 @@ mod tests { assert_eq!(command_spec, expected) } + #[test] + fn create_command_obfuscated_env_vars() { + assert_eq!( + Robot { + robot_target: "~/calculator_test/calculator.robot".into(), + n_attempts_max: 1, + command_line_args: vec![], + envs_rendered_obfuscated: vec![("NAME".into(), "value".into())], + retry_strategy: RetryStrategy::Complete, + } + .command_spec( + &Utf8PathBuf::default(), + &Utf8PathBuf::default().join("out.xml"), + 1 + ) + .envs_rendered_obfuscated, + vec![("NAME".into(), "value".into())] + ) + } + #[test] fn create_two_attempts() { // Assemble @@ -334,6 +398,7 @@ mod tests { robot_target: "~/calculator_test/calculator.robot".into(), n_attempts_max: 2, command_line_args: vec![], + envs_rendered_obfuscated: vec![], retry_strategy: RetryStrategy::Incremental, }; let output_directory = diff --git a/tests/test_ht_import_scheduler.rs b/tests/test_ht_import_scheduler.rs index 70a080b8..04e36f18 100644 --- a/tests/test_ht_import_scheduler.rs +++ b/tests/test_ht_import_scheduler.rs @@ -97,6 +97,7 @@ fn create_config(test_dir: &Utf8Path, suite_dir: &Utf8Path, rcc_config: RCCConfi variable_files: vec![], argument_files: vec![], exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![], }, execution_config: ExecutionConfig { n_attempts_max: 1, diff --git a/tests/test_plan_run.rs b/tests/test_plan_run.rs index d5cade7b..51b4db4e 100644 --- a/tests/test_plan_run.rs +++ b/tests/test_plan_run.rs @@ -17,6 +17,7 @@ fn test_rebot_run() -> AnyhowResult<()> { robot_target: "tests/minimal_suite/tasks.robot".into(), n_attempts_max: 1, command_line_args: vec![], + envs_rendered_obfuscated: vec![], retry_strategy: RetryStrategy::Complete, }; let (attempt_reports, rebot) = run_attempts_with_rebot( @@ -45,6 +46,7 @@ fn test_timeout_process() -> AnyhowResult<()> { robot_target: "tests/timeout/tasks.robot".into(), n_attempts_max: 1, command_line_args: vec!["--variable".into(), format!("RESOURCE:{resource}")], + envs_rendered_obfuscated: vec![], retry_strategy: RetryStrategy::Complete, }; let (attempt_reports, rebot) = run_attempts_with_rebot( diff --git a/tests/test_scheduler.rs b/tests/test_scheduler.rs index 33a72bfa..37ddbc07 100644 --- a/tests/test_scheduler.rs +++ b/tests/test_scheduler.rs @@ -180,6 +180,7 @@ fn create_config( variable_files: vec![], argument_files: vec![], exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![], }, execution_config: ExecutionConfig { n_attempts_max: 1, @@ -219,6 +220,7 @@ fn create_config( variable_files: vec![], argument_files: vec![], exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![], }, execution_config: ExecutionConfig { n_attempts_max: 1, @@ -262,6 +264,7 @@ fn create_config( variable_files: vec![], argument_files: vec![], exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![], }, execution_config: ExecutionConfig { n_attempts_max: 1, @@ -313,6 +316,7 @@ fn create_config( variable_files: vec![], argument_files: vec![], exit_on_failure: false, + environment_variables_rendered_obfuscated: vec![], }, execution_config: ExecutionConfig { n_attempts_max: 1,