mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-06 19:40:42 +00:00
113 lines
3.8 KiB
Bash
113 lines
3.8 KiB
Bash
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
source scripts/lib/openclaw-e2e-instance.sh
|
|
openclaw_e2e_eval_test_state_from_b64 "${OPENCLAW_TEST_STATE_SCRIPT_B64:?missing OPENCLAW_TEST_STATE_SCRIPT_B64}"
|
|
export OPENCLAW_SKIP_CHANNELS=1
|
|
export OPENCLAW_SKIP_GMAIL_WATCHER=1
|
|
export OPENCLAW_SKIP_CRON=1
|
|
export OPENCLAW_SKIP_CANVAS_HOST=1
|
|
export OPENCLAW_SKIP_BROWSER_CONTROL_SERVER=1
|
|
export OPENCLAW_SKIP_ACPX_RUNTIME=1
|
|
export OPENCLAW_SKIP_ACPX_RUNTIME_PROBE=1
|
|
|
|
PORT="${PORT:?missing PORT}"
|
|
MOCK_PORT="${MOCK_PORT:?missing MOCK_PORT}"
|
|
TOKEN="${OPENCLAW_GATEWAY_TOKEN:?missing OPENCLAW_GATEWAY_TOKEN}"
|
|
SUCCESS_MARKER="OPENCLAW_SCHEMA_E2E_OK"
|
|
RAW_SCHEMA_ERROR="400 The following tools cannot be used with reasoning.effort 'minimal': web_search."
|
|
MOCK_REQUEST_LOG="/tmp/openclaw-openai-web-search-minimal-requests.jsonl"
|
|
GATEWAY_LOG="/tmp/openclaw-openai-web-search-minimal-gateway.log"
|
|
mock_pid=""
|
|
gateway_pid=""
|
|
|
|
cleanup() {
|
|
if [ -n "${gateway_pid:-}" ] && kill -0 "$gateway_pid" 2>/dev/null; then
|
|
kill "$gateway_pid" 2>/dev/null || true
|
|
wait "$gateway_pid" 2>/dev/null || true
|
|
fi
|
|
if [ -n "${mock_pid:-}" ] && kill -0 "$mock_pid" 2>/dev/null; then
|
|
kill "$mock_pid" 2>/dev/null || true
|
|
wait "$mock_pid" 2>/dev/null || true
|
|
fi
|
|
}
|
|
trap cleanup EXIT
|
|
|
|
dump_debug_logs() {
|
|
local status="$1"
|
|
echo "OpenAI web_search minimal Docker E2E failed with exit code $status" >&2
|
|
for file in \
|
|
"$GATEWAY_LOG" \
|
|
/tmp/openclaw-openai-web-search-minimal-mock.log \
|
|
/tmp/openclaw-openai-web-search-minimal-client-success.log \
|
|
/tmp/openclaw-openai-web-search-minimal-client-reject.log \
|
|
"$MOCK_REQUEST_LOG" \
|
|
"$OPENCLAW_STATE_DIR/openclaw.json"; do
|
|
if [ -f "$file" ]; then
|
|
echo "--- $file ---" >&2
|
|
sed -n '1,260p' "$file" >&2 || true
|
|
fi
|
|
done
|
|
}
|
|
trap 'status=$?; dump_debug_logs "$status"; exit "$status"' ERR
|
|
|
|
entry="$(openclaw_e2e_resolve_entrypoint)"
|
|
mkdir -p "$OPENCLAW_STATE_DIR"
|
|
|
|
node scripts/e2e/lib/openai-web-search-minimal/assertions.mjs assert-patch-behavior
|
|
|
|
node scripts/e2e/lib/fixture.mjs openai-web-search-minimal-config
|
|
|
|
MOCK_PORT="$MOCK_PORT" \
|
|
MOCK_REQUEST_LOG="$MOCK_REQUEST_LOG" \
|
|
SUCCESS_MARKER="$SUCCESS_MARKER" \
|
|
RAW_SCHEMA_ERROR="$RAW_SCHEMA_ERROR" \
|
|
node scripts/e2e/lib/openai-web-search-minimal/mock-server.mjs >/tmp/openclaw-openai-web-search-minimal-mock.log 2>&1 &
|
|
mock_pid="$!"
|
|
|
|
for _ in $(seq 1 80); do
|
|
if node -e "fetch('http://127.0.0.1:${MOCK_PORT}/health').then(r=>process.exit(r.ok?0:1)).catch(()=>process.exit(1))" >/dev/null 2>&1; then
|
|
break
|
|
fi
|
|
sleep 0.1
|
|
done
|
|
node -e "fetch('http://127.0.0.1:${MOCK_PORT}/health').then(r=>process.exit(r.ok?0:1)).catch(()=>process.exit(1))" >/dev/null
|
|
|
|
node "$entry" gateway --port "$PORT" --bind loopback --allow-unconfigured >"$GATEWAY_LOG" 2>&1 &
|
|
gateway_pid="$!"
|
|
for _ in $(seq 1 360); do
|
|
if ! kill -0 "$gateway_pid" 2>/dev/null; then
|
|
echo "gateway exited before listening" >&2
|
|
exit 1
|
|
fi
|
|
if node "$entry" gateway health \
|
|
--url "ws://127.0.0.1:$PORT" \
|
|
--token "$TOKEN" \
|
|
--timeout 120000 \
|
|
--json >/dev/null 2>&1; then
|
|
break
|
|
fi
|
|
sleep 0.25
|
|
done
|
|
node "$entry" gateway health \
|
|
--url "ws://127.0.0.1:$PORT" \
|
|
--token "$TOKEN" \
|
|
--timeout 120000 \
|
|
--json >/dev/null
|
|
|
|
PORT="$PORT" OPENCLAW_GATEWAY_TOKEN="$TOKEN" node scripts/e2e/lib/openai-web-search-minimal/client.mjs success >/tmp/openclaw-openai-web-search-minimal-client-success.log 2>&1
|
|
|
|
node scripts/e2e/lib/openai-web-search-minimal/assertions.mjs assert-success-request "$MOCK_REQUEST_LOG"
|
|
|
|
PORT="$PORT" OPENCLAW_GATEWAY_TOKEN="$TOKEN" node scripts/e2e/lib/openai-web-search-minimal/client.mjs reject >/tmp/openclaw-openai-web-search-minimal-client-reject.log 2>&1
|
|
|
|
for _ in $(seq 1 80); do
|
|
if grep -Fq "$RAW_SCHEMA_ERROR" "$GATEWAY_LOG"; then
|
|
break
|
|
fi
|
|
sleep 0.25
|
|
done
|
|
grep -F "$RAW_SCHEMA_ERROR" "$GATEWAY_LOG" >/dev/null
|
|
|
|
echo "OpenAI web_search minimal reasoning Docker E2E passed"
|