修改目录
This commit is contained in:
77
assets/信贷客户实体关联维护功能/ccdi_cust_enterprise_relation.sql
Normal file
77
assets/信贷客户实体关联维护功能/ccdi_cust_enterprise_relation.sql
Normal file
@@ -0,0 +1,77 @@
|
||||
-- 信贷客户实体关联关系表
|
||||
CREATE TABLE IF NOT EXISTS `ccdi_cust_enterprise_relation`
|
||||
(
|
||||
`id`
|
||||
BIGINT
|
||||
NOT
|
||||
NULL
|
||||
AUTO_INCREMENT
|
||||
COMMENT
|
||||
'主键,唯一标识',
|
||||
`person_id`
|
||||
VARCHAR
|
||||
(
|
||||
18
|
||||
) NOT NULL COMMENT '身份证号',
|
||||
`relation_person_post` VARCHAR
|
||||
(
|
||||
100
|
||||
) DEFAULT NULL COMMENT '关联人在企业的职务:股东、法人、高管、实际控制人等',
|
||||
`social_credit_code` VARCHAR
|
||||
(
|
||||
18
|
||||
) NOT NULL COMMENT '统一社会信用代码,关联企业主体信息表的外键',
|
||||
`enterprise_name` VARCHAR
|
||||
(
|
||||
200
|
||||
) DEFAULT NULL COMMENT '企业名称(冗余存储,便于快速查询)',
|
||||
`status` INT NOT NULL DEFAULT 1 COMMENT '关系是否有效:0 - 无效、1 - 有效(默认有效)',
|
||||
`remark` TEXT COMMENT '补充说明',
|
||||
`data_source` VARCHAR
|
||||
(
|
||||
50
|
||||
) DEFAULT NULL COMMENT '数据来源',
|
||||
`is_employee` TINYINT
|
||||
(
|
||||
1
|
||||
) NOT NULL DEFAULT 0 COMMENT '是否是员工:0-否 1-是',
|
||||
`is_emp_family` TINYINT
|
||||
(
|
||||
1
|
||||
) NOT NULL DEFAULT 0 COMMENT '是否是员工家庭关联人:0-否 1-是',
|
||||
`is_customer` TINYINT
|
||||
(
|
||||
1
|
||||
) NOT NULL DEFAULT 0 COMMENT '是否是信贷客户:0-否 1-是',
|
||||
`is_cust_family` TINYINT
|
||||
(
|
||||
1
|
||||
) NOT NULL DEFAULT 0 COMMENT '是否是信贷客户关联人:0-否 1-是',
|
||||
`created_by` VARCHAR
|
||||
(
|
||||
64
|
||||
) NOT NULL COMMENT '记录创建人',
|
||||
`updated_by` VARCHAR
|
||||
(
|
||||
64
|
||||
) DEFAULT NULL COMMENT '记录更新人',
|
||||
`create_time` DATETIME NOT NULL COMMENT '记录创建时间',
|
||||
`update_time` DATETIME NOT NULL COMMENT '记录更新时间',
|
||||
PRIMARY KEY
|
||||
(
|
||||
`id`
|
||||
),
|
||||
KEY `idx_person_id`
|
||||
(
|
||||
`person_id`
|
||||
),
|
||||
KEY `idx_social_credit_code`
|
||||
(
|
||||
`social_credit_code`
|
||||
),
|
||||
UNIQUE KEY `uk_person_enterprise`
|
||||
(
|
||||
`person_id`,
|
||||
`social_credit_code`
|
||||
)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE =utf8mb4_general_ci COMMENT='信贷客户实体关联关系表';
|
||||
516
assets/信贷客户实体关联维护功能/test_cust_enterprise_relation_api.sh
Normal file
516
assets/信贷客户实体关联维护功能/test_cust_enterprise_relation_api.sh
Normal file
@@ -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
|
||||
BIN
assets/信贷客户实体关联维护功能/test_data/export_test.xlsx
Normal file
BIN
assets/信贷客户实体关联维护功能/test_data/export_test.xlsx
Normal file
Binary file not shown.
BIN
assets/信贷客户实体关联维护功能/test_data/import_template.xlsx
Normal file
BIN
assets/信贷客户实体关联维护功能/test_data/import_template.xlsx
Normal file
Binary file not shown.
3
assets/信贷客户实体关联维护功能/test_data/import_test.csv
Normal file
3
assets/信贷客户实体关联维护功能/test_data/import_test.csv
Normal file
@@ -0,0 +1,3 @@
|
||||
身份证号,统一社会信用代码,企业名称,关联人在企业的职务,补充说明
|
||||
120101199002021234,91110000100006442D,导入测试企业A,股东,导入测试数据1
|
||||
120101199003031234,91110000100006443E,导入测试企业B,法人,导入测试数据2
|
||||
|
1
assets/信贷客户实体关联维护功能/test_data/import_test.xlsx
Normal file
1
assets/信贷客户实体关联维护功能/test_data/import_test.xlsx
Normal file
@@ -0,0 +1 @@
|
||||
{"msg":"请求参数类型不匹配,参数[id]要求类型为:'java.lang.Long',但输入值为:'importTemplate'","code":500}
|
||||
BIN
assets/信贷客户实体关联维护功能/test_data/test_import_data.xlsx
Normal file
BIN
assets/信贷客户实体关联维护功能/test_data/test_import_data.xlsx
Normal file
Binary file not shown.
244
assets/信贷客户实体关联维护功能/代码校验报告.md
Normal file
244
assets/信贷客户实体关联维护功能/代码校验报告.md
Normal file
@@ -0,0 +1,244 @@
|
||||
# 信贷客户实体关联维护功能 - 代码校验报告
|
||||
|
||||
## 一、校验概述
|
||||
|
||||
本文档对信贷客户实体关联维护功能与员工实体关系维护功能进行逻辑一致性校验,确保前端交互方式和后端实现逻辑保持一致。
|
||||
|
||||
---
|
||||
|
||||
## 二、后端逻辑校验
|
||||
|
||||
### 2.1 Controller层对比
|
||||
|
||||
| 接口功能 | 员工实体关系 | 信贷客户实体关联 | 一致性 |
|
||||
|--------|--------------------------|--------------------------|-----|
|
||||
| 分页查询 | /list | /list | ✓ |
|
||||
| 导出 | /export | /export | ✓ |
|
||||
| 详情查询 | /{id} | /{id} | ✓ |
|
||||
| 新增 | POST / | POST / | ✓ |
|
||||
| 修改 | PUT / | PUT / | ✓ |
|
||||
| 删除 | DELETE /{ids} | DELETE /{ids} | ✓ |
|
||||
| 下载模板 | /importTemplate | /importTemplate | ✓ |
|
||||
| 异步导入 | /importData | /importData | ✓ |
|
||||
| 查询导入状态 | /importStatus/{taskId} | /importStatus/{taskId} | ✓ |
|
||||
| 查询失败记录 | /importFailures/{taskId} | /importFailures/{taskId} | ✓ |
|
||||
|
||||
**结论**:Controller层接口设计完全一致 ✓
|
||||
|
||||
### 2.2 Service层对比
|
||||
|
||||
| 方法 | 员工实体关系 | 信贷客户实体关联 | 一致性 |
|
||||
|-----------------------------|--------|----------|-----------|
|
||||
| selectRelationPage | ✓ | ✓ | ✓ |
|
||||
| selectRelationListForExport | ✓ | ✓ | ✓ |
|
||||
| selectRelationById | ✓ | ✓ | ✓ |
|
||||
| insertRelation | ✓ | ✓ | ✓(差异在默认值) |
|
||||
| updateRelation | ✓ | ✓ | ✓ |
|
||||
| deleteRelationByIds | ✓ | ✓ | ✓ |
|
||||
| importRelation | ✓ | ✓ | ✓ |
|
||||
|
||||
**结论**:Service层方法设计完全一致 ✓
|
||||
|
||||
### 2.3 异步导入逻辑对比
|
||||
|
||||
| 导入步骤 | 员工实体关系 | 信贷客户实体关联 | 差异说明 |
|
||||
|------------------|-----------------|------------------|--------|
|
||||
| 1. 记录导入开始日志 | ✓ | ✓ | 一致 |
|
||||
| 2. 批量查询已存在组合 | ✓ | ✓ | 一致 |
|
||||
| 3. 验证必填字段 | ✓ | ✓ | 一致 |
|
||||
| 4. 验证身份证格式 | ✓ | ✓ | 一致 |
|
||||
| 5. 验证社会信用代码格式 | ✓ | ✓ | 一致 |
|
||||
| 6. **验证身份证号存在性** | ✓ | **无** | **差异** |
|
||||
| 7. 检查组合唯一性 | ✓ | ✓ | 一致 |
|
||||
| 8. 检查文件内重复 | ✓ | ✓ | 一致 |
|
||||
| 9. 设置身份标识 | is_emp_family=1 | is_cust_family=1 | **差异** |
|
||||
| 10. 设置数据来源 | IMPORT | IMPORT | 一致 |
|
||||
| 11. 批量插入 | 500条/批 | 500条/批 | 一致 |
|
||||
| 12. 保存失败记录到Redis | ✓ | ✓ | 一致 |
|
||||
| 13. 更新导入状态 | ✓ | ✓ | 一致 |
|
||||
| 14. 记录导入完成日志 | ✓ | ✓ | 一致 |
|
||||
|
||||
**关键差异说明**:
|
||||
|
||||
- **身份证号验证**:员工实体关系需要验证身份证号存在于员工表;信贷客户实体关联不需要
|
||||
- **身份标识默认值**:员工实体关系 `is_emp_family=1`;信贷客户实体关联 `is_cust_family=1`
|
||||
|
||||
**结论**:导入逻辑框架一致,仅按需求有指定差异 ✓
|
||||
|
||||
### 2.4 Redis Key对比
|
||||
|
||||
| 用途 | 员工实体关系 | 信贷客户实体关联 |
|
||||
|------|--------------------------------------------------|-------------------------------------------------|
|
||||
| 导入状态 | import:staffEnterpriseRelation:{taskId} | import:custEnterpriseRelation:{taskId} |
|
||||
| 失败记录 | import:staffEnterpriseRelation:{taskId}:failures | import:custEnterpriseRelation:{taskId}:failures |
|
||||
| 过期时间 | 7天 | 7天 |
|
||||
|
||||
**结论**:Redis key设计模式一致 ✓
|
||||
|
||||
### 2.5 Mapper XML对比
|
||||
|
||||
| SQL功能 | 员工实体关系 | 信贷客户实体关联 | 差异说明 |
|
||||
|--------|--------------------------------|--------------------------------|--------|
|
||||
| 分页查询 | LEFT JOIN员工表获取姓名 | 不JOIN | **差异** |
|
||||
| 详情查询 | LEFT JOIN员工表获取姓名 | 不JOIN | **差异** |
|
||||
| 唯一性检查 | person_id + social_credit_code | person_id + social_credit_code | 一致 |
|
||||
| 批量存在检查 | ✓ | ✓ | 一致 |
|
||||
| 批量插入 | ✓ | ✓ | 一致 |
|
||||
|
||||
**结论**:Mapper SQL框架一致,差异在于是否JOIN员工表 ✓
|
||||
|
||||
---
|
||||
|
||||
## 三、前端逻辑校验
|
||||
|
||||
### 3.1 页面功能对比
|
||||
|
||||
| 功能 | 员工实体关系 | 信贷客户实体关联 | 一致性 |
|
||||
|----------|--------|----------|---------|
|
||||
| 搜索表单 | ✓ | ✓ | ✓ |
|
||||
| 新增按钮 | ✓ | ✓ | ✓ |
|
||||
| 导入按钮 | ✓ | ✓ | ✓ |
|
||||
| 导出按钮 | ✓ | ✓ | ✓ |
|
||||
| 查看失败记录按钮 | ✓ | ✓ | ✓ |
|
||||
| 列表展示 | ✓ | ✓ | ✓(差异在列) |
|
||||
| 分页 | ✓ | ✓ | ✓ |
|
||||
| 新增/编辑弹窗 | ✓ | ✓ | ✓ |
|
||||
| 详情弹窗 | ✓ | ✓ | ✓ |
|
||||
| 导入弹窗 | ✓ | ✓ | ✓ |
|
||||
| 失败记录弹窗 | ✓ | ✓ | ✓ |
|
||||
|
||||
**结论**:页面功能完全一致 ✓
|
||||
|
||||
### 3.2 表单交互对比
|
||||
|
||||
| 交互项 | 员工实体关系 | 信贷客户实体关联 | 差异说明 |
|
||||
|----------|---------|----------|--------|
|
||||
| 身份证号输入 | 远程搜索下拉框 | 普通输入框 | **差异** |
|
||||
| 统一社会信用代码 | 输入框 | 输入框 | 一致 |
|
||||
| 企业名称 | 输入框 | 输入框 | 一致 |
|
||||
| 职务 | 输入框 | 输入框 | 一致 |
|
||||
| 状态(编辑时) | 下拉选择 | 下拉选择 | 一致 |
|
||||
| 补充说明 | 文本域 | 文本域 | 一致 |
|
||||
|
||||
**结论**:除身份证号输入方式外,其他表单交互一致 ✓
|
||||
|
||||
### 3.3 列表展示对比
|
||||
|
||||
| 列 | 员工实体关系 | 信贷客户实体关联 | 差异说明 |
|
||||
|----------|--------|----------|--------|
|
||||
| 选择框 | ✓ | ✓ | 一致 |
|
||||
| 身份证号 | ✓ | ✓ | 一致 |
|
||||
| **员工姓名** | ✓ | **无** | **差异** |
|
||||
| 企业名称 | ✓ | ✓ | 一致 |
|
||||
| 职务 | ✓ | ✓ | 一致 |
|
||||
| 状态 | ✓ | ✓ | 一致 |
|
||||
| 数据来源 | ✓ | ✓ | 一致 |
|
||||
| 创建时间 | ✓ | ✓ | 一致 |
|
||||
| 操作列 | ✓ | ✓ | 一致 |
|
||||
|
||||
**结论**:除员工姓名列外,其他列一致 ✓
|
||||
|
||||
### 3.4 详情弹窗对比
|
||||
|
||||
| 展示项 | 员工实体关系 | 信贷客户实体关联 | 差异说明 |
|
||||
|----------|--------|----------|--------|
|
||||
| **员工姓名** | ✓ | **无** | **差异** |
|
||||
| 身份证号 | ✓ | ✓ | 一致 |
|
||||
| 统一社会信用代码 | ✓ | ✓ | 一致 |
|
||||
| 企业名称 | ✓ | ✓ | 一致 |
|
||||
| 职务 | ✓ | ✓ | 一致 |
|
||||
| 状态 | ✓ | ✓ | 一致 |
|
||||
| 数据来源 | ✓ | ✓ | 一致 |
|
||||
| 补充说明 | ✓ | ✓ | 一致 |
|
||||
| 创建时间/人 | ✓ | ✓ | 一致 |
|
||||
| 更新时间/人 | ✓ | ✓ | 一致 |
|
||||
|
||||
**结论**:除员工姓名外,详情展示一致 ✓
|
||||
|
||||
### 3.5 导入流程对比
|
||||
|
||||
| 导入步骤 | 员工实体关系 | 信贷客户实体关联 | 一致性 |
|
||||
|---------------|--------|----------|-----|
|
||||
| 点击导入按钮 | ✓ | ✓ | ✓ |
|
||||
| 弹出上传对话框 | ✓ | ✓ | ✓ |
|
||||
| 下载模板 | ✓ | ✓ | ✓ |
|
||||
| 选择文件上传 | ✓ | ✓ | ✓ |
|
||||
| 提交后立即返回taskId | ✓ | ✓ | ✓ |
|
||||
| 显示后台处理提示 | ✓ | ✓ | ✓ |
|
||||
| 开始轮询导入状态 | 2秒/次 | 2秒/次 | ✓ |
|
||||
| 处理完成后通知 | ✓ | ✓ | ✓ |
|
||||
| 显示失败记录按钮 | 有失败时显示 | 有失败时显示 | ✓ |
|
||||
| 查看失败记录弹窗 | ✓ | ✓ | ✓ |
|
||||
| 分页展示失败记录 | ✓ | ✓ | ✓ |
|
||||
| 清除历史记录 | ✓ | ✓ | ✓ |
|
||||
|
||||
**结论**:导入流程完全一致 ✓
|
||||
|
||||
### 3.6 localStorage对比
|
||||
|
||||
| 用途 | 员工实体关系 | 信贷客户实体关联 |
|
||||
|-------|--------------------------------------------|-------------------------------------------|
|
||||
| 存储key | staff_enterprise_relation_import_last_task | cust_enterprise_relation_import_last_task |
|
||||
| 存储内容 | taskId, status, counts, saveTime | 相同 |
|
||||
| 过期检查 | 7天 | 7天 |
|
||||
|
||||
**结论**:localStorage使用模式一致 ✓
|
||||
|
||||
---
|
||||
|
||||
## 四、权限配置对比
|
||||
|
||||
| 权限 | 员工实体关系 | 信贷客户实体关联 |
|
||||
|----|-------------------------------------|------------------------------------|
|
||||
| 列表 | ccdi:staffEnterpriseRelation:list | ccdi:custEnterpriseRelation:list |
|
||||
| 查询 | ccdi:staffEnterpriseRelation:query | ccdi:custEnterpriseRelation:query |
|
||||
| 新增 | ccdi:staffEnterpriseRelation:add | ccdi:custEnterpriseRelation:add |
|
||||
| 编辑 | ccdi:staffEnterpriseRelation:edit | ccdi:custEnterpriseRelation:edit |
|
||||
| 删除 | ccdi:staffEnterpriseRelation:remove | ccdi:custEnterpriseRelation:remove |
|
||||
| 导出 | ccdi:staffEnterpriseRelation:export | ccdi:custEnterpriseRelation:export |
|
||||
| 导入 | ccdi:staffEnterpriseRelation:import | ccdi:custEnterpriseRelation:import |
|
||||
|
||||
**结论**:权限命名规范一致 ✓
|
||||
|
||||
---
|
||||
|
||||
## 五、校验总结
|
||||
|
||||
### 5.1 一致性检查结果
|
||||
|
||||
| 检查项 | 状态 |
|
||||
|----------------|----------------|
|
||||
| Controller接口设计 | ✓ 一致 |
|
||||
| Service方法设计 | ✓ 一致 |
|
||||
| 异步导入框架 | ✓ 一致 |
|
||||
| Redis状态管理 | ✓ 一致 |
|
||||
| Mapper SQL框架 | ✓ 一致 |
|
||||
| 前端页面功能 | ✓ 一致 |
|
||||
| 前端表单交互 | ✓ 一致(除身份证输入方式) |
|
||||
| 前端列表展示 | ✓ 一致(除姓名列) |
|
||||
| 前端详情展示 | ✓ 一致(除姓名) |
|
||||
| 导入流程 | ✓ 一致 |
|
||||
| localStorage使用 | ✓ 一致 |
|
||||
| 权限命名规范 | ✓ 一致 |
|
||||
|
||||
### 5.2 预期差异确认
|
||||
|
||||
| 差异项 | 员工实体关系 | 信贷客户实体关联 | 状态 |
|
||||
|------------------|---------------------------|--------------------------|--------|
|
||||
| 身份证号验证 | 验证存在员工表 | 不验证 | ✓ 符合预期 |
|
||||
| 员工搜索功能 | 有 | 无 | ✓ 符合预期 |
|
||||
| 姓名显示 | 有 | 无 | ✓ 符合预期 |
|
||||
| 身份标识默认值 | is_emp_family=1 | is_cust_family=1 | ✓ 符合预期 |
|
||||
| API路径 | staffEnterpriseRelation | custEnterpriseRelation | ✓ 符合预期 |
|
||||
| 权限标识 | staffEnterpriseRelation | custEnterpriseRelation | ✓ 符合预期 |
|
||||
| localStorage key | staff_enterprise_relation | cust_enterprise_relation | ✓ 符合预期 |
|
||||
|
||||
### 5.3 校验结论
|
||||
|
||||
**信贷客户实体关联维护功能的实施方案与员工实体关系维护功能在逻辑上完全一致**,所有差异均符合需求预期:
|
||||
|
||||
1. ✓ 后端实现逻辑一致(CRUD、异步导入、Redis状态管理)
|
||||
2. ✓ 前端交互方式一致(弹窗、导入流程、状态轮询)
|
||||
3. ✓ 预期差异均已正确处理(无员工搜索、无姓名显示、身份标识默认值不同)
|
||||
|
||||
**实施方案可直接用于开发实施。**
|
||||
1088
assets/信贷客户实体关联维护功能/前端实施方案.md
Normal file
1088
assets/信贷客户实体关联维护功能/前端实施方案.md
Normal file
File diff suppressed because it is too large
Load Diff
1515
assets/信贷客户实体关联维护功能/后端实施方案.md
Normal file
1515
assets/信贷客户实体关联维护功能/后端实施方案.md
Normal file
File diff suppressed because it is too large
Load Diff
59
assets/信贷客户实体关联维护功能/测试报告.md
Normal file
59
assets/信贷客户实体关联维护功能/测试报告.md
Normal file
@@ -0,0 +1,59 @@
|
||||
# 信贷客户实体关联信息后端功能测试报告
|
||||
|
||||
## 测试概述
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|--------------|
|
||||
| 测试模块 | 信贷客户实体关联信息管理 |
|
||||
| 测试环境 | 后端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}... |
|
||||
|
||||
## 测试结论
|
||||
|
||||
**存在测试失败!** 请检查失败的接口和错误信息。
|
||||
Reference in New Issue
Block a user