mirror of
https://github.com/Tyrrrz/DiscordChatExporter.git
synced 2026-06-09 15:52:37 -06:00
Mount logs/ in compose, map DCE_RUN_SUMMARY_FILE to /logs, and auto-enable JSON summary beside operator-validation log files when scraping.
100 lines
2.8 KiB
Bash
Executable file
100 lines
2.8 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
set -Eeuo pipefail
|
|
|
|
REPO_ROOT=$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." && pwd -P)
|
|
RUNNER="$REPO_ROOT/scripts/run-operator-validation.sh"
|
|
TMP_DIR=$(mktemp -d "${TMPDIR:-/tmp}/dce-op-val-smoke.XXXXXX")
|
|
ARCHIVE_ROOT="$TMP_DIR/archive"
|
|
CONFIG_PATH="$TMP_DIR/config.json"
|
|
ENV_PATH="$TMP_DIR/scrape.env"
|
|
LOG_DIR="$TMP_DIR/logs"
|
|
FAKE_DOCKER="$TMP_DIR/docker"
|
|
PATH_BACKUP="$PATH"
|
|
|
|
cleanup() {
|
|
export PATH="$PATH_BACKUP"
|
|
rm -rf "$TMP_DIR"
|
|
}
|
|
trap cleanup EXIT
|
|
|
|
mkdir -p "$ARCHIVE_ROOT/demo" "$LOG_DIR"
|
|
printf '{"messages":[{"id":"1"}],"channel":{"id":"111111111111111111"}}\n' \
|
|
>"$ARCHIVE_ROOT/demo/Guild - general [111111111111111111].json"
|
|
|
|
mkdir -p "$ARCHIVE_ROOT/demo2"
|
|
printf '{"messages":[{"id":"1"}],"channel":{"id":"222222222222222222"}}\n' \
|
|
>"$ARCHIVE_ROOT/demo2/Guild - other [222222222222222222].json"
|
|
|
|
cat >"$CONFIG_PATH" <<JSON
|
|
{
|
|
"archive_root": "$ARCHIVE_ROOT",
|
|
"targets": [
|
|
{
|
|
"name": "demo",
|
|
"kind": "guild",
|
|
"output_dir": "$ARCHIVE_ROOT/demo",
|
|
"enabled": true
|
|
},
|
|
{
|
|
"name": "demo2",
|
|
"kind": "guild",
|
|
"output_dir": "$ARCHIVE_ROOT/demo2",
|
|
"enabled": true
|
|
}
|
|
]
|
|
}
|
|
JSON
|
|
|
|
printf 'DISCORD_TOKEN=dummy\n' >"$ENV_PATH"
|
|
|
|
cat >"$FAKE_DOCKER" <<'EOF'
|
|
#!/usr/bin/env bash
|
|
if [[ "${1:-}" == "compose" && "${2:-}" == "version" ]]; then
|
|
exit 0
|
|
fi
|
|
exit 1
|
|
EOF
|
|
chmod +x "$FAKE_DOCKER"
|
|
export PATH="$TMP_DIR:$PATH_BACKUP"
|
|
|
|
DCE_MIN_FREE_MB=0 DCE_REPO_ROOT="$REPO_ROOT" DCE_CONFIG_FILE="$CONFIG_PATH" DCE_ENV_FILE="$ENV_PATH" \
|
|
DCE_LOG_DIR="$LOG_DIR" \
|
|
"$RUNNER" --dry-run --per-target --config "$CONFIG_PATH" --log-file "$LOG_DIR/validation.log"
|
|
|
|
grep -q 'Per-target summary: 2 succeeded, 0 failed' "$LOG_DIR/validation.log" || {
|
|
printf 'ERROR: per-target summary missing from log\n' >&2
|
|
exit 1
|
|
}
|
|
|
|
grep -q 'Operator validation finished successfully' "$LOG_DIR/validation.log" || {
|
|
printf 'ERROR: validation log missing success marker\n' >&2
|
|
exit 1
|
|
}
|
|
|
|
if grep -q 'JSON summary file:' "$LOG_DIR/validation.log"; then
|
|
printf 'ERROR: dry-run should not enable JSON summary export\n' >&2
|
|
exit 1
|
|
fi
|
|
|
|
SALVAGE_LOG="$LOG_DIR/salvage-validation.log"
|
|
DCE_MIN_FREE_MB=0 DCE_REPO_ROOT="$REPO_ROOT" DCE_CONFIG_FILE="$CONFIG_PATH" DCE_ENV_FILE="$ENV_PATH" \
|
|
DCE_LOG_DIR="$LOG_DIR" DCE_SKIP_SCRAPE_LOCK=1 \
|
|
"$RUNNER" --salvage-only --target demo --config "$CONFIG_PATH" --log-file "$SALVAGE_LOG"
|
|
|
|
grep -q 'Mode: salvage-only' "$SALVAGE_LOG" || {
|
|
printf 'ERROR: salvage-only mode not logged\n' >&2
|
|
exit 1
|
|
}
|
|
grep -q 'run-documents-scrape (salvage-only)' "$SALVAGE_LOG" || {
|
|
printf 'ERROR: salvage-only documents scrape step missing\n' >&2
|
|
exit 1
|
|
}
|
|
grep -q 'Operator validation finished successfully' "$SALVAGE_LOG" || {
|
|
printf 'ERROR: salvage-only validation did not succeed\n' >&2
|
|
cat "$SALVAGE_LOG" >&2
|
|
exit 1
|
|
}
|
|
|
|
printf 'run-operator-validation-smoke: ok\n'
|