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 0000000..3b48ff2 Binary files /dev/null and b/doc/信贷客户实体关联维护功能/test_data/export_test.xlsx differ diff --git a/doc/信贷客户实体关联维护功能/test_data/import_template.xlsx b/doc/信贷客户实体关联维护功能/test_data/import_template.xlsx new file mode 100644 index 0000000..9861005 Binary files /dev/null and b/doc/信贷客户实体关联维护功能/test_data/import_template.xlsx differ diff --git a/doc/信贷客户实体关联维护功能/test_data/import_test.csv b/doc/信贷客户实体关联维护功能/test_data/import_test.csv new file mode 100644 index 0000000..888f138 --- /dev/null +++ b/doc/信贷客户实体关联维护功能/test_data/import_test.csv @@ -0,0 +1,3 @@ +身份证号,统一社会信用代码,企业名称,关联人在企业的职务,补充说明 +120101199002021234,91110000100006442D,导入测试企业A,股东,导入测试数据1 +120101199003031234,91110000100006443E,导入测试企业B,法人,导入测试数据2 diff --git a/doc/信贷客户实体关联维护功能/test_data/import_test.xlsx b/doc/信贷客户实体关联维护功能/test_data/import_test.xlsx new file mode 100644 index 0000000..7c69e89 --- /dev/null +++ b/doc/信贷客户实体关联维护功能/test_data/import_test.xlsx @@ -0,0 +1 @@ +{"msg":"请求参数类型不匹配,参数[id]要求类型为:'java.lang.Long',但输入值为:'importTemplate'","code":500} \ No newline at end of file diff --git a/doc/信贷客户实体关联维护功能/test_data/test_import_data.xlsx b/doc/信贷客户实体关联维护功能/test_data/test_import_data.xlsx new file mode 100644 index 0000000..f3b647b Binary files /dev/null and b/doc/信贷客户实体关联维护功能/test_data/test_import_data.xlsx differ 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 @@ + + + + +