mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-06 19:10:58 +00:00
89 lines
2.7 KiB
Bash
89 lines
2.7 KiB
Bash
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
ROOT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")/../.." && pwd)"
|
|
source "$ROOT_DIR/scripts/lib/docker-e2e-image.sh"
|
|
IMAGE_NAME="$(docker_e2e_resolve_image "openclaw-cron-mcp-cleanup-e2e" OPENCLAW_IMAGE)"
|
|
PORT="18789"
|
|
TOKEN="cron-mcp-e2e-$(date +%s)-$$"
|
|
CONTAINER_NAME="openclaw-cron-mcp-e2e-$$"
|
|
CLIENT_LOG="$(mktemp -t openclaw-cron-mcp-client-log.XXXXXX)"
|
|
|
|
cleanup() {
|
|
docker rm -f "$CONTAINER_NAME" >/dev/null 2>&1 || true
|
|
rm -f "$CLIENT_LOG"
|
|
}
|
|
trap cleanup EXIT
|
|
|
|
docker_e2e_build_or_reuse "$IMAGE_NAME" cron-mcp-cleanup
|
|
|
|
echo "Running in-container cron/subagent MCP cleanup smoke..."
|
|
set +e
|
|
docker run --rm \
|
|
--name "$CONTAINER_NAME" \
|
|
-e "OPENCLAW_GATEWAY_TOKEN=$TOKEN" \
|
|
-e "OPENCLAW_SKIP_CHANNELS=1" \
|
|
-e "OPENCLAW_SKIP_GMAIL_WATCHER=1" \
|
|
-e "OPENCLAW_SKIP_CANVAS_HOST=1" \
|
|
-e "OPENCLAW_STATE_DIR=/tmp/openclaw-state" \
|
|
-e "OPENCLAW_CONFIG_PATH=/tmp/openclaw-state/openclaw.json" \
|
|
-e "GW_URL=ws://127.0.0.1:$PORT" \
|
|
-e "GW_TOKEN=$TOKEN" \
|
|
-e "OPENCLAW_ALLOW_INSECURE_PRIVATE_WS=1" \
|
|
"$IMAGE_NAME" \
|
|
bash -lc "set -euo pipefail
|
|
entry=dist/index.mjs
|
|
[ -f \"\$entry\" ] || entry=dist/index.js
|
|
node --import tsx scripts/e2e/cron-mcp-cleanup-seed.ts >/tmp/cron-mcp-cleanup-seed.log
|
|
node \"\$entry\" gateway --port $PORT --bind loopback --allow-unconfigured >/tmp/cron-mcp-cleanup-gateway.log 2>&1 &
|
|
gateway_pid=\$!
|
|
cleanup_inner() {
|
|
kill \"\$gateway_pid\" >/dev/null 2>&1 || true
|
|
wait \"\$gateway_pid\" >/dev/null 2>&1 || true
|
|
}
|
|
dump_gateway_log_on_error() {
|
|
status=\$?
|
|
if [ \"\$status\" -ne 0 ]; then
|
|
tail -n 80 /tmp/cron-mcp-cleanup-gateway.log 2>/dev/null || true
|
|
cat /tmp/cron-mcp-cleanup-seed.log 2>/dev/null || true
|
|
fi
|
|
cleanup_inner
|
|
exit \"\$status\"
|
|
}
|
|
trap cleanup_inner EXIT
|
|
trap dump_gateway_log_on_error ERR
|
|
for _ in \$(seq 1 80); do
|
|
if node --input-type=module -e '
|
|
import net from \"node:net\";
|
|
const socket = net.createConnection({ host: \"127.0.0.1\", port: $PORT });
|
|
const timeout = setTimeout(() => {
|
|
socket.destroy();
|
|
process.exit(1);
|
|
}, 400);
|
|
socket.on(\"connect\", () => {
|
|
clearTimeout(timeout);
|
|
socket.end();
|
|
process.exit(0);
|
|
});
|
|
socket.on(\"error\", () => {
|
|
clearTimeout(timeout);
|
|
process.exit(1);
|
|
});
|
|
' >/dev/null 2>&1; then
|
|
break
|
|
fi
|
|
sleep 0.25
|
|
done
|
|
node --import tsx scripts/e2e/cron-mcp-cleanup-docker-client.ts
|
|
" >"$CLIENT_LOG" 2>&1
|
|
status=${PIPESTATUS[0]}
|
|
set -e
|
|
|
|
if [ "$status" -ne 0 ]; then
|
|
echo "Docker cron/subagent MCP cleanup smoke failed"
|
|
cat "$CLIENT_LOG"
|
|
exit "$status"
|
|
fi
|
|
|
|
echo "OK"
|