From 7d1ab61705569d246c621d7bdf7895521f110f8c Mon Sep 17 00:00:00 2001 From: wkc <978997012@qq.com> Date: Fri, 13 Feb 2026 10:15:34 +0800 Subject: [PATCH] =?UTF-8?q?feat=E4=BF=A1=E8=B4=B7=E5=AE=A2=E6=88=B7?= =?UTF-8?q?=E5=AE=9E=E4=BD=93=E5=85=B3=E7=B3=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../test_cust_enterprise_relation_api.sh | 516 +++++++++++ .../test_data/export_test.xlsx | Bin 0 -> 3880 bytes .../test_data/import_template.xlsx | Bin 0 -> 3720 bytes .../test_data/import_test.csv | 3 + .../test_data/import_test.xlsx | 1 + .../test_data/test_import_data.xlsx | Bin 0 -> 6352 bytes doc/信贷客户实体关联维护功能/测试报告.md | 58 ++ .../src/api/ccdiCustEnterpriseRelation.js | 89 ++ .../ccdiCustEnterpriseRelation/index.vue | 855 ++++++++++++++++++ 9 files changed, 1522 insertions(+) create mode 100644 doc/信贷客户实体关联维护功能/test_cust_enterprise_relation_api.sh create mode 100644 doc/信贷客户实体关联维护功能/test_data/export_test.xlsx create mode 100644 doc/信贷客户实体关联维护功能/test_data/import_template.xlsx create mode 100644 doc/信贷客户实体关联维护功能/test_data/import_test.csv create mode 100644 doc/信贷客户实体关联维护功能/test_data/import_test.xlsx create mode 100644 doc/信贷客户实体关联维护功能/test_data/test_import_data.xlsx create mode 100644 doc/信贷客户实体关联维护功能/测试报告.md create mode 100644 ruoyi-ui/src/api/ccdiCustEnterpriseRelation.js create mode 100644 ruoyi-ui/src/views/ccdiCustEnterpriseRelation/index.vue diff --git a/doc/信贷客户实体关联维护功能/test_cust_enterprise_relation_api.sh b/doc/信贷客户实体关联维护功能/test_cust_enterprise_relation_api.sh new file mode 100644 index 0000000..e42d271 --- /dev/null +++ b/doc/信贷客户实体关联维护功能/test_cust_enterprise_relation_api.sh @@ -0,0 +1,516 @@ +#!/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 diff --git a/doc/信贷客户实体关联维护功能/test_data/export_test.xlsx b/doc/信贷客户实体关联维护功能/test_data/export_test.xlsx new file mode 100644 index 0000000000000000000000000000000000000000..3b48ff234135d9db5b9d4187e65b03100be36223 GIT binary patch literal 3880 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 UW1x}<0AQjXD%54_J4k!`7xJ7rXaE2J literal 0 HcmV?d00001 diff --git a/doc/信贷客户实体关联维护功能/test_data/import_template.xlsx b/doc/信贷客户实体关联维护功能/test_data/import_template.xlsx new file mode 100644 index 0000000000000000000000000000000000000000..98610051d7690e7cf8a7809fd3ffe5d1e1cdc265 GIT binary patch literal 3720 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 O<5&2x;(NdN{q{dvuSod- literal 0 HcmV?d00001 diff --git a/doc/信贷客户实体关联维护功能/测试报告.md b/doc/信贷客户实体关联维护功能/测试报告.md new file mode 100644 index 0000000..af9a64f --- /dev/null +++ b/doc/信贷客户实体关联维护功能/测试报告.md @@ -0,0 +1,58 @@ +# 信贷客户实体关联信息后端功能测试报告 + +## 测试概述 + +| 项目 | 内容 | +|------|------| +| 测试模块 | 信贷客户实体关联信息管理 | +| 测试环境 | 后端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} | + +## 测试结果汇总 + + +| 统计项 | 数值 | +|--------|------| +| 总测试数 | 11 | +| 通过数 | 10 | +| 失败数 | 1 | +| 通过率 | 90% | + +## 详细测试结果 + +| 序号 | 测试接口 | 状态 | 耗时(ms) | 响应摘要 | +|------|----------|------|----------|----------| +| 1 | 获取Token | :white_check_mark: PASS | 754 | {"msg":"操作成功","code":200,"token":"eyJhbGciOiJIUzUx... | +| 2 | 分页查询列表 | :white_check_mark: PASS | 276 | {"total":1,"rows":[{"id":1,"personId":"11010119900... | +| 3 | 新增记录 | :white_check_mark: PASS | 419 | {"msg":"操作成功","code":200}... | +| 4 | 查询详情 | :white_check_mark: PASS | 187 | {"msg":"操作成功","code":200,"data":{"id":2,"personId"... | +| 5 | 修改记录 | :white_check_mark: PASS | 413 | {"msg":"操作成功","code":200}... | +| 6 | 导出Excel | :white_check_mark: PASS | 309 | HTTP 200, 文件大小: 3880bytes... | +| 7 | 下载导入模板 | :white_check_mark: PASS | 172 | HTTP 200, 文件大小: 132bytes... | +| 8 | 导入数据 | :x: FAIL | 187 | {"msg":"导入Excel失败","code":500}... | +| 9 | 查询导入状态 | :white_check_mark: PASS | 215 | {"msg":"任务不存在或已过期","code":500}... | +| 10 | 查询导入失败记录 | :white_check_mark: PASS | 236 | {"total":0,"rows":[],"code":200,"msg":"查询成功"}... | +| 11 | 删除记录 | :white_check_mark: PASS | 364 | {"msg":"操作成功","code":200}... | + +## 测试结论 + +**存在测试失败!** 请检查失败的接口和错误信息。 diff --git a/ruoyi-ui/src/api/ccdiCustEnterpriseRelation.js b/ruoyi-ui/src/api/ccdiCustEnterpriseRelation.js new file mode 100644 index 0000000..389a5ca --- /dev/null +++ b/ruoyi-ui/src/api/ccdiCustEnterpriseRelation.js @@ -0,0 +1,89 @@ +import request from '@/utils/request' + +// 查询信贷客户实体关联列表 +export function listRelation(query) { + return request({ + url: '/ccdi/custEnterpriseRelation/list', + method: 'get', + params: query + }) +} + +// 查询信贷客户实体关联详情 +export function getRelation(id) { + return request({ + url: '/ccdi/custEnterpriseRelation/' + id, + method: 'get' + }) +} + +// 新增信贷客户实体关联 +export function addRelation(data) { + return request({ + url: '/ccdi/custEnterpriseRelation', + method: 'post', + data: data + }) +} + +// 修改信贷客户实体关联 +export function updateRelation(data) { + return request({ + url: '/ccdi/custEnterpriseRelation', + method: 'put', + data: data + }) +} + +// 删除信贷客户实体关联 +export function delRelation(ids) { + return request({ + url: '/ccdi/custEnterpriseRelation/' + ids, + method: 'delete' + }) +} + +// 导出信贷客户实体关联 +export function exportRelation(query) { + return request({ + url: '/ccdi/custEnterpriseRelation/export', + method: 'post', + params: query + }) +} + +// 下载导入模板 +export function importTemplate() { + return request({ + url: '/ccdi/custEnterpriseRelation/importTemplate', + method: 'post' + }) +} + +// 导入信贷客户实体关联 +export function importData(file) { + const formData = new FormData() + formData.append('file', file) + return request({ + url: '/ccdi/custEnterpriseRelation/importData', + method: 'post', + data: formData + }) +} + +// 查询导入状态 +export function getImportStatus(taskId) { + return request({ + url: '/ccdi/custEnterpriseRelation/importStatus/' + taskId, + method: 'get' + }) +} + +// 查询导入失败记录 +export function getImportFailures(taskId, pageNum, pageSize) { + return request({ + url: '/ccdi/custEnterpriseRelation/importFailures/' + taskId, + method: 'get', + params: { pageNum, pageSize } + }) +} diff --git a/ruoyi-ui/src/views/ccdiCustEnterpriseRelation/index.vue b/ruoyi-ui/src/views/ccdiCustEnterpriseRelation/index.vue new file mode 100644 index 0000000..1649190 --- /dev/null +++ b/ruoyi-ui/src/views/ccdiCustEnterpriseRelation/index.vue @@ -0,0 +1,855 @@ + + + + +