Server测试迁移优化 - Brownfield Epic
Epic Goal
将当前web目录中对packages/server的测试迁移到packages/server目录中,实现更好的代码组织和测试架构,使packages/server成为一个真正独立的、可测试的库包。
Epic Description
现有系统上下文
- 当前测试结构:所有测试集中在web/tests目录下,包括对packages/server的单元测试和集成测试
- packages/server现状:纯库包,没有任何测试配置和测试文件
- 技术栈:Node.js + TypeScript + Hono + TypeORM + PostgreSQL + Vitest
- 集成点:数据库连接、服务层、工具类、API路由
迁移详情
- 迁移内容:将web/tests中针对packages/server的单元测试和部分集成测试迁移到packages/server目录
- 保留内容:前端组件测试、E2E测试、需要web特定环境的集成测试
- 目标架构:
- packages/server成为独立的可测试库包
- web目录专注于前端和端到端测试
- 测试工具类在适当位置共享
迁移优先级
- 高优先级:服务层单元测试(UserService、FileService、MinioService等)
- 中优先级:工具类单元测试(backup、restore、jwt等)
- 低优先级:集成测试(需要评估依赖关系)
Stories
Story 005.001: 为packages/server配置测试环境
- 在packages/server/package.json中添加测试脚本
- 创建packages/server/vitest.config.ts配置文件
- 建立packages/server/tests目录结构
- 配置测试依赖和工具
Story 005.002: 迁移服务层单元测试
- 迁移UserService相关测试
- 迁移FileService相关测试
- 迁移MinioService相关测试
- 迁移AuthService相关测试
- 验证迁移后测试正常运行
Story 005.003: 迁移工具类单元测试
- 迁移backup工具测试
- 迁移restore工具测试
- 迁移jwt工具测试
- 迁移其他工具类测试
- 验证迁移后测试正常运行
Story 005.004: 评估和迁移集成测试
- 分析集成测试对web环境的依赖
- 迁移适合的集成测试到packages/server
- 更新测试工具类的共享使用
- 验证集成测试正常运行
Story 005.005: 清理和优化
- 清理web目录中已迁移的测试文件
- 更新CI/CD配置支持新的测试结构
- 更新文档说明新的测试架构
- 验证整体测试覆盖率
兼容性要求
风险缓解
- 主要风险:测试迁移导致测试失败或遗漏
- 缓解措施:逐步迁移,保持新旧测试并行运行一段时间
- 次要风险:测试工具类依赖关系复杂
- 缓解措施:仔细分析依赖,创建适当的共享机制
- 回滚计划:恢复原有测试文件,删除packages/server中的测试配置
完成定义
验证检查清单
范围验证
风险评估
完整性检查