From 5f22a836f2c3330d9f2c3707167096e1e3ece31f Mon Sep 17 00:00:00 2001 From: Helmut Grohne Date: Sun, 6 Apr 2025 10:08:34 +0200 Subject: salsa-ci: add basic tests for debefivm-* --- tests/create-and-run.sh | 2 +- tests/efi-create-and-run.sh | 46 ++++++++++++++++++++++++++++++++++++++++++ tests/shell_interaction.expect | 2 +- 3 files changed, 48 insertions(+), 2 deletions(-) create mode 100755 tests/efi-create-and-run.sh (limited to 'tests') diff --git a/tests/create-and-run.sh b/tests/create-and-run.sh index 1d0a56d..fab04bc 100755 --- a/tests/create-and-run.sh +++ b/tests/create-and-run.sh @@ -69,4 +69,4 @@ debvm-waitssh -t 540 "$SSH_PORT" run_ssh "$@" poweroff wait -"$(dirname "$0")/shell_interaction.expect" -- -i "$IMAGE" +"$(dirname "$0")/shell_interaction.expect" -- debvm-run -i "$IMAGE" diff --git a/tests/efi-create-and-run.sh b/tests/efi-create-and-run.sh new file mode 100755 index 0000000..2b70662 --- /dev/null +++ b/tests/efi-create-and-run.sh @@ -0,0 +1,46 @@ +#!/bin/sh + +if test "$#" -ne 2; then + echo "$(basename "$0") takes two positional arguments: architecture and release" 1>&2 + exit 1 +fi +ARCHITECTURE=$1 +RELEASE=$2 +SSH_KEYPATH=ssh_id +IMAGE=test.img + +set -eux + +. "$(dirname "$0")/test_common.sh" + +cleanup() { + rm -f "$SSH_KEYPATH" "$SSH_KEYPATH.pub" "$IMAGE" +} + +trap cleanup EXIT INT TERM QUIT + +ssh-keygen -f "$SSH_KEYPATH" -N '' +set -- -- +if test -z "$RELEASE"; then + # The ordering of maybe-merged-usr and + # copy-host-apt-sources-and-preferences is unfortunately the wrong way + # round. Therefore, we make debvm-create skip it and pass it ourselves. + # The final empty string is the mirror specification. + set -- \ + --skip=usrmerge \ + "$@" \ + --hook-dir=/usr/share/mmdebstrap/hooks/copy-host-apt-sources-and-preferences \ + --hook-dir=/usr/share/mmdebstrap/hooks/file-mirror-automount \ + --hook-dir=/usr/share/mmdebstrap/hooks/maybe-merged-usr \ + "" +fi +debefivm-create -k "$SSH_KEYPATH.pub" -o "$IMAGE" -r "$RELEASE" -a "$ARCHITECTURE" "$@" + +SSH_PORT=2222 +timeout 600s debefivm-run -s "$SSH_PORT" -i "$IMAGE" & +set -- localhost +debvm-waitssh -t 540 "$SSH_PORT" +run_ssh "$@" poweroff +wait + +"$(dirname "$0")/shell_interaction.expect" -- debefivm-run -i "$IMAGE" diff --git a/tests/shell_interaction.expect b/tests/shell_interaction.expect index 325e476..72f8676 100755 --- a/tests/shell_interaction.expect +++ b/tests/shell_interaction.expect @@ -1,7 +1,7 @@ #!/usr/bin/expect set args [lrange $argv 0 end] set timeout 300 -spawn debvm-run {*}$args +spawn {*}$args expect "root@testvm:~#" set timeout 10 send "echo 6coF0JBW\$((2+3))\r" -- cgit v1.2.3 From 4991b8e2a0456c1f96042fd7206983738b9a3946 Mon Sep 17 00:00:00 2001 From: Helmut Grohne Date: Sun, 6 Apr 2025 17:33:06 +0200 Subject: salsa-ci: add a test case for the mmdebstrap-autopkgtest-build-qemu use case --- .gitlab-ci.yml | 7 +++++++ tests/autopkgtest-qemu-efi.sh | 46 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 53 insertions(+) create mode 100755 tests/autopkgtest-qemu-efi.sh (limited to 'tests') diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 97fc9a0..fd9b193 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -92,3 +92,10 @@ arch_test_efi: - apt-get --no-install-recommends --yes install dosfstools dpkg-dev e2fsprogs expect fdisk mmdebstrap mount mtools openssh-client ovmf qemu-efi-aarch64 qemu-efi-arm qemu-efi-riscv64 qemu-system arch-test qemu-user-static systemd systemd-ukify - /lib/systemd/systemd-binfmt - PATH=$(pwd)/bin:$PATH ./tests/efi-create-and-run.sh "$ARCHITECTURE" "$DEFAULT_SUITE" + +autopkgtest-qemu-efi: + script: + - apt-get update + - apt-get dist-upgrade --yes + - apt-get --no-install-recommends --yes install autopkgtest dosfstools e2fsprogs fdisk mmdebstrap mount mtools ovmf qemu-utils qemu-kvm systemd systemd-ukify + - PATH=$(pwd)/bin:$PATH ./tests/autopkgtest-qemu-efi.sh "$ARCHITECTURE" "$DEFAULT_SUITE" diff --git a/tests/autopkgtest-qemu-efi.sh b/tests/autopkgtest-qemu-efi.sh new file mode 100755 index 0000000..bc761d5 --- /dev/null +++ b/tests/autopkgtest-qemu-efi.sh @@ -0,0 +1,46 @@ +#!/bin/sh + +set -eux + +IMAGE=test.img +RELEASE="${1:-}" + +cleanup() { + rm -f "$IMAGE" +} +trap cleanup EXIT +cleanup_abort() { + cleanup + echo aborted >&2 + exit 2 +} +trap cleanup_abort HUP INT TERM QUIT + +INSTALL_LOCATION=$(command -v debefivm-create) +if test "${INSTALL_LOCATION#/usr/}" = "$INSTALL_LOCATION"; then + USERADDHOOK="${INSTALL_LOCATION%/*}/../useraddhook" +else + USERADDHOOK=/usr/share/mmdebstrap/hooks/useradd +fi + +set -- -- +if test -z "$RELEASE"; then + # We no longer need usrmerge in trixie and later and it does not work + # with copy-host-apt-sources-and-preferences in the default order. + set -- \ + --skip=usrmerge \ + "$@" \ + --hook-dir=/usr/share/mmdebstrap/hooks/copy-host-apt-sources-and-preferences \ + --hook-dir=/usr/share/mmdebstrap/hooks/file-mirror-automount \ + "" +fi + +debefivm-create \ + -o "$IMAGE" \ + -r "$RELEASE" \ + "$@" \ + --include=linux-image-generic,libpam-systemd,passwd,python3 \ + --hook-dir="$USERADDHOOK" \ + --customize-hook=/usr/share/autopkgtest/setup-commands/setup-testbed + +autopkgtest hello -- qemu --boot=efi --show-boot "$IMAGE" -- cgit v1.2.3