|
|
@@ -0,0 +1,104 @@
|
|
|
+# 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目录专注于前端和端到端测试
|
|
|
+ - 测试工具类在适当位置共享
|
|
|
+
|
|
|
+### 迁移优先级
|
|
|
+1. **高优先级**:服务层单元测试(UserService、FileService、MinioService等)
|
|
|
+2. **中优先级**:工具类单元测试(backup、restore、jwt等)
|
|
|
+3. **低优先级**:集成测试(需要评估依赖关系)
|
|
|
+
|
|
|
+## Stories
|
|
|
+
|
|
|
+1. **Story 005.001**: 为packages/server配置测试环境
|
|
|
+ - 在packages/server/package.json中添加测试脚本
|
|
|
+ - 创建packages/server/vitest.config.ts配置文件
|
|
|
+ - 建立packages/server/tests目录结构
|
|
|
+ - 配置测试依赖和工具
|
|
|
+
|
|
|
+2. **Story 005.002**: 迁移服务层单元测试
|
|
|
+ - 迁移UserService相关测试
|
|
|
+ - 迁移FileService相关测试
|
|
|
+ - 迁移MinioService相关测试
|
|
|
+ - 迁移AuthService相关测试
|
|
|
+ - 验证迁移后测试正常运行
|
|
|
+
|
|
|
+3. **Story 005.003**: 迁移工具类单元测试
|
|
|
+ - 迁移backup工具测试
|
|
|
+ - 迁移restore工具测试
|
|
|
+ - 迁移jwt工具测试
|
|
|
+ - 迁移其他工具类测试
|
|
|
+ - 验证迁移后测试正常运行
|
|
|
+
|
|
|
+4. **Story 005.004**: 评估和迁移集成测试
|
|
|
+ - 分析集成测试对web环境的依赖
|
|
|
+ - 迁移适合的集成测试到packages/server
|
|
|
+ - 更新测试工具类的共享使用
|
|
|
+ - 验证集成测试正常运行
|
|
|
+
|
|
|
+5. **Story 005.005**: 清理和优化
|
|
|
+ - 清理web目录中已迁移的测试文件
|
|
|
+ - 更新CI/CD配置支持新的测试结构
|
|
|
+ - 更新文档说明新的测试架构
|
|
|
+ - 验证整体测试覆盖率
|
|
|
+
|
|
|
+## 兼容性要求
|
|
|
+
|
|
|
+- [ ] 现有API保持不变
|
|
|
+- [ ] 测试功能对等(迁移前后测试覆盖相同功能)
|
|
|
+- [ ] 现有测试继续正常工作
|
|
|
+- [ ] 性能影响最小
|
|
|
+- [ ] CI/CD流水线支持新的测试结构
|
|
|
+
|
|
|
+## 风险缓解
|
|
|
+
|
|
|
+- **主要风险**:测试迁移导致测试失败或遗漏
|
|
|
+- **缓解措施**:逐步迁移,保持新旧测试并行运行一段时间
|
|
|
+- **次要风险**:测试工具类依赖关系复杂
|
|
|
+- **缓解措施**:仔细分析依赖,创建适当的共享机制
|
|
|
+- **回滚计划**:恢复原有测试文件,删除packages/server中的测试配置
|
|
|
+
|
|
|
+## 完成定义
|
|
|
+
|
|
|
+- [ ] Story 005.001完成且验收标准满足
|
|
|
+- [ ] 服务层单元测试成功迁移
|
|
|
+- [ ] 工具类单元测试成功迁移
|
|
|
+- [ ] 集成测试评估完成
|
|
|
+- [ ] 测试通过率100%
|
|
|
+- [ ] CI/CD流水线支持新的测试结构
|
|
|
+
|
|
|
+## 验证检查清单
|
|
|
+
|
|
|
+### 范围验证
|
|
|
+- [ ] Epic目标清晰可实现
|
|
|
+- [ ] 故事范围适当
|
|
|
+- [ ] 迁移策略合理
|
|
|
+- [ ] 集成复杂度可控
|
|
|
+
|
|
|
+### 风险评估
|
|
|
+- [ ] 对现有系统风险低
|
|
|
+- [ ] 回滚计划可行
|
|
|
+- [ ] 测试覆盖无遗漏
|
|
|
+- [ ] 团队具备迁移知识
|
|
|
+
|
|
|
+### 完整性检查
|
|
|
+- [ ] Epic目标清晰可实现
|
|
|
+- [ ] 故事范围适当
|
|
|
+- [ ] 成功标准可衡量
|
|
|
+- [ ] 依赖项已识别
|