From eea68711b5187178895ed1cf784e8c336b760574 Mon Sep 17 00:00:00 2001 From: Ben Sima Date: Fri, 5 Jul 2019 19:05:31 -0700 Subject: [chip/push] better error handling/logging --- chip/push | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) (limited to 'chip/push') diff --git a/chip/push b/chip/push index 1b8c1f8..f7114ed 100755 --- a/chip/push +++ b/chip/push @@ -5,13 +5,17 @@ import os import subprocess import tempfile import importlib.util +import sys def shell(*args): "Run a shell command and capture the output." try: proc = subprocess.run(args, check=True, capture_output=True) except subprocess.CalledProcessError as e: - raise RuntimeError(f'{e.cmd} error {e.returncode}: {e.output}') + print(f'! fail {e.returncode}') + print(f'! {" ".join(e.cmd)}') + print(f'! {e.stderr.strip().decode("utf8")}') + sys.exit(1) return proc.stdout.strip().decode('utf8') cli = argparse.ArgumentParser(description='deploy a thing') @@ -29,16 +33,16 @@ out = f"{bild_dir}/{args.depo}" # bild shell("nix-build", "-A", f"depo.{args.depo}", "--out-link", out) -print("bilt") +print("+ bilt") # push shell("nix", "copy", "--to", f"ssh://root@{args.depo}", f"{out}") -print("sent") +print("+ sent") # switch shell("ssh", f"root@{args.depo}", "sudo", f"{os.readlink(out)}/bin/switch-to-configuration", "switch") -print("switched") +print("+ switched") -print(f"pushed {args.depo}") +print(f"+ pushed {args.depo}") -- cgit v1.2.3