You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

run.rs 1.3 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. use dora_tracing::set_up_tracing;
  2. use eyre::{bail, Context};
  3. use std::path::Path;
  4. #[tokio::main]
  5. async fn main() -> eyre::Result<()> {
  6. set_up_tracing("rust-dataflow-runner").wrap_err("failed to set up tracing subscriber")?;
  7. let root = Path::new(env!("CARGO_MANIFEST_DIR"));
  8. std::env::set_current_dir(root.join(file!()).parent().unwrap())
  9. .wrap_err("failed to set working dir")?;
  10. let dataflow = Path::new("dataflow.yml");
  11. build_dataflow(dataflow).await?;
  12. run_dataflow(dataflow).await?;
  13. Ok(())
  14. }
  15. async fn build_dataflow(dataflow: &Path) -> eyre::Result<()> {
  16. let cargo = std::env::var("CARGO").unwrap();
  17. let mut cmd = tokio::process::Command::new(&cargo);
  18. cmd.arg("run");
  19. cmd.arg("--package").arg("dora-cli");
  20. cmd.arg("--").arg("build").arg(dataflow);
  21. if !cmd.status().await?.success() {
  22. bail!("failed to build dataflow");
  23. };
  24. Ok(())
  25. }
  26. async fn run_dataflow(dataflow: &Path) -> eyre::Result<()> {
  27. let cargo = std::env::var("CARGO").unwrap();
  28. let mut cmd = tokio::process::Command::new(&cargo);
  29. cmd.arg("run");
  30. cmd.arg("--package").arg("dora-cli");
  31. cmd.arg("--")
  32. .arg("daemon")
  33. .arg("--run-dataflow")
  34. .arg(dataflow);
  35. if !cmd.status().await?.success() {
  36. bail!("failed to run dataflow");
  37. };
  38. Ok(())
  39. }