diff options
-rwxr-xr-x | chip/push | 27 |
1 files changed, 15 insertions, 12 deletions
@@ -6,6 +6,14 @@ import subprocess import tempfile import importlib.util +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}') + return proc.stdout.strip().decode('utf8') + cli = argparse.ArgumentParser(description='deploy a thing') cli.add_argument('depo', type=str, help='the depo roun to deploy') @@ -20,22 +28,17 @@ out = f"{bild_dir}/{args.depo}" # bild -subprocess.run(["nix-build", "-A", f"depo.{args.depo}", - "--out-link", out]) +shell("nix-build", "-A", f"depo.{args.depo}", "--out-link", out) print("bilt") -# get roun -p = subprocess.run(["chip/roun", args.depo, "-i"], - stdout=subprocess.PIPE) -ip = p.stdout.decode() - # push -subprocess.run(["nix", "copy", "--to", f"ssh://root@{ip}", f"{out}"]) +shell("nix", "copy", "--to", f"ssh://root@{args.depo}", f"{out}") print("sent") # switch -subprocess.run(["ssh", f"root@{ip}", "sudo", - f"{os.readlink(out)}/bin/switch-to-configuration", - "switch"]) +shell("ssh", f"root@{args.depo}", "sudo", + f"{os.readlink(out)}/bin/switch-to-configuration", + "switch") +print("switched") -print(f"pushed {args.depo} -> {ip}") +print(f"pushed {args.depo}") |