Blame view

scripts/sh/test_personal_performance_api.sh 4.51 KB
1fffa876   “wangming”   优化储扣列表接口:增加门店、时间、...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
  #!/bin/bash
  
  # 测试个人业绩统计接口性能和返回数据
  
  echo "=== 测试个人业绩统计接口 ==="
  echo ""
  
  # 1. 获取token
  echo "=== 1. 获取Token ==="
  TOKEN_RESPONSE=$(curl -s -X POST "http://localhost:2011/api/oauth/Login" \
    -H "Content-Type: application/x-www-form-urlencoded" \
    -d "account=admin&password=e10adc3949ba59abbe56e057f20f883e")
  
  TOKEN=$(echo "$TOKEN_RESPONSE" | python3 -c "import sys, json; data=json.load(sys.stdin); print(data['data']['token'])" 2>/dev/null)
  
  if [ -z "$TOKEN" ]; then
    echo "❌ Token获取失败"
    echo "$TOKEN_RESPONSE"
    exit 1
  fi
  
  echo "✅ Token获取成功"
  echo ""
  
  # 2. 测试接口 - 无筛选条件,第一页
  echo "=== 2. 测试接口 - 无筛选条件,第一页(20条)==="
  START_TIME=$(date +%s%N)
  RESPONSE=$(curl -s -w "\n%{http_code}\n%{time_total}" -X POST "http://localhost:2011/api/Extend/LqStatistics/get-personal-performance-statistics-list" \
    -H "Authorization: $TOKEN" \
    -H "Content-Type: application/json" \
    -d '{
      "statisticsMonth": "202512",
      "currentPage": 1,
      "pageSize": 20
    }')
  END_TIME=$(date +%s%N)
  
  HTTP_CODE=$(echo "$RESPONSE" | tail -2 | head -1)
  TIME_TOTAL=$(echo "$RESPONSE" | tail -1)
  RESPONSE_BODY=$(echo "$RESPONSE" | sed '$d' | sed '$d')
  
  echo "HTTP状态码: $HTTP_CODE"
  echo "响应时间: ${TIME_TOTAL}秒"
  ELAPSED_MS=$((($END_TIME - $START_TIME) / 1000000))
  echo "总耗时: ${ELAPSED_MS}毫秒"
  echo ""
  
  # 检查返回结果
  if [ "$HTTP_CODE" = "200" ]; then
    CODE=$(echo "$RESPONSE_BODY" | python3 -c "import sys, json; data=json.load(sys.stdin); print(data.get('code', ''))" 2>/dev/null)
    if [ "$CODE" = "200" ]; then
      echo "✅ 接口调用成功"
      LIST_COUNT=$(echo "$RESPONSE_BODY" | python3 -c "import sys, json; data=json.load(sys.stdin); print(len(data.get('data', {}).get('list', [])))" 2>/dev/null)
      TOTAL=$(echo "$RESPONSE_BODY" | python3 -c "import sys, json; data=json.load(sys.stdin); print(data.get('data', {}).get('pagination', {}).get('total', 0))" 2>/dev/null)
      echo "返回数据条数: $LIST_COUNT"
      echo "总记录数: $TOTAL"
      
      # 显示第一条数据示例
      echo ""
      echo "第一条数据示例:"
      echo "$RESPONSE_BODY" | python3 -c "import sys, json; data=json.load(sys.stdin); item=data.get('data', {}).get('list', [{}])[0] if data.get('data', {}).get('list') else {}; print(json.dumps(item, indent=2, ensure_ascii=False))" 2>/dev/null
    else
      echo "❌ 接口返回错误"
      echo "$RESPONSE_BODY" | python3 -m json.tool 2>/dev/null || echo "$RESPONSE_BODY"
    fi
  else
    echo "❌ HTTP请求失败"
    echo "$RESPONSE_BODY"
  fi
  
  echo ""
  echo ""
  
  # 3. 测试接口 - 带门店筛选
  echo "=== 3. 测试接口 - 带门店筛选 ==="
  START_TIME=$(date +%s%N)
  RESPONSE2=$(curl -s -w "\n%{http_code}\n%{time_total}" -X POST "http://localhost:2011/api/Extend/LqStatistics/get-personal-performance-statistics-list" \
    -H "Authorization: $TOKEN" \
    -H "Content-Type: application/json" \
    -d '{
      "statisticsMonth": "202512",
      "storeName": "测试",
      "currentPage": 1,
      "pageSize": 20
    }')
  END_TIME=$(date +%s%N)
  
  HTTP_CODE2=$(echo "$RESPONSE2" | tail -2 | head -1)
  TIME_TOTAL2=$(echo "$RESPONSE2" | tail -1)
  RESPONSE_BODY2=$(echo "$RESPONSE2" | sed '$d' | sed '$d')
  
  echo "HTTP状态码: $HTTP_CODE2"
  echo "响应时间: ${TIME_TOTAL2}秒"
  ELAPSED_MS2=$((($END_TIME - $START_TIME) / 1000000))
  echo "总耗时: ${ELAPSED_MS2}毫秒"
  
  if [ "$HTTP_CODE2" = "200" ]; then
    CODE2=$(echo "$RESPONSE_BODY2" | python3 -c "import sys, json; data=json.load(sys.stdin); print(data.get('code', ''))" 2>/dev/null)
    if [ "$CODE2" = "200" ]; then
      echo "✅ 接口调用成功"
      LIST_COUNT2=$(echo "$RESPONSE_BODY2" | python3 -c "import sys, json; data=json.load(sys.stdin); print(len(data.get('data', {}).get('list', [])))" 2>/dev/null)
      TOTAL2=$(echo "$RESPONSE_BODY2" | python3 -c "import sys, json; data=json.load(sys.stdin); print(data.get('data', {}).get('pagination', {}).get('total', 0))" 2>/dev/null)
      echo "返回数据条数: $LIST_COUNT2"
      echo "总记录数: $TOTAL2"
    else
      echo "❌ 接口返回错误"
      echo "$RESPONSE_BODY2" | python3 -m json.tool 2>/dev/null || echo "$RESPONSE_BODY2"
    fi
  fi
  
  echo ""
  echo ""
  
  # 4. 性能评估
  echo "=== 4. 性能评估 ==="
  if [ -n "$ELAPSED_MS" ]; then
    if [ "$ELAPSED_MS" -lt 1000 ]; then
      echo "✅ 性能优秀 (< 1秒)"
    elif [ "$ELAPSED_MS" -lt 3000 ]; then
      echo "⚠️  性能良好 (1-3秒)"
    elif [ "$ELAPSED_MS" -lt 5000 ]; then
      echo "⚠️  性能一般 (3-5秒)"
    else
      echo "❌ 性能较差 (> 5秒),需要优化"
    fi
  fi