#!/usr/bin/env bash set -euo pipefail trap "" PIPE export TERM=xterm-256color export NO_COLOR=1 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}" openclaw_e2e_install_trash_shim export NPM_CONFIG_PREFIX="$HOME/.npm-global" export PATH="$NPM_CONFIG_PREFIX/bin:$PATH" export npm_config_loglevel=error export npm_config_fund=false export npm_config_audit=false export OPENAI_API_KEY="sk-openclaw-release-media-memory" export OPENCLAW_QA_ALLOW_LOCAL_IMAGE_PROVIDER=1 PORT="18789" MOCK_PORT="44200" SUCCESS_MARKER="OPENCLAW_E2E_OK_MEDIA_MEMORY" MEMORY_MARKER="release-media-memory-saffron-$(date +%s)" MOCK_REQUEST_LOG="/tmp/openclaw-release-media-memory-openai.jsonl" export SUCCESS_MARKER MOCK_REQUEST_LOG mock_pid="" gateway_pid="" cleanup() { openclaw_e2e_terminate_gateways "${gateway_pid:-}" openclaw_e2e_stop_process "${mock_pid:-}" } trap cleanup EXIT dump_debug_logs() { local status="$1" echo "release media memory failed with exit code $status" >&2 openclaw_e2e_dump_logs \ /tmp/openclaw-release-media-memory-install.log \ /tmp/openclaw-release-media-memory-onboard.log \ /tmp/openclaw-release-media-memory-openai.log \ "$MOCK_REQUEST_LOG" \ /tmp/openclaw-release-media-memory-describe.json \ /tmp/openclaw-release-media-memory-generate.json \ /tmp/openclaw-release-media-memory-index.log \ /tmp/openclaw-release-media-memory-search-before.json \ /tmp/openclaw-release-media-memory-search-after.json \ /tmp/openclaw-release-media-memory-gateway-1.log \ /tmp/openclaw-release-media-memory-gateway-2.log } trap 'status=$?; dump_debug_logs "$status"; exit "$status"' ERR start_gateway() { local log_path="$1" gateway_pid="$(openclaw_e2e_start_gateway "$entry" "$PORT" "$log_path")" openclaw_e2e_wait_gateway_ready "$gateway_pid" "$log_path" } stop_gateway() { openclaw_e2e_terminate_gateways "${gateway_pid:-}" gateway_pid="" } openclaw_e2e_install_package /tmp/openclaw-release-media-memory-install.log command -v openclaw >/dev/null package_root="$(openclaw_e2e_package_root)" entry="$(openclaw_e2e_package_entrypoint "$package_root")" mock_pid="$(openclaw_e2e_start_mock_openai "$MOCK_PORT" /tmp/openclaw-release-media-memory-openai.log)" openclaw_e2e_wait_mock_openai "$MOCK_PORT" openclaw onboard \ --non-interactive \ --accept-risk \ --flow quickstart \ --mode local \ --auth-choice skip \ --gateway-port "$PORT" \ --gateway-bind loopback \ --skip-daemon \ --skip-ui \ --skip-channels \ --skip-skills \ --skip-health >/tmp/openclaw-release-media-memory-onboard.log 2>&1 node scripts/e2e/lib/release-scenarios/assertions.mjs configure-mock-openai "$MOCK_PORT" mkdir -p "$OPENCLAW_STATE_DIR/workspace/memory" /tmp/openclaw-release-media-memory printf '%s' 'iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mP8/x8AAwMCAO+yf7kAAAAASUVORK5CYII=' | base64 -d > /tmp/openclaw-release-media-memory/input.png openclaw infer image describe \ --file /tmp/openclaw-release-media-memory/input.png \ --model openai/gpt-5.5 \ --prompt "Describe this image and return marker $SUCCESS_MARKER" \ --json >/tmp/openclaw-release-media-memory-describe.json 2>&1 node scripts/e2e/lib/release-scenarios/assertions.mjs assert-image-describe /tmp/openclaw-release-media-memory-describe.json "$MOCK_REQUEST_LOG" openclaw infer image generate \ --model openai/gpt-image-1 \ --prompt "Generate a tiny test image for $SUCCESS_MARKER" \ --output /tmp/openclaw-release-media-memory/generated.png \ --json >/tmp/openclaw-release-media-memory-generate.json 2>&1 node scripts/e2e/lib/release-scenarios/assertions.mjs assert-image-generate /tmp/openclaw-release-media-memory-generate.json "$MOCK_REQUEST_LOG" cat >"$OPENCLAW_STATE_DIR/workspace/MEMORY.md" </tmp/openclaw-release-media-memory-index.log 2>&1 || true openclaw memory search "$MEMORY_MARKER" --json >/tmp/openclaw-release-media-memory-search-before.json 2>&1 node scripts/e2e/lib/release-scenarios/assertions.mjs assert-memory-search /tmp/openclaw-release-media-memory-search-before.json "$MEMORY_MARKER" start_gateway /tmp/openclaw-release-media-memory-gateway-1.log stop_gateway start_gateway /tmp/openclaw-release-media-memory-gateway-2.log openclaw memory search "$MEMORY_MARKER" --json >/tmp/openclaw-release-media-memory-search-after.json 2>&1 node scripts/e2e/lib/release-scenarios/assertions.mjs assert-memory-search /tmp/openclaw-release-media-memory-search-after.json "$MEMORY_MARKER" stop_gateway echo "Release media memory scenario passed."