Blame view

scripts/sh/test_lq_salary_service.sh 3.46 KB
83a6fd1f   “wangming”   feat: 添加员工确认状态及相关...
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
  #!/bin/bash
  
  # 测试健康师工资服务接口
  # 使用方法:./scripts/sh/test_lq_salary_service.sh
  
  BASE_URL="http://localhost:2011"
  TOKEN=""
  
  echo "=========================================="
  echo "开始测试健康师工资服务接口"
  echo "=========================================="
  echo ""
  
  # 1. 获取Token
  echo "1. 获取Token..."
  LOGIN_RESPONSE=$(curl -s -X POST "${BASE_URL}/api/oauth/Login" \
    -H "Content-Type: application/x-www-form-urlencoded" \
    -d "account=admin&password=e10adc3949ba59abbe56e057f20f883e")
  
  TOKEN=$(echo $LOGIN_RESPONSE | python3 -c "import sys, json; print(json.load(sys.stdin)['data']['token'])" 2>/dev/null)
  
  if [ -z "$TOKEN" ]; then
    echo "❌ 获取Token失败"
    echo "响应: $LOGIN_RESPONSE"
    exit 1
  fi
  
  echo "✅ Token获取成功"
  echo ""
  
  # 2. 测试计算健康师工资接口
  echo "2. 测试计算健康师工资接口(calculate/health-coach)..."
  echo "请求参数: year=2025, month=9"
  echo ""
  
  CALCULATE_RESPONSE=$(curl -s -X POST "${BASE_URL}/api/Extend/LqSalary/calculate/health-coach?year=2025&month=9" \
    -H "Authorization: ${TOKEN}")
  
  echo "响应:"
  echo "$CALCULATE_RESPONSE" | python3 -m json.tool 2>/dev/null || echo "$CALCULATE_RESPONSE"
  echo ""
  
  # 检查返回结果
  if echo "$CALCULATE_RESPONSE" | python3 -c "import sys, json; data=json.load(sys.stdin); exit(0 if data.get('code') == 200 or '操作成功' in str(data) or data == '' else 1)" 2>/dev/null; then
    echo "✅ 计算健康师工资接口测试通过"
  else
    echo "⚠️  计算健康师工资接口可能存在问题"
    echo "响应内容: $CALCULATE_RESPONSE"
  fi
  echo ""
  
  # 3. 测试导入接口
  echo "3. 测试导入工资接口(import)..."
  echo "使用文件: ExportFiles/工资导入/健康师工资_带ID.xlsx"
  echo ""
  
  if [ ! -f "ExportFiles/工资导入/健康师工资_带ID.xlsx" ]; then
    echo "❌ Excel文件不存在: ExportFiles/工资导入/健康师工资_带ID.xlsx"
    echo "跳过导入测试"
  else
    IMPORT_RESPONSE=$(curl -s -X POST "${BASE_URL}/api/Extend/LqSalary/import" \
      -H "Authorization: ${TOKEN}" \
      -F "file=@ExportFiles/工资导入/健康师工资_带ID.xlsx")
    
    echo "响应:"
    echo "$IMPORT_RESPONSE" | python3 -m json.tool 2>/dev/null || echo "$IMPORT_RESPONSE"
    echo ""
    
    # 检查返回结果
    if echo "$IMPORT_RESPONSE" | python3 -c "import sys, json; data=json.load(sys.stdin); exit(0 if (data.get('code') == 200 or data.get('success') == True) else 1)" 2>/dev/null; then
      echo "✅ 导入工资接口测试通过"
    else
      echo "⚠️  导入工资接口可能存在问题"
      echo "响应内容: $IMPORT_RESPONSE"
    fi
  fi
  echo ""
  
  # 4. 测试确认接口(需要先获取一条已锁定的记录)
  echo "4. 测试员工确认工资条接口(confirm)..."
  echo "提示:需要先锁定一条工资记录才能测试确认接口"
  echo ""
  
  # 先查询一条记录用于测试
  SALARY_RECORD=$(curl -s -X GET "${BASE_URL}/api/Extend/LqSalary/health-coach?currentPage=1&pageSize=1&year=2025&month=9" \
    -H "Authorization: ${TOKEN}")
  
  echo "查询到的工资记录:"
  echo "$SALARY_RECORD" | python3 -m json.tool 2>/dev/null | head -30 || echo "$SALARY_RECORD"
  echo ""
  
  echo "=========================================="
  echo "测试完成"
  echo "=========================================="
  echo ""
  echo "注意:"
  echo "1. 确认接口测试需要先锁定一条工资记录(IsLocked=1)"
  echo "2. 可以使用SQL更新一条记录的F_IsLocked=1进行测试"
  echo "3. 然后使用该记录的ID和EmployeeId调用确认接口"