aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornotgne22020-10-26 12:24:57 -0700
committernotgne22020-10-26 12:24:57 -0700
commit426fb3c489dcbb4ccbf98a3ab6a7fe25e71b95ca (patch)
treed0f31955251d9a5570e8309059448862d08884ce
parent8b3b91344abe6b6361b22943a0176e41fb2d585c (diff)
Automatically run checks when deploying
-rw-r--r--src/main.rs44
1 files changed, 43 insertions, 1 deletions
diff --git a/src/main.rs b/src/main.rs
index 1358a83..48fb482 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -40,6 +40,10 @@ struct Opts {
#[clap(short, long)]
result_path: Option<String>,
+ /// Skip the automatic pre-build checks
+ #[clap(short, long)]
+ skip_checks: bool,
+
/// Override the SSH user with the given value
#[clap(long)]
ssh_user: Option<String>,
@@ -197,8 +201,42 @@ async fn test_flake_support() -> Result<bool, Box<dyn std::error::Error>> {
.success())
}
+async fn check_deployment(supports_flakes: bool, repo: &str, extra_build_args: &[String]) -> () {
+ let mut c = match supports_flakes {
+ true => Command::new("nix"),
+ false => Command::new("nix-build"),
+ };
+
+ let mut check_command = match supports_flakes {
+ true => {
+ c.arg("flake")
+ .arg("check")
+ .arg(repo)
+ }
+ false => {
+ c.arg("-E")
+ .arg("--no-out-link")
+ .arg(format!("let r = import {}/.; in (if builtins.isFunction r then (r {{}}) else r).checks.${{builtins.currentSystem}}", repo))
+ }
+ };
+
+ for extra_arg in extra_build_args {
+ check_command = check_command.arg(extra_arg);
+ }
+
+ let check_status = match check_command.status().await {
+ Ok(x) => x,
+ Err(err) => good_panic!("Error running checks for the given flake repo: {:?}", err),
+ };
+
+ if !check_status.success() {
+ good_panic!("Checks failed for the given flake repo");
+ }
+
+ ()
+}
+
/// Evaluates the Nix in the given `repo` and return the processed Data from it
-#[inline]
async fn get_deployment_data(
supports_flakes: bool,
repo: &str,
@@ -374,6 +412,10 @@ async fn main() -> Result<(), Box<dyn std::error::Error>> {
warn!("A Nix version without flakes support was detected, support for this is work in progress");
}
+ if !opts.skip_checks {
+ check_deployment(supports_flakes, deploy_flake.repo, &opts.extra_build_args).await;
+ }
+
let data =
get_deployment_data(supports_flakes, deploy_flake.repo, &opts.extra_build_args).await?;