#!/bin/bash ################################################################################ # 信贷客户实体关联信息后端功能测试脚本 # 测试所有接口,生成Markdown格式测试报告 # 遇到失败立即停止 ################################################################################ # 配置 BASE_URL="http://localhost:8080" REPORT_FILE="doc/信贷客户实体关联维护功能/测试报告.md" TEST_DATA_DIR="doc/信贷客户实体关联维护功能/test_data" TOKEN="" # 测试数据(动态生成唯一数据) TIMESTAMP=$(date +%s) # 身份证号格式:18位,正则 ^[1-9]\d{5}(18|19|20)\d{2}(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])\d{3}[0-9Xx]$ # 110101(地区码) + 19900101(合法日期) + 随机3位顺序码 + X(校验码) RANDOM_SUFFIX=$((TIMESTAMP % 1000)) TEST_PERSON_ID="11010119900101123X" if [ $((RANDOM_SUFFIX % 2)) -eq 0 ]; then TEST_PERSON_ID="110101199001011234" fi # 统一社会信用代码格式:18位,正则 ^[0-9A-HJ-NPQRTUWXY]{2}\d{6}[0-9A-HJ-NPQRTUWXY]{10}$ # 使用固定的合法格式 TEST_SOCIAL_CREDIT_CODE="9111000010000644$((TIMESTAMP % 10))C" TEST_ENTERPRISE_NAME="测试企业有限公司_${TIMESTAMP}" TEST_RELATION_POST="股东" TEST_REMARK="自动化测试数据_${TIMESTAMP}" TEST_ID="" # 颜色输出 RED='\033[0;31m' GREEN='\033[0;32m' YELLOW='\033[1;33m' NC='\033[0m' # No Color # 计数器 TOTAL_TESTS=0 PASSED_TESTS=0 FAILED_TESTS=0 # 测试结果存储 declare -a TEST_RESULTS # 初始化报告文件 init_report() { mkdir -p "doc/信贷客户实体关联维护功能" cat > "$REPORT_FILE" << 'EOF' # 信贷客户实体关联信息后端功能测试报告 ## 测试概述 | 项目 | 内容 | |------|------| | 测试模块 | 信贷客户实体关联信息管理 | | 测试环境 | 后端API接口测试 | | 测试时间 | EOF echo "$(date '+%Y-%m-%d %H:%M:%S')" >> "$REPORT_FILE" cat >> "$REPORT_FILE" << 'EOF' | 测试人员 | 自动化测试脚本 | ## 测试接口列表 | 序号 | 接口名称 | 请求方法 | 接口路径 | |------|----------|----------|----------| | 1 | 获取Token | POST | /login/test | | 2 | 分页查询列表 | GET | /ccdi/custEnterpriseRelation/list | | 3 | 新增记录 | POST | /ccdi/custEnterpriseRelation | | 4 | 查询详情 | GET | /ccdi/custEnterpriseRelation/{id} | | 5 | 修改记录 | PUT | /ccdi/custEnterpriseRelation | | 6 | 删除记录 | DELETE | /ccdi/custEnterpriseRelation/{ids} | | 7 | 导出Excel | POST | /ccdi/custEnterpriseRelation/export | | 8 | 下载导入模板 | GET | /ccdi/custEnterpriseRelation/importTemplate | | 9 | 导入数据 | POST | /ccdi/custEnterpriseRelation/importData | | 10 | 查询导入状态 | GET | /ccdi/custEnterpriseRelation/importStatus/{taskId} | | 11 | 查询导入失败记录 | GET | /ccdi/custEnterpriseRelation/importFailures/{taskId} | ## 测试结果汇总 EOF } # 记录测试结果 log_test() { local test_name="$1" local status="$2" local response="$3" local duration="$4" TOTAL_TESTS=$((TOTAL_TESTS + 1)) if [ "$status" == "PASS" ]; then PASSED_TESTS=$((PASSED_TESTS + 1)) echo -e "${GREEN}[PASS]${NC} $test_name (${duration}ms)" else FAILED_TESTS=$((FAILED_TESTS + 1)) echo -e "${RED}[FAIL]${NC} $test_name (${duration}ms)" fi # 存储测试结果 TEST_RESULTS+=("$test_name|$status|$duration|${response:0:200}") } # 完成报告 finalize_report() { local success_rate=0 if [ $TOTAL_TESTS -gt 0 ]; then success_rate=$((PASSED_TESTS * 100 / TOTAL_TESTS)) fi cat >> "$REPORT_FILE" << EOF | 统计项 | 数值 | |--------|------| | 总测试数 | $TOTAL_TESTS | | 通过数 | $PASSED_TESTS | | 失败数 | $FAILED_TESTS | | 通过率 | ${success_rate}% | ## 详细测试结果 | 序号 | 测试接口 | 状态 | 耗时(ms) | 响应摘要 | |------|----------|------|----------|----------| EOF local idx=1 for result in "${TEST_RESULTS[@]}"; do IFS='|' read -r name status duration response <<< "$result" local status_icon=":white_check_mark:" if [ "$status" != "PASS" ]; then status_icon=":x:" fi echo "| $idx | $name | $status_icon $status | $duration | ${response:0:50}... |" >> "$REPORT_FILE" idx=$((idx + 1)) done cat >> "$REPORT_FILE" << EOF ## 测试结论 EOF if [ $FAILED_TESTS -eq 0 ]; then echo "**所有测试通过!** 后端接口功能正常。" >> "$REPORT_FILE" else echo "**存在测试失败!** 请检查失败的接口和错误信息。" >> "$REPORT_FILE" fi echo -e "\n${YELLOW}测试报告已生成: $REPORT_FILE${NC}" } # 失败退出 fail_exit() { local test_name="$1" local message="$2" echo -e "${RED}测试失败: $test_name${NC}" echo -e "${RED}错误信息: $message${NC}" finalize_report exit 1 } # 检查命令是否存在 check_command() { if ! command -v "$1" &> /dev/null; then echo -e "${RED}错误: 未找到命令 '$1',请先安装${NC}" exit 1 fi } # 测试1: 获取Token test_login() { echo -e "\n${YELLOW}=== 测试1: 获取Token ===${NC}" local start_time=$(date +%s%3N) local response=$(curl -s -X POST \ "${BASE_URL}/login/test" \ -H "Content-Type: application/json" \ -d '{"username":"admin","password":"admin123"}') local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if echo "$response" | grep -q '"token"'; then TOKEN=$(echo "$response" | grep -o '"token":"[^"]*"' | sed 's/"token":"//;s/"//') log_test "获取Token" "PASS" "$response" "$duration" echo "Token获取成功: ${TOKEN:0:20}..." else log_test "获取Token" "FAIL" "$response" "$duration" fail_exit "获取Token" "无法获取Token,响应: $response" fi } # 测试2: 分页查询列表 test_list() { echo -e "\n${YELLOW}=== 测试2: 分页查询列表 ===${NC}" local start_time=$(date +%s%3N) local response=$(curl -s -X GET \ "${BASE_URL}/ccdi/custEnterpriseRelation/list?pageNum=1&pageSize=10" \ -H "Authorization: Bearer $TOKEN") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if echo "$response" | grep -q '"total"'; then local total=$(echo "$response" | grep -o '"total":[0-9]*' | sed 's/"total"://') log_test "分页查询列表" "PASS" "$response" "$duration" echo "查询成功,总数: $total" else log_test "分页查询列表" "FAIL" "$response" "$duration" fail_exit "分页查询列表" "查询失败,响应: $response" fi } # 测试3: 新增记录 test_add() { echo -e "\n${YELLOW}=== 测试3: 新增记录 ===${NC}" local start_time=$(date +%s%3N) local response=$(curl -s -X POST \ "${BASE_URL}/ccdi/custEnterpriseRelation" \ -H "Authorization: Bearer $TOKEN" \ -H "Content-Type: application/json" \ -d "{ \"personId\": \"${TEST_PERSON_ID}\", \"socialCreditCode\": \"${TEST_SOCIAL_CREDIT_CODE}\", \"enterpriseName\": \"${TEST_ENTERPRISE_NAME}\", \"relationPersonPost\": \"${TEST_RELATION_POST}\", \"status\": 1, \"remark\": \"${TEST_REMARK}\" }") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if echo "$response" | grep -q '"code":200'; then log_test "新增记录" "PASS" "$response" "$duration" echo "新增成功" else log_test "新增记录" "FAIL" "$response" "$duration" fail_exit "新增记录" "新增失败,响应: $response" fi } # 测试4: 查询详情(先查询列表获取ID) test_get_by_id() { echo -e "\n${YELLOW}=== 测试4: 查询详情 ===${NC}" # 先查询列表获取刚新增的记录ID local list_response=$(curl -s -X GET \ "${BASE_URL}/ccdi/custEnterpriseRelation/list?pageNum=1&pageSize=1&personId=${TEST_PERSON_ID}" \ -H "Authorization: Bearer $TOKEN") TEST_ID=$(echo "$list_response" | grep -o '"id":[0-9]*' | head -1 | sed 's/"id"://') if [ -z "$TEST_ID" ]; then fail_exit "查询详情" "无法获取测试记录ID" fi local start_time=$(date +%s%3N) local response=$(curl -s -X GET \ "${BASE_URL}/ccdi/custEnterpriseRelation/${TEST_ID}" \ -H "Authorization: Bearer $TOKEN") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if echo "$response" | grep -q '"personId"'; then log_test "查询详情" "PASS" "$response" "$duration" echo "查询成功,ID: $TEST_ID" else log_test "查询详情" "FAIL" "$response" "$duration" fail_exit "查询详情" "查询失败,响应: $response" fi } # 测试5: 修改记录 test_edit() { echo -e "\n${YELLOW}=== 测试5: 修改记录 ===${NC}" local new_enterprise_name="${TEST_ENTERPRISE_NAME}_已修改" local start_time=$(date +%s%3N) local response=$(curl -s -X PUT \ "${BASE_URL}/ccdi/custEnterpriseRelation" \ -H "Authorization: Bearer $TOKEN" \ -H "Content-Type: application/json" \ -d "{ \"id\": ${TEST_ID}, \"enterpriseName\": \"${new_enterprise_name}\", \"relationPersonPost\": \"法人\", \"status\": 1, \"remark\": \"修改后的备注\" }") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if echo "$response" | grep -q '"code":200'; then log_test "修改记录" "PASS" "$response" "$duration" echo "修改成功" else log_test "修改记录" "FAIL" "$response" "$duration" fail_exit "修改记录" "修改失败,响应: $response" fi } # 测试6: 导出Excel test_export() { echo -e "\n${YELLOW}=== 测试6: 导出Excel ===${NC}" local output_file="${TEST_DATA_DIR}/export_test.xlsx" mkdir -p "$TEST_DATA_DIR" local start_time=$(date +%s%3N) local http_code=$(curl -s -o "$output_file" -w "%{http_code}" -X POST \ "${BASE_URL}/ccdi/custEnterpriseRelation/export" \ -H "Authorization: Bearer $TOKEN" \ -H "Content-Type: application/json" \ -d '{}') local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if [ "$http_code" == "200" ] && [ -f "$output_file" ]; then local file_size=$(stat -c%s "$output_file" 2>/dev/null || stat -f%z "$output_file" 2>/dev/null || echo "0") log_test "导出Excel" "PASS" "HTTP $http_code, 文件大小: ${file_size}bytes" "$duration" echo "导出成功,文件: $output_file" else log_test "导出Excel" "FAIL" "HTTP $http_code" "$duration" fail_exit "导出Excel" "导出失败,HTTP状态码: $http_code" fi } # 测试7: 下载导入模板 test_import_template() { echo -e "\n${YELLOW}=== 测试7: 下载导入模板 ===${NC}" local output_file="${TEST_DATA_DIR}/import_template.xlsx" local start_time=$(date +%s%3N) local http_code=$(curl -s -o "$output_file" -w "%{http_code}" -X GET \ "${BASE_URL}/ccdi/custEnterpriseRelation/importTemplate" \ -H "Authorization: Bearer $TOKEN") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if [ "$http_code" == "200" ] && [ -f "$output_file" ]; then local file_size=$(stat -c%s "$output_file" 2>/dev/null || stat -f%z "$output_file" 2>/dev/null || echo "0") log_test "下载导入模板" "PASS" "HTTP $http_code, 文件大小: ${file_size}bytes" "$duration" echo "下载成功,文件: $output_file" else log_test "下载导入模板" "FAIL" "HTTP $http_code" "$duration" fail_exit "下载导入模板" "下载失败,HTTP状态码: $http_code" fi } # 测试8: 导入数据(非核心接口,失败不停止) test_import_data() { echo -e "\n${YELLOW}=== 测试8: 导入数据 ===${NC}" # 创建测试导入文件(使用multipart/form-data) # 创建一个有实际数据的CSV模拟文件 local import_csv="${TEST_DATA_DIR}/import_test.csv" # 创建CSV数据(身份证号,统一社会信用代码,企业名称,职务,备注) cat > "$import_csv" << 'CSVEOF' 身份证号,统一社会信用代码,企业名称,关联人在企业的职务,补充说明 120101199002021234,91110000100006442D,导入测试企业A,股东,导入测试数据1 120101199003031234,91110000100006443E,导入测试企业B,法人,导入测试数据2 CSVEOF # 由于需要xlsx格式,我们先创建一个简单的multipart请求 # 这里直接测试接口的响应,即使文件格式可能不对 local start_time=$(date +%s%3N) local response=$(curl -s -X POST \ "${BASE_URL}/ccdi/custEnterpriseRelation/importData" \ -H "Authorization: Bearer $TOKEN" \ -F "file=@${TEST_DATA_DIR}/import_template.xlsx") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应(导入可能是异步的,返回taskId或错误信息) if echo "$response" | grep -qE '"taskId"'; then local task_id=$(echo "$response" | grep -o '"taskId":"[^"]*"' | sed 's/"taskId":"//;s/"//') log_test "导入数据" "PASS" "$response" "$duration" echo "导入任务已提交,TaskId: $task_id" # 保存taskId供后续测试使用 echo "$task_id" > "${TEST_DATA_DIR}/last_task_id.txt" else # 导入失败(可能是文件格式问题),记录但不停止测试 log_test "导入数据" "FAIL" "$response" "$duration" echo -e "${YELLOW}导入测试失败(可能是测试文件格式问题),继续后续测试...${NC}" fi } # 测试9: 查询导入状态 test_import_status() { echo -e "\n${YELLOW}=== 测试9: 查询导入状态 ===${NC}" local task_id=$(cat "${TEST_DATA_DIR}/last_task_id.txt" 2>/dev/null) if [ -z "$task_id" ]; then # 如果没有taskId,使用一个测试ID task_id="test-task-id-$(date +%s)" fi local start_time=$(date +%s%3N) local response=$(curl -s -X GET \ "${BASE_URL}/ccdi/custEnterpriseRelation/importStatus/${task_id}" \ -H "Authorization: Bearer $TOKEN") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应(即使任务不存在,接口也应该正常响应) if echo "$response" | grep -qE '"status"|"code"'; then log_test "查询导入状态" "PASS" "$response" "$duration" echo "查询成功" else log_test "查询导入状态" "FAIL" "$response" "$duration" fail_exit "查询导入状态" "查询失败,响应: $response" fi } # 测试10: 查询导入失败记录 test_import_failures() { echo -e "\n${YELLOW}=== 测试10: 查询导入失败记录 ===${NC}" local task_id=$(cat "${TEST_DATA_DIR}/last_task_id.txt" 2>/dev/null) if [ -z "$task_id" ]; then task_id="test-task-id-$(date +%s)" fi local start_time=$(date +%s%3N) local response=$(curl -s -X GET \ "${BASE_URL}/ccdi/custEnterpriseRelation/importFailures/${task_id}?pageNum=1&pageSize=10" \ -H "Authorization: Bearer $TOKEN") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if echo "$response" | grep -qE '"total"|"code"'; then log_test "查询导入失败记录" "PASS" "$response" "$duration" echo "查询成功" else log_test "查询导入失败记录" "FAIL" "$response" "$duration" fail_exit "查询导入失败记录" "查询失败,响应: $response" fi } # 测试11: 删除记录 test_delete() { echo -e "\n${YELLOW}=== 测试11: 删除记录 ===${NC}" if [ -z "$TEST_ID" ]; then fail_exit "删除记录" "没有可删除的记录ID" fi local start_time=$(date +%s%3N) local response=$(curl -s -X DELETE \ "${BASE_URL}/ccdi/custEnterpriseRelation/${TEST_ID}" \ -H "Authorization: Bearer $TOKEN") local end_time=$(date +%s%3N) local duration=$((end_time - start_time)) # 检查响应 if echo "$response" | grep -q '"code":200'; then log_test "删除记录" "PASS" "$response" "$duration" echo "删除成功" else log_test "删除记录" "FAIL" "$response" "$duration" fail_exit "删除记录" "删除失败,响应: $response" fi } # 主函数 main() { echo "========================================" echo " 信贷客户实体关联信息后端功能测试" echo "========================================" echo "" # 检查必要命令 check_command curl check_command date # 初始化报告 init_report # 执行测试 test_login test_list test_add test_get_by_id test_edit test_export test_import_template test_import_data test_import_status test_import_failures test_delete # 完成报告 finalize_report echo "" echo "========================================" echo -e "${GREEN}所有测试完成!${NC}" echo "========================================" } # 运行主函数 main