#!/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调用确认接口"