milestone: USB — enhanced checker + unified runtime harness
redbear-usb-check: rewritten from 99-line minimal checker to full Phase-pattern validation (CheckResult/Report, JSON output, proper cfg-gating). Checks xHCI controllers, USB device enumeration, HID class detection, storage class detection. test-usb-runtime.sh: guest + QEMU harness following Phase 1-5 pattern. Zero warnings.
This commit is contained in:
@@ -0,0 +1,74 @@
|
||||
#!/usr/bin/env bash
|
||||
# USB maturity runtime validation harness.
|
||||
# Follows Phase 1-5 pattern: guest + QEMU, exit-code-based.
|
||||
|
||||
set -euo pipefail
|
||||
PROG="$(basename "$0")"
|
||||
|
||||
usage() {
|
||||
cat <<'EOF'
|
||||
Usage: test-usb-runtime.sh [--guest|--qemu CONFIG]
|
||||
Exit: 0 if all pass, 1 otherwise.
|
||||
EOF
|
||||
exit 1
|
||||
}
|
||||
|
||||
MODE=""; CONFIG=""
|
||||
while [[ $# -gt 0 ]]; do
|
||||
case "$1" in
|
||||
--guest) MODE="guest"; shift ;;
|
||||
--qemu) MODE="qemu"; CONFIG="$2"; shift 2 ;;
|
||||
-h|--help) usage ;;
|
||||
*) echo "$PROG: unknown: $1"; usage ;;
|
||||
esac
|
||||
done
|
||||
[[ -z "$MODE" ]] && usage
|
||||
|
||||
run_guest_checks() {
|
||||
local failures=0
|
||||
run_check() {
|
||||
local name="$1" cmd="$2" desc="$3"
|
||||
if ! command -v "$cmd" >/dev/null 2>&1; then
|
||||
echo " FAIL $name: $cmd not found ($desc)"
|
||||
failures=$((failures + 1)); return 0
|
||||
fi
|
||||
echo " Running $name..."
|
||||
if "$cmd" --json >/dev/null 2>&1; then
|
||||
echo " PASS $name: $desc"
|
||||
else
|
||||
echo " FAIL $name: $desc (exit non-zero)"
|
||||
failures=$((failures + 1))
|
||||
fi
|
||||
}
|
||||
echo "=== USB Maturity Validation ==="; echo
|
||||
run_check "USB" "redbear-usb-check" "xHCI controller + device enumeration + class detection"
|
||||
echo
|
||||
echo "=== USB Summary ==="
|
||||
if [[ $failures -eq 0 ]]; then echo "ALL USB CHECKS PASSED"; else echo "FAILURES: $failures"; exit 1; fi; exit 0
|
||||
}
|
||||
|
||||
run_qemu_checks() {
|
||||
local arch="${ARCH:-x86_64}"
|
||||
local image="build/${arch}/${CONFIG}/harddrive.img"
|
||||
local firmware="${FIRMWARE_PATH:-/usr/share/ovmf/x64/OVMF.fd}"
|
||||
if [[ ! -f "$image" ]]; then echo "$PROG: image not found: $image"; exit 1; fi
|
||||
if [[ ! -f "$firmware" ]]; then echo "$PROG: firmware not found: $firmware"; exit 1; fi
|
||||
expect <<EXPECT_SCRIPT
|
||||
log_user 1; set timeout 300
|
||||
spawn qemu-system-x86_64 -name {Red Bear OS} -device qemu-xhci -smp 4 -m 2048 -bios $firmware -chardev stdio,id=debug,signal=off,mux=on -serial chardev:debug -mon chardev:debug -machine q35 -device virtio-net,netdev=net0 -netdev user,id=net0 -nographic -vga none -drive file=$image,format=raw,if=none,id=drv0 -device nvme,drive=drv0,serial=NVME_SERIAL -enable-kvm -cpu host
|
||||
expect "login:"; send "root\r"
|
||||
expect "assword:"; send "password\r"
|
||||
expect "Type 'help' for available commands."
|
||||
send "echo __READY__\r"; expect "__READY__"
|
||||
send "redbear-usb-check --json >/dev/null 2>&1 && echo __USB_OK__ || echo __USB_FAIL__\r"
|
||||
expect { "__USB_OK__" { } "__USB_FAIL__" { puts "FAIL: usb"; exit 1 } timeout { puts "FAIL: timeout"; exit 1 } eof { puts "FAIL: eof"; exit 1 } }
|
||||
puts "ALL USB CHECKS PASSED"
|
||||
EXPECT_SCRIPT
|
||||
exit $?
|
||||
}
|
||||
|
||||
case "$MODE" in
|
||||
guest) run_guest_checks ;;
|
||||
qemu) export FIRMWARE_PATH="${FIRMWARE_PATH:-/usr/share/ovmf/x64/OVMF.fd}"; run_qemu_checks ;;
|
||||
*) usage ;;
|
||||
esac
|
||||
Reference in New Issue
Block a user