#!/usr/bin/env bash set -Eeuo pipefail REPO_ROOT=$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." && pwd -P) PROOF="$REPO_ROOT/scripts/run-operator-proof.sh" TMP_DIR=$(mktemp -d "${TMPDIR:-/tmp}/dce-operator-proof-smoke.XXXXXX") CONFIG_PATH="$TMP_DIR/config.json" ENV_PATH="$TMP_DIR/scrape.env" mkdir -p "$TMP_DIR/logs" cleanup() { rm -rf "$TMP_DIR" } trap cleanup EXIT mkdir -p "$TMP_DIR/archive/demo" printf '{"messages":[{"id":"1"}],"channel":{"id":"111111111111111111"}}\n' \ >"$TMP_DIR/archive/demo/Guild - general [111111111111111111].json" cat >"$CONFIG_PATH" <"$ENV_PATH" COMPOSE_FILE="$TMP_DIR/docker-compose.yml" FAKE_DOCKER="$TMP_DIR/docker" cat >"$COMPOSE_FILE" <<'EOF' services: discord-scraper: image: fake EOF cat >"$FAKE_DOCKER" <<'EOF' #!/usr/bin/env bash printf 'run succeeded\n' EOF chmod +x "$FAKE_DOCKER" set +e output=$( DCE_MIN_FREE_MB=0 \ DCE_CONFIG_FILE="$CONFIG_PATH" \ DCE_ENV_FILE="$ENV_PATH" \ "$PROOF" --config "$CONFIG_PATH" --target demo --dry-run 2>&1 ) status=$? set -e if [[ "$status" -ne 0 ]] || ! grep -q 'Dry run complete' <<<"$output"; then printf 'run-operator-proof dry-run failed (status=%s)\n' "$status" >&2 printf '%s\n' "$output" >&2 exit 1 fi grep -q 'Operator proof run plan' <<<"$output" || { echo "expected Operator proof run plan in dry-run output" >&2 exit 1 } if grep -q 'JSON summary file:' <<<"$output"; then echo "dry-run should not enable JSON summary export" >&2 exit 1 fi set +e salvage_output=$( DCE_MIN_FREE_MB=0 \ DCE_CONFIG_FILE="$CONFIG_PATH" \ DCE_ENV_FILE="$ENV_PATH" \ DCE_SKIP_SCRAPE_LOCK=1 \ "$PROOF" --config "$CONFIG_PATH" --target demo --salvage-only 2>&1 ) salvage_status=$? set -e if [[ "$salvage_status" -ne 0 ]] || ! grep -q 'Salvage-only proof complete' <<<"$salvage_output"; then printf 'run-operator-proof --salvage-only failed (status=%s)\n' "$salvage_status" >&2 printf '%s\n' "$salvage_output" >&2 exit 1 fi if grep -q 'JSON summary file:' <<<"$salvage_output"; then echo "salvage-only should not enable JSON summary export" >&2 exit 1 fi set +e salvage_before_output=$( DCE_MIN_FREE_MB=0 \ DCE_CONFIG_FILE="$CONFIG_PATH" \ DCE_ENV_FILE="$ENV_PATH" \ DCE_SKIP_SCRAPE_LOCK=1 \ DCE_DOCKER_BIN="$FAKE_DOCKER" \ DCE_COMPOSE_FILE="$COMPOSE_FILE" \ "$PROOF" --config "$CONFIG_PATH" --target demo --salvage-before-scrape 2>&1 ) salvage_before_status=$? set -e if [[ "$salvage_before_status" -ne 0 ]] || ! grep -q 'salvage completed' <<<"$salvage_before_output"; then printf 'run-operator-proof --salvage-before-scrape failed (status=%s)\n' "$salvage_before_status" >&2 printf '%s\n' "$salvage_before_output" >&2 exit 1 fi grep -q 'Operator proof passed for demo' <<<"$salvage_before_output" || { printf 'expected operator proof to pass after salvage-before scrape\n' >&2 printf '%s\n' "$salvage_before_output" >&2 exit 1 } grep -q 'JSON summary file:' <<<"$salvage_before_output" || { printf 'expected JSON summary path when operator proof scrapes\n' >&2 exit 1 } command -v flock >/dev/null 2>&1 && { LOCK_FILE="$TMP_DIR/archive/.dce-scrape.lock" HOLDER_PID="" ( exec {lock_fd}>>"$LOCK_FILE" flock -n "$lock_fd" || exit 1 sleep 120 ) & HOLDER_PID=$! sleep 0.2 set +e blocked_output=$( DCE_MIN_FREE_MB=0 \ DCE_CONFIG_FILE="$CONFIG_PATH" \ DCE_ENV_FILE="$ENV_PATH" \ DCE_LOG_DIR="$TMP_DIR/logs" \ "$REPO_ROOT/scripts/run-operator-validation.sh" \ --salvage-only --target demo --config "$CONFIG_PATH" \ --log-file "$TMP_DIR/logs/lock-blocked.log" 2>&1 ) blocked_status=$? set -e kill "$HOLDER_PID" 2>/dev/null || true wait "$HOLDER_PID" 2>/dev/null || true if [[ "$blocked_status" -eq 0 ]] || ! grep -q 'Scrape lock is held' <<<"$blocked_output"; then printf 'expected validation to fail when scrape lock held (status=%s)\n' "$blocked_status" >&2 printf '%s\n' "$blocked_output" >&2 exit 1 fi } printf 'run-operator-proof-smoke: ok\n'