summary refs log tree commit diff
diff options
context:
space:
mode:
authorAlyssa Ross <hi@alyssa.is>2023-05-26 20:44:34 +0000
committerAlyssa Ross <hi@alyssa.is>2023-05-27 21:35:31 +0000
commit6b34ec8a8ba7c48837edcec06be808d773ce793a (patch)
treef10ae4f37d5e4548e0d9057a4c826d0c34f34859
parent1c6893145bdf023cd03b7675a18749ce8ed3803f (diff)
downloadspectrum-6b34ec8a8ba7c48837edcec06be808d773ce793a.tar
spectrum-6b34ec8a8ba7c48837edcec06be808d773ce793a.tar.gz
spectrum-6b34ec8a8ba7c48837edcec06be808d773ce793a.tar.bz2
spectrum-6b34ec8a8ba7c48837edcec06be808d773ce793a.tar.lz
spectrum-6b34ec8a8ba7c48837edcec06be808d773ce793a.tar.xz
spectrum-6b34ec8a8ba7c48837edcec06be808d773ce793a.tar.zst
spectrum-6b34ec8a8ba7c48837edcec06be808d773ce793a.zip
release/checks/try.nix: init
This is a regression test for c7f87f3 ("host/rootfs: allow growing ext
partition to fail").  It's the first time we're actually doing
automated tests of a Spectrum boot.  For now, I'm using the NixOS test
framework, but because we're not using NixOS and not setting any NixOS
options, it feels to me like it doesn't actually buy us very much, so
if it doesn't start adding more value as we add more (or more complex)
tests, it might be simpler to just use a shell/execline script for
tests.

Signed-off-by: Alyssa Ross <hi@alyssa.is>
Message-Id: <20230526210757.397735-1-hi@alyssa.is>
Reviewed-by: Ryan Lahfa <ryan@lahfa.xyz>
-rw-r--r--release/checks/default.nix2
-rw-r--r--release/checks/try.nix51
-rw-r--r--release/live/default.nix2
3 files changed, 54 insertions, 1 deletions
diff --git a/release/checks/default.nix b/release/checks/default.nix
index f8a3f9b..bf26b9a 100644
--- a/release/checks/default.nix
+++ b/release/checks/default.nix
@@ -15,4 +15,6 @@ import ../../lib/eval-config.nix ({ ... } @ args:
   rustfmt = import ./rustfmt.nix args;
 
   shellcheck = import ./shellcheck.nix args;
+
+  try = import ./try.nix args;
 })
diff --git a/release/checks/try.nix b/release/checks/try.nix
new file mode 100644
index 0000000..62fade9
--- /dev/null
+++ b/release/checks/try.nix
@@ -0,0 +1,51 @@
+# SPDX-License-Identifier: MIT
+# SPDX-FileCopyrightText: 2023 Alyssa Ross <hi@alyssa.is>
+
+import ../../lib/eval-config.nix ({ config, ... }:
+
+let
+  live = import ../live { inherit config; };
+in
+
+config.pkgs.nixosTest ({ stdenv, mtools, ... }: {
+  name = "try-spectrum-test";
+  nodes = {};
+
+  testScript = ''
+    import shlex
+    import subprocess
+
+    conf = subprocess.run([
+      "${mtools}/bin/mcopy",
+      "-i",
+      "${live}@@1M",
+      "::loader/entries/spectrum.conf",
+      "-",
+    ], stdout=subprocess.PIPE)
+    conf.check_returncode()
+
+    cmdline = None
+    for line in conf.stdout.decode('utf-8').splitlines():
+      key, value = line.split(' ', 1)
+      if key == 'options':
+        cmdline = value
+        break
+
+    flags = " ".join(map(shlex.quote, [
+      "qemu-kvm",
+      "-m", "512",
+      "-kernel", "${live.rootfs.kernel}/${stdenv.hostPlatform.linux-kernel.target}",
+      "-initrd", "${live.initramfs}",
+      "-device", "qemu-xhci",
+      "-device", "usb-storage,drive=drive1,removable=true",
+      "-drive", "file=${live},id=drive1,format=raw,if=none,readonly=on",
+      "-append", f"panic=-1 {cmdline}",
+    ]))
+
+    machine = create_machine({"startCommand": flags})
+
+    machine.start()
+    machine.wait_for_console_text("EXT4-fs \(sda4\): mounted filesystem")
+    machine.crash()
+  '';
+}))
diff --git a/release/live/default.nix b/release/live/default.nix
index b7ee036..6df73d4 100644
--- a/release/live/default.nix
+++ b/release/live/default.nix
@@ -48,6 +48,6 @@ stdenvNoCC.mkDerivation {
 
   enableParallelBuilding = true;
 
-  passthru = { inherit rootfs; };
+  passthru = { inherit initramfs rootfs; };
 }
 ) {})