Files
proxmox/scripts/verify/run-all-validation.sh
2026-04-24 10:56:01 -07:00

182 lines
6.5 KiB
Bash

#!/usr/bin/env bash
# Run all validation checks that do not require LAN/SSH/credentials.
# Use for CI or pre-deploy: dependencies, config files, optional genesis.
# Usage: bash scripts/verify/run-all-validation.sh [--skip-genesis]
# --skip-genesis: do not run validate-genesis.sh (default: run if smom-dbis-138 present).
# Steps: dependencies, config files, cW* mesh matrix (if pair-discovery JSON exists), optional advisory non-EVM public health, genesis.
set -euo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
cd "$PROJECT_ROOT"
# shellcheck source=./scripts/lib/run-summary.sh
source "$PROJECT_ROOT/scripts/lib/run-summary.sh"
RUN_STARTED_AT="$(date -u +"%Y-%m-%dT%H:%M:%SZ")"
SECONDS=0
SKIP_GENESIS=false
JSON_OUT=""
while [[ $# -gt 0 ]]; do
case "$1" in
--skip-genesis)
SKIP_GENESIS=true
shift
;;
--json-out)
[[ $# -ge 2 ]] || { echo "Missing value for --json-out" >&2; exit 1; }
JSON_OUT="$2"
shift 2
;;
-h|--help)
sed -n '1,6p' "$0"
echo " --json-out PATH Write a machine-readable run summary JSON."
exit 0
;;
*)
echo "Unknown argument: $1" >&2
exit 1
;;
esac
done
RUN_STATUS="failed"
run_summary_init "run-all-validation.sh" "$RUN_STARTED_AT" "$JSON_OUT"
trap 'run_summary_write "$RUN_STATUS" "$SECONDS" "run"; run_summary_cleanup' EXIT
log_ok() { echo -e "\033[0;32m[✓]\033[0m $1"; }
log_err() { echo -e "\033[0;31m[✗]\033[0m $1"; exit 1; }
format_duration() { printf '%02dm:%02ds' "$(($1 / 60))" "$(($1 % 60))"; }
step_done() { echo " Completed in $(format_duration "$((SECONDS - $1))")"; }
echo "=== Run all validation (no LAN/SSH) ==="
echo "Started (UTC): $RUN_STARTED_AT"
echo ""
echo "1. Dependencies..."
STEP_STARTED=$SECONDS
bash "$SCRIPT_DIR/check-dependencies.sh" || log_err "check-dependencies failed"
log_ok "Dependencies OK"
run_summary_record_step "1" "Dependencies" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
echo "1b. pnpm workspace vs lockfile..."
STEP_STARTED=$SECONDS
if [[ -f "$PROJECT_ROOT/pnpm-workspace.yaml" ]]; then
bash "$SCRIPT_DIR/check-pnpm-workspace-lockfile.sh" || log_err "pnpm lockfile / workspace drift"
log_ok "pnpm lockfile aligned with workspace"
else
echo " (no pnpm-workspace.yaml at root — skip)"
fi
run_summary_record_step "1b" "pnpm workspace vs lockfile" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
echo "1c. Gitea workflow source sync..."
STEP_STARTED=$SECONDS
bash "$SCRIPT_DIR/check-gitea-workflows.sh" || log_err "Gitea workflow source drift"
log_ok "Gitea workflows match source-of-truth files"
run_summary_record_step "1c" "Gitea workflow source sync" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
echo "1d. main/master workflow parity..."
STEP_STARTED=$SECONDS
bash "$SCRIPT_DIR/check-gitea-branch-workflow-parity.sh" || log_err "main/master workflow parity drift"
log_ok "main/master workflow parity OK"
run_summary_record_step "1d" "main/master workflow parity" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
echo "2. Config files..."
STEP_STARTED=$SECONDS
bash "$SCRIPT_DIR/../validation/validate-config-files.sh" || log_err "validate-config-files failed"
log_ok "Config validation OK"
run_summary_record_step "2" "Config files" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
echo "3. cW* mesh matrix (deployment-status + Uni V2 pair-discovery)..."
STEP_STARTED=$SECONDS
DISCOVERY_JSON="$PROJECT_ROOT/reports/extraction/promod-uniswap-v2-live-pair-discovery-latest.json"
if [[ -f "$DISCOVERY_JSON" ]]; then
MATRIX_JSON="$PROJECT_ROOT/reports/status/cw-mesh-deployment-matrix-latest.json"
bash "$SCRIPT_DIR/build-cw-mesh-deployment-matrix.sh" --no-markdown --json-out "$MATRIX_JSON" || log_err "cw mesh matrix merge failed"
log_ok "cW mesh matrix OK (also wrote $MATRIX_JSON)"
else
echo " ($DISCOVERY_JSON missing — run: bash scripts/verify/build-promod-uniswap-v2-live-pair-discovery.sh)"
fi
run_summary_record_step "3" "cW mesh matrix" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
echo "3b. deployment-status graph (cross-chain-pmm-lps)..."
STEP_STARTED=$SECONDS
PMM_VALIDATE="$PROJECT_ROOT/cross-chain-pmm-lps/scripts/validate-deployment-status.cjs"
if [[ -f "$PMM_VALIDATE" ]] && command -v node &>/dev/null; then
node "$PMM_VALIDATE" || log_err "validate-deployment-status.cjs failed"
log_ok "deployment-status.json rules OK"
else
echo " (skip: node or $PMM_VALIDATE missing)"
fi
run_summary_record_step "3b" "deployment-status graph" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
echo "3c. External dependency blockers..."
STEP_STARTED=$SECONDS
EXT_CHECK="$SCRIPT_DIR/check-external-dependencies.sh"
if [[ -x "$EXT_CHECK" ]]; then
bash "$EXT_CHECK" --advisory || true
else
echo " (skip: $EXT_CHECK missing)"
fi
run_summary_record_step "3c" "External dependency blockers" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
echo "3d. Non-EVM public network health (advisory)..."
STEP_STARTED=$SECONDS
NON_EVM_CHECK="$SCRIPT_DIR/check-non-evm-network-health.sh"
NON_EVM_REPORT="$SCRIPT_DIR/build-non-evm-lane-status.py"
if [[ -x "$NON_EVM_CHECK" ]]; then
bash "$NON_EVM_CHECK" --json-out "$PROJECT_ROOT/reports/status/non-evm-network-health-latest.json" || true
if [[ -x "$NON_EVM_REPORT" ]]; then
python3 "$NON_EVM_REPORT" || log_err "build-non-evm-lane-status.py failed"
log_ok "non-EVM lane status refreshed"
else
echo " (skip report: $NON_EVM_REPORT missing)"
fi
else
echo " (skip: $NON_EVM_CHECK missing)"
fi
run_summary_record_step "3d" "Non-EVM public network health" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
echo ""
if [[ "$SKIP_GENESIS" == true ]]; then
echo "4. Genesis — skipped (--skip-genesis)"
run_summary_record_step "4" "Genesis (smom-dbis-138)" "skipped" "0"
else
echo "4. Genesis (smom-dbis-138)..."
STEP_STARTED=$SECONDS
GENESIS_SCRIPT="$PROJECT_ROOT/smom-dbis-138/scripts/validation/validate-genesis.sh"
if [[ -x "$GENESIS_SCRIPT" ]]; then
bash "$GENESIS_SCRIPT" || log_err "validate-genesis failed"
log_ok "Genesis OK"
else
echo " (smom-dbis-138/scripts/validation/validate-genesis.sh not found, skipping)"
fi
run_summary_record_step "4" "Genesis (smom-dbis-138)" "success" "$((SECONDS - STEP_STARTED))"
step_done "$STEP_STARTED"
fi
echo ""
log_ok "All validation passed."
echo "Total elapsed: $(format_duration "$SECONDS")"
RUN_STATUS="success"
exit 0