fix(composer): spawn commands to allow interaction (#71)
All checks were successful
Run Check Script / check (push) Successful in 1m39s
Compile and package harmony_composer / package_harmony_composer (push) Successful in 3m5s

Using `Command::output()` executes the command and wait for it to be finished before returning the output.
Though in some cases the user might need to interact with the CLI before continuing, which hangs the command execution.

Instead, using `Command::spawn()` allows to forward stdin/stdout to the parent process.

Reviewed-on: https://git.nationtech.io/NationTech/harmony/pulls/71
Reviewed-by: johnride <jg@nationtech.io>
This commit is contained in:
Ian Letourneau 2025-07-01 21:08:19 +00:00
parent 284cc6afd7
commit ee02906ce9

View File

@ -73,10 +73,9 @@ async fn main() {
.try_exists() .try_exists()
.expect("couldn't check if path exists"); .expect("couldn't check if path exists");
let harmony_bin_path: PathBuf; let harmony_bin_path: PathBuf = match harmony_path {
match harmony_path {
true => { true => {
harmony_bin_path = compile_harmony( compile_harmony(
cli_args.compile_method, cli_args.compile_method,
cli_args.compile_platform, cli_args.compile_platform,
cli_args.harmony_path.clone(), cli_args.harmony_path.clone(),
@ -84,7 +83,7 @@ async fn main() {
.await .await
} }
false => todo!("implement autodetect code"), false => todo!("implement autodetect code"),
} };
match cli_args.command { match cli_args.command {
Some(command) => match command { Some(command) => match command {
@ -103,8 +102,10 @@ async fn main() {
}; };
let check_output = Command::new(check_script) let check_output = Command::new(check_script)
.output() .spawn()
.expect("failed to run check script"); .expect("failed to run check script")
.wait_with_output()
.unwrap();
info!( info!(
"check stdout: {}, check stderr: {}", "check stdout: {}, check stderr: {}",
String::from_utf8(check_output.stdout).expect("couldn't parse from utf8"), String::from_utf8(check_output.stdout).expect("couldn't parse from utf8"),
@ -112,18 +113,16 @@ async fn main() {
); );
} }
Commands::Deploy(args) => { Commands::Deploy(args) => {
if args.staging { let deploy = if args.staging {
todo!("implement staging deployment"); todo!("implement staging deployment")
} else if args.prod {
todo!("implement prod deployment")
} else {
Command::new(harmony_bin_path).arg("-y").arg("-a").spawn()
} }
.expect("failed to run harmony deploy");
if args.prod { let deploy_output = deploy.wait_with_output().unwrap();
todo!("implement prod deployment");
}
let deploy_output = Command::new(harmony_bin_path)
.arg("-y")
.arg("-a")
.output()
.expect("failed to run harmony deploy");
println!( println!(
"deploy output: {}", "deploy output: {}",
String::from_utf8(deploy_output.stdout).expect("couldn't parse from utf8") String::from_utf8(deploy_output.stdout).expect("couldn't parse from utf8")