Some checks failed
CI/CD / lint (pull_request) Failing after 13s
CI/CD / test (pull_request) Failing after 10s
CI/CD / typecheck (pull_request) Failing after 36s
CI/CD / build (pull_request) Has been skipped
CI/CD / publish-rpm (pull_request) Has been skipped
CI/CD / publish-deb (pull_request) Has been skipped
Kickstart installs on real hardware failed silently — no error reporting, only 3 progress callbacks, zero log streaming. This overhaul makes every install fully observable. Kickstart improvements: - Error trapping in %pre and %post (trap ERR sends failure details to bastion) - 12+ granular progress stages (was 3): SSH, hostname, k3s prep, EFI boot, metadata - Background log streamer: tails %post output and batch-sends to /api/log - bastion_log() function for explicit log lines from kickstart scripts Bastion API: - POST /api/log — receives raw log lines from kickstart (single or batch) - InstallLogBuffer — per-MAC ring buffer (2000 lines) + file persistence - GET /api/logs/:mac — now returns log_lines + log_total alongside stages - SSE /api/logs/:mac/follow — uses named events (event: stage vs event: log) - Progress events forwarded to labd via bastion-progress WebSocket message - Post-provision k3s logs routed through progressBus (was console-only) dnsmasq fixes found during VM testing: - HTTP Boot filename: ipxe-real.efi → ipxe.efi (leftover from old 2-stage approach) - pxe-service directives: only in proxy mode (breaks OVMF PXE in full mode) - PXEClient vendor class echo for UEFI firmware compatibility Integration tests: - PXE boot test: blank UEFI VM → dnsmasq → HTTP Boot → iPXE → bastion → install - ISO boot test: blank VM boots from bastion-generated ISO → same flow - Shared helpers: pxe-network (no DHCP, nftables fix), pxe-vm (UEFI + ISO boot) - test-provision.sh: runs both PXE + ISO tests with prerequisite checks - 250GB sparse QCOW2 disk (LVM layout needs ~204GB) 201 unit tests passing (11 new). Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
132 lines
3.3 KiB
Bash
Executable File
132 lines
3.3 KiB
Bash
Executable File
#!/bin/bash
|
|
# Run PXE and/or ISO boot integration tests.
|
|
#
|
|
# Usage:
|
|
# sudo ./scripts/test-provision.sh # run both PXE + ISO tests
|
|
# sudo ./scripts/test-provision.sh pxe # PXE only
|
|
# sudo ./scripts/test-provision.sh iso # ISO only
|
|
#
|
|
# Prerequisites:
|
|
# libvirtd, OVMF (edk2-ovmf), iPXE (ipxe-bootimgs-x86),
|
|
# dnsmasq, xorriso, mtools, virt-install, qemu-img
|
|
set -e
|
|
|
|
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)"
|
|
PROJECT_ROOT="$(dirname "$SCRIPT_DIR")"
|
|
|
|
cd "$PROJECT_ROOT"
|
|
|
|
# Detect real user for SSH keys
|
|
REAL_USER="${SUDO_USER:-$(whoami)}"
|
|
REAL_HOME=$(getent passwd "$REAL_USER" | cut -d: -f6)
|
|
|
|
RED='\033[0;31m'
|
|
GREEN='\033[0;32m'
|
|
YELLOW='\033[1;33m'
|
|
BOLD='\033[1m'
|
|
RESET='\033[0m'
|
|
|
|
echo ""
|
|
echo -e "${BOLD}Lab Bastion -- Provision Integration Tests${RESET}"
|
|
echo "==========================================="
|
|
echo ""
|
|
|
|
# --- Prerequisite checks ---
|
|
MISSING=""
|
|
for cmd in virsh virt-install qemu-img dnsmasq xorriso mformat mcopy curl; do
|
|
if ! command -v "$cmd" &>/dev/null; then
|
|
MISSING="$MISSING $cmd"
|
|
fi
|
|
done
|
|
|
|
if [ -n "$MISSING" ]; then
|
|
echo -e "${RED}Missing tools:${RESET}$MISSING"
|
|
echo "Install: sudo dnf install libvirt virt-install qemu-img dnsmasq xorriso mtools curl"
|
|
exit 1
|
|
fi
|
|
|
|
if ! systemctl is-active libvirtd &>/dev/null; then
|
|
echo -e "${RED}libvirtd not running.${RESET} Start with: sudo systemctl start libvirtd"
|
|
exit 1
|
|
fi
|
|
|
|
if [ ! -f /usr/share/edk2/ovmf/OVMF_CODE.fd ]; then
|
|
echo -e "${RED}OVMF firmware not found.${RESET} Install: sudo dnf install edk2-ovmf"
|
|
exit 1
|
|
fi
|
|
|
|
IPXE_EFI=""
|
|
for f in /usr/share/ipxe/ipxe-snponly-x86_64.efi /usr/share/ipxe/ipxe-snp-x86_64.efi /usr/share/ipxe/ipxe-x86_64.efi; do
|
|
[ -f "$f" ] && IPXE_EFI="$f" && break
|
|
done
|
|
if [ -z "$IPXE_EFI" ]; then
|
|
echo -e "${RED}iPXE EFI binary not found.${RESET} Install: sudo dnf install ipxe-bootimgs-x86"
|
|
exit 1
|
|
fi
|
|
|
|
# Find SSH key
|
|
SSH_KEY=""
|
|
for name in id_ed25519 id_ecdsa id_rsa; do
|
|
if [ -f "$REAL_HOME/.ssh/$name" ] && [ -f "$REAL_HOME/.ssh/$name.pub" ]; then
|
|
SSH_KEY="$REAL_HOME/.ssh/$name"
|
|
break
|
|
fi
|
|
done
|
|
if [ -z "$SSH_KEY" ]; then
|
|
echo -e "${RED}No SSH key found in $REAL_HOME/.ssh/${RESET}"
|
|
exit 1
|
|
fi
|
|
|
|
echo -e " User: ${BOLD}$REAL_USER${RESET}"
|
|
echo -e " SSH key: ${BOLD}$SSH_KEY${RESET}"
|
|
echo -e " iPXE: ${BOLD}$IPXE_EFI${RESET}"
|
|
echo ""
|
|
|
|
# --- Determine which tests to run ---
|
|
MODE="${1:-both}"
|
|
|
|
run_test() {
|
|
local name="$1" pattern="$2"
|
|
echo ""
|
|
echo -e "${YELLOW}━━━ Running $name test ━━━${RESET}"
|
|
echo ""
|
|
|
|
if SSH_KEY_PATH="$SSH_KEY" HOME="$REAL_HOME" \
|
|
npx vitest run -c tests/integration/vitest.config.ts -t "$pattern" 2>&1; then
|
|
echo ""
|
|
echo -e "${GREEN}✔ $name test passed${RESET}"
|
|
return 0
|
|
else
|
|
echo ""
|
|
echo -e "${RED}✘ $name test failed${RESET}"
|
|
return 1
|
|
fi
|
|
}
|
|
|
|
FAILED=0
|
|
|
|
case "$MODE" in
|
|
pxe)
|
|
run_test "PXE boot" "PXE boot" || FAILED=1
|
|
;;
|
|
iso)
|
|
run_test "ISO boot" "ISO boot" || FAILED=1
|
|
;;
|
|
both|all)
|
|
run_test "PXE boot" "PXE boot" || FAILED=1
|
|
run_test "ISO boot" "ISO boot" || FAILED=1
|
|
;;
|
|
*)
|
|
echo "Usage: $0 [pxe|iso|both]"
|
|
exit 1
|
|
;;
|
|
esac
|
|
|
|
echo ""
|
|
if [ "$FAILED" -eq 0 ]; then
|
|
echo -e "${GREEN}${BOLD}All provision tests passed.${RESET}"
|
|
else
|
|
echo -e "${RED}${BOLD}Some tests failed.${RESET}"
|
|
exit 1
|
|
fi
|