## 新增文件 ### 测试脚本 (Task 11) - doc/scripts/test-intermediary-api.sh: 完整的API自动化测试脚本 * 获取Token * 测试查询列表(含条件查询) * 测试新增个人/实体中介 * 测试查询详情 * 测试修改操作 * 测试唯一性校验 * 支持彩色输出和错误处理 - doc/scripts/cleanup-intermediary-test-data.sh: 测试数据清理脚本 * 查询测试数据 * 删除测试数据 * 验证删除结果 - doc/scripts/run-test.bat: Windows测试脚本启动器 - doc/scripts/run-cleanup.bat: Windows清理脚本启动器 ### API文档 (Task 12) - doc/api/中介黑名单管理API文档-v2.0.md: 完整的v2.0 API接口文档 * 14个API接口详细说明 * 请求参数、响应格式、错误码 * 字典数据说明 * 业务错误信息 * v2.0主要变更说明 ### 菜单配置 (Task 13) - sql/menu-intermediary.sql: 菜单和权限配置SQL * 主菜单: 中介黑名单(目录) * 子菜单: 中介管理(页面) * 按钮权限: 查询、列表、新增、修改、删除、导出、导入 * 包含详细的注释和使用说明 ### 测试报告模板 (Task 14) - doc/test/intermediary-blacklist-test-report.md: 测试报告模板 * 44个测试用例(列表查询、个人/实体中介、唯一性校验、删除、导入导出、权限) * 测试结果统计表格 * 缺陷统计表格 * 测试结论模板 * 签名确认 ### 文档 (Task 10) - doc/README-中介黑名单测试部署.md: 测试与部署指南 * 快速开始指南 * API接口列表 * 菜单权限说明 * 数据字典说明 * 常见问题解答 * 版本历史 ## 功能特性 1. **自动化测试** - 支持Linux/Windows环境 - 完整的API覆盖 - 彩色输出,易于阅读 - 错误处理和提示 2. **完整的文档** - 详细的API文档 - 清晰的测试报告模板 - 便于复现的测试用例 3. **菜单配置** - 一键SQL执行 - 完整的权限体系 - 支持角色分配 4. **测试支持** - 测试数据清理 - 测试结果验证 - 批处理支持 ## 技术亮点 - 使用jq进行JSON解析 - 支持Token自动获取 - 完整的错误处理 - 跨平台支持(Linux/Windows) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
178 lines
4.7 KiB
Bash
178 lines
4.7 KiB
Bash
#!/bin/bash
|
|
|
|
################################################################################
|
|
# 中介黑名单管理测试数据清理脚本
|
|
# 功能: 清理测试脚本创建的测试数据
|
|
# 作者: Claude Code
|
|
# 日期: 2026-02-04
|
|
################################################################################
|
|
|
|
# 颜色定义
|
|
RED='\033[0;31m'
|
|
GREEN='\033[0;32m'
|
|
YELLOW='\033[1;33m'
|
|
NC='\033[0m' # No Color
|
|
|
|
# 配置
|
|
BASE_URL="http://localhost:8080"
|
|
TEST_USERNAME="admin"
|
|
TEST_PASSWORD="admin123"
|
|
|
|
# 输出函数
|
|
print_header() {
|
|
echo ""
|
|
echo "========================================"
|
|
echo "$1"
|
|
echo "========================================"
|
|
}
|
|
|
|
print_section() {
|
|
echo ""
|
|
echo -e "${YELLOW}=== $1 ===${NC}"
|
|
}
|
|
|
|
print_success() {
|
|
echo -e "${GREEN}✓ $1${NC}"
|
|
}
|
|
|
|
print_error() {
|
|
echo -e "${RED}✗ $1${NC}"
|
|
}
|
|
|
|
# 获取Token
|
|
get_token() {
|
|
print_section "获取Token"
|
|
|
|
TOKEN=$(curl -s -X POST "${BASE_URL}/login/test" \
|
|
-H "Content-Type: application/json" \
|
|
-d "{\"username\":\"${TEST_USERNAME}\",\"password\":\"${TEST_PASSWORD}\"}" | jq -r '.data.token')
|
|
|
|
if [ "$TOKEN" != "null" ] && [ -n "$TOKEN" ]; then
|
|
print_success "Token获取成功"
|
|
else
|
|
print_error "Token获取失败"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
# 查询测试数据
|
|
query_test_data() {
|
|
print_section "查询测试数据"
|
|
|
|
echo "查询测试个人中介:"
|
|
PERSON_RESPONSE=$(curl -s -X GET "${BASE_URL}/ccdi/intermediary/list?name=测试中介个人&intermediaryType=1" \
|
|
-H "Authorization: Bearer $TOKEN")
|
|
|
|
echo "$PERSON_RESPONSE" | jq '.'
|
|
|
|
PERSON_IDS=$(echo "$PERSON_RESPONSE" | jq -r '.rows[].bizId // empty')
|
|
|
|
echo ""
|
|
echo "查询测试实体中介:"
|
|
ENTITY_RESPONSE=$(curl -s -X GET "${BASE_URL}/ccdi/intermediary/list?name=测试中介公司&intermediaryType=2" \
|
|
-H "Authorization: Bearer $TOKEN")
|
|
|
|
echo "$ENTITY_RESPONSE" | jq '.'
|
|
|
|
ENTITY_IDS=$(echo "$ENTITY_RESPONSE" | jq -r '.rows[].bizId // empty')
|
|
}
|
|
|
|
# 删除测试数据
|
|
delete_test_data() {
|
|
print_section "删除测试数据"
|
|
|
|
# 删除测试个人中介
|
|
if [ -n "$PERSON_IDS" ]; then
|
|
echo "删除测试个人中介: $PERSON_IDS"
|
|
DELETE_RESPONSE=$(curl -s -X DELETE "${BASE_URL}/ccdi/intermediary/${PERSON_IDS}" \
|
|
-H "Authorization: Bearer $TOKEN")
|
|
|
|
echo "$DELETE_RESPONSE" | jq '.'
|
|
|
|
code=$(echo "$DELETE_RESPONSE" | jq -r '.code')
|
|
if [ "$code" == "200" ]; then
|
|
print_success "测试个人中介删除成功"
|
|
else
|
|
print_error "测试个人中介删除失败"
|
|
fi
|
|
else
|
|
echo "没有找到测试个人中介数据"
|
|
fi
|
|
|
|
# 删除测试实体中介
|
|
if [ -n "$ENTITY_IDS" ]; then
|
|
echo ""
|
|
echo "删除测试实体中介: $ENTITY_IDS"
|
|
DELETE_RESPONSE=$(curl -s -X DELETE "${BASE_URL}/ccdi/intermediary/${ENTITY_IDS}" \
|
|
-H "Authorization: Bearer $TOKEN")
|
|
|
|
echo "$DELETE_RESPONSE" | jq '.'
|
|
|
|
code=$(echo "$DELETE_RESPONSE" | jq -r '.code')
|
|
if [ "$code" == "200" ]; then
|
|
print_success "测试实体中介删除成功"
|
|
else
|
|
print_error "测试实体中介删除失败"
|
|
fi
|
|
else
|
|
echo ""
|
|
echo "没有找到测试实体中介数据"
|
|
fi
|
|
}
|
|
|
|
# 验证删除结果
|
|
verify_deletion() {
|
|
print_section "验证删除结果"
|
|
|
|
echo "验证测试个人中介是否已删除:"
|
|
VERIFY_PERSON=$(curl -s -X GET "${BASE_URL}/ccdi/intermediary/list?name=测试中介个人&intermediaryType=1" \
|
|
-H "Authorization: Bearer $TOKEN")
|
|
|
|
TOTAL=$(echo "$VERIFY_PERSON" | jq -r '.total')
|
|
if [ "$TOTAL" == "0" ]; then
|
|
print_success "测试个人中介已全部删除"
|
|
else
|
|
print_error "仍有 $TOTAL 条测试个人中介数据未删除"
|
|
fi
|
|
|
|
echo ""
|
|
echo "验证测试实体中介是否已删除:"
|
|
VERIFY_ENTITY=$(curl -s -X GET "${BASE_URL}/ccdi/intermediary/list?name=测试中介公司&intermediaryType=2" \
|
|
-H "Authorization: Bearer $TOKEN")
|
|
|
|
TOTAL=$(echo "$VERIFY_ENTITY" | jq -r '.total')
|
|
if [ "$TOTAL" == "0" ]; then
|
|
print_success "测试实体中介已全部删除"
|
|
else
|
|
print_error "仍有 $TOTAL 条测试实体中介数据未删除"
|
|
fi
|
|
}
|
|
|
|
# 主函数
|
|
main() {
|
|
print_header "中介黑名单测试数据清理开始"
|
|
|
|
# 检查jq命令
|
|
if ! command -v jq &> /dev/null; then
|
|
print_error "jq命令未安装,请先安装: apt-get install jq 或 yum install jq"
|
|
exit 1
|
|
fi
|
|
|
|
# 获取Token
|
|
get_token
|
|
|
|
# 查询测试数据
|
|
query_test_data
|
|
|
|
# 删除测试数据
|
|
delete_test_data
|
|
|
|
# 验证删除结果
|
|
verify_deletion
|
|
|
|
print_header "清理完成"
|
|
}
|
|
|
|
# 执行主函数
|
|
main
|