#!/usr/bin/env bash
set -euo pipefail


USER_IP_POOL_LIST=(
  "33.32.20.27"
  "33.18.233.105"
  "33.32.32.65"
  "33.18.235.12"
)

USER_MODEL_NAME="${USER_MODEL_NAME:-}"
USER_BASE_URL="${USER_BASE_URL:-}"

# 选择 user 是否走计费端口
USER_MODEL_NAME="DeepSeek-V3.2-Meituan"
USER_BASE_URL="https://basicaiservice.sankuai.com/basicai/v1"

# 自己训的模型 ===================================================================
# OPEN_SOURCE=1
# AGENT_THINKING=0

# AGENT_MODEL_NAME="qwen2514_toucan_119k" AGENT_IP="10.166.104.49"
# AGENT_MODEL_NAME="qwen2532_toucan_119k" AGENT_IP="10.164.25.68"

# AGENT_MODEL_NAME="qwen2514_toucan_119k_travel_3k" AGENT_IP="10.166.104.49"
# AGENT_MODEL_NAME="qwen2532_toucan_119k_travel_3k" AGENT_IP="10.164.25.68"

# AGENT_MODEL_NAME="qwen2514_toucan_119k_travel_3k_mt_ctr_rd_mi_220" AGENT_IP="33.32.51.124"
# AGENT_MODEL_NAME="qwen2532_toucan_119k_travel_3k_mt_ctr_rd_mi_220" AGENT_IP="33.18.241.116"


# AGENT_MODEL_NAME="qwen2514_toucan_119k_travel_3k_mt_ctr_rd_220" AGENT_IP="33.32.6.15"

# AGENT_MODEL_NAME="qwen2514_toucan_119k_travel_3k_mt_ctr_220" AGENT_IP="33.18.247.72"

# AGENT_MODEL_NAME="qwen2514_toucan_119k_travel_3k_mt_220" AGENT_IP="33.32.40.109"

# AGENT_MODEL_NAME="qwen2514_toucan_119k_travel_3k_st_140" AGENT_IP="33.18.236.96"


# 开源 think ===================================================================
# OPEN_SOURCE=1
# AGENT_THINKING=1

# AGENT_MODEL_NAME="deepseek-v32" AGENT_IP="33.18.232.8" USER_IP_POOL_LIST=("33.18.232.8")
# AGENT_MODEL_NAME="qwen3-235b-think"  AGENT_IP="33.32.40.143"  # 记得调整 max_token 为 32k


# 开源 nothink ===================================================================
# OPEN_SOURCE=1
# AGENT_THINKING=0

# AGENT_MODEL_NAME="qwen2514"  AGENT_IP="10.166.152.109"
# AGENT_MODEL_NAME="qwen2532"  AGENT_IP="10.164.53.74"

# AGENT_MODEL_NAME="deepseek-v32"  AGENT_IP="33.32.41.91"
# AGENT_MODEL_NAME="qwen3-235b-instruct" AGENT_IP="33.18.241.27"  # 记得调整 max_token 为 32k
# AGENT_MODEL_NAME="qwen2.5-32b-instruct" AGENT_IP="33.253.132.106" # 记得调整 max_token 为 32k
# AGENT_MODEL_NAME="qwen3-32b" AGENT_IP="33.32.40.143"  # 记得调整 max_token 为 32k


# 闭源 think ===================================================================
OPEN_SOURCE=0
AGENT_THINKING=1
AGENT_IP="0.1.2.3"


# AGENT_MODEL_NAME="qwen3-235b-a22b-thinking-2507-meituan"
# AGENT_MODEL_NAME="LongCat-Flash-Thinking-2601"
# AGENT_MODEL_NAME="glm-4.7"
# AGENT_MODEL_NAME="gpt-5.2"
# AGENT_MODEL_NAME="openai/gpt-5.2"
AGENT_MODEL_NAME="gemini-3-flash-preview"  # 记得调整 max_token 为 32k
# AGENT_MODEL_NAME="gemini-3-pro-preview"  # 记得调整 max_token 为 32k
# AGENT_MODEL_NAME="aws.claude-sonnet-4.5"
# AGENT_MODEL_NAME="kimi-k2-thinking"


# 闭源 nothink ===================================================================
# OPEN_SOURCE=0
# AGENT_THINKING=0
# AGENT_IP="0.1.2.3"

# AGENT_MODEL_NAME="glm-4.7"
# AGENT_MODEL_NAME="kimi-k2-0905-preview"


# ====================================================================

# 并发设置
OPEN_SOURCE_REQUESTS_PER_IP=3  # 开源的并发
CLOSED_SOURCE_REQUESTS_PER_IP=3  # 闭源的并发


if [ "$OPEN_SOURCE" -eq 0 ] && [ "$AGENT_MODEL_NAME" != "LongCat-Flash-Thinking-2601" ]; then
    TESTS="$MINI_TESTS"
else
    TESTS="$FULL_TESTS"
fi


if [ "$OPEN_SOURCE" -eq 1 ]; then
    AGENT_BASE_URL="http://$AGENT_IP:8000/v1"
else
    case "$AGENT_MODEL_NAME" in
        openai/gpt-5.2)
            AGENT_BASE_URL="https://openrouter.ai/api/v1"
            ;;
        *)
            AGENT_BASE_URL="https://basicaiservice.sankuai.com/basicai/v1"
            ;;
    esac
fi



if [ "$OPEN_SOURCE" -eq 1 ]; then
    REQUESTS_PER_IP="$OPEN_SOURCE_REQUESTS_PER_IP"
else
    REQUESTS_PER_IP="$CLOSED_SOURCE_REQUESTS_PER_IP"
fi

if [ "$AGENT_THINKING" -eq 1 ]; then
    TASK_ID="${AGENT_MODEL_NAME}-think"
else
    TASK_ID="${AGENT_MODEL_NAME}-nothink"
fi

AGENT_MAX_TOKENS=""
case "$AGENT_MODEL_NAME" in
    qwen2514_toucan_119k|qwen2532_toucan_119k|qwen2514_toucan_119k_travel_3k|qwen2532_toucan_119k_travel_3k)
        AGENT_MAX_TOKENS=$((32 * 1024))
        ;;
    qwen*|gemini*)
        AGENT_MAX_TOKENS=$((32 * 1024))
        ;;
esac

SCRIPT_DIR="$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" && pwd -P)"
WORKSPACE_DIR="$(cd -- "$SCRIPT_DIR/../.." && pwd -P)"

LOG_DIR="$WORKSPACE_DIR/ttv2_eval/log"
LOG_TASK_ID="${TASK_ID//\//_}"
LOG_FILE="$LOG_DIR/${LOG_TASK_ID}.log"

USER_IP_POOL="$(IFS=,; echo "${USER_IP_POOL_LIST[*]}")"

# 创建日志目录
mkdir -p "$LOG_DIR"

# 使用 --task_id 参数将 TASK_ID 传递给 Python 脚本
USER_IP_POOL="$USER_IP_POOL" \
USER_MODEL_NAME="$USER_MODEL_NAME" \
USER_BASE_URL="$USER_BASE_URL" \
AGENT_MODEL_NAME="$AGENT_MODEL_NAME" \
AGENT_IP="$AGENT_IP" \
AGENT_BASE_URL="$AGENT_BASE_URL" \
OPEN_SOURCE="$OPEN_SOURCE" \
REQUESTS_PER_IP="$REQUESTS_PER_IP" \
AGENT_THINKING="$AGENT_THINKING" \
AGENT_MAX_TOKENS="$AGENT_MAX_TOKENS" \
TESTS="$TESTS" \
nohup python3 -u "$SCRIPT_DIR/eval_api.py" --task_id "$TASK_ID" >"$LOG_FILE" 2>&1 &

# 保存进程ID到文件
# echo "$!" >"$LOG_FILE.pid"

# 输出PID和日志文件位置
echo "pid=$! log=$LOG_FILE"



# 查找当前的进程：
# ps aux | grep "task_id "
