Files
user-system/docs/team/WORKFLOW.md

282 lines
7.1 KiB
Markdown
Raw Normal View History

# 多智能体并行协作工作流
版本1.0
更新时间2026-04-02
本文档描述基于 Gitea 远程仓库的多智能体并行协作工作流。
## 1. 工作流总览
```
需求/问题 → 规划智能体 → 任务拆分 → 方案对比(可选) → 并行实现 → 并行验证 → PR合并 → 文档同步
```
## 2. 角色定义
### 2.1 规划智能体 (Planner)
- **职责**:需求分析、任务拆分、依赖识别、方案对比组织
- **输出**:任务清单、依赖图、方案对比报告(如需要)
- **触发条件**:收到新功能需求或复杂问题
### 2.2 实现智能体 (Implementer)
- **职责**:编码实现、单元测试编写
- **输出**:代码变更、测试用例
- **触发条件**:收到明确的任务描述和验收标准
### 2.3 验证智能体 (Verifier)
- **职责**:执行验证矩阵、生成验证报告
- **输出**:验证报告(通过/失败/阻塞)
- **触发条件**:实现智能体完成编码后
### 2.4 审查智能体 (Reviewer)
- **职责**:代码审查、安全审查、性能审查
- **输出**:审查报告(问题清单+优先级)
- **触发条件**PR 创建后
## 3. 任务拆分规则
### 3.1 拆分原则
- 每个任务必须是独立的、可并行执行的单元
- 任务粒度:每个任务应在 30-120 分钟内可完成
- 前后端分离的任务必须拆分为独立任务
- 数据库变更必须单独作为一个任务
### 3.2 依赖标注
- 任务之间如果有依赖,必须明确标注:
- `依赖: TASK-XXX`
- 执行顺序:`先执行 TASK-XXX再执行 TASK-YYY`
- 无依赖的任务标记为 `独立`
### 3.3 任务模板
```markdown
### TASK-XXX: 任务名称
**优先级**: P0/P1/P2
**工作量**: S(1h)/M(2h)/L(4h)
**依赖**: 无 / TASK-XXX
**负责人**: 实现智能体-A
**任务描述**:
- 要做什么
- 为什么做
**验收标准**:
- [ ] 标准1
- [ ] 标准2
**验证命令**:
- 命令1
- 命令2
```
## 4. 方案对比流程
### 4.1 触发条件
- 新增核心功能
- 架构变更
- 存在多种可行实现路径
- 性能优化涉及重大权衡
### 4.2 对比流程
1. 规划智能体识别需要方案对比的任务
2. 分配 2-3 个智能体并行输出不同方案
3. 每个方案必须包含:
- 实现思路
- 优缺点分析
- 预估工作量
- 风险评估
4. 决策者根据对比维度选择最优方案
5. 记录决策原因和否决原因
### 4.3 对比维度
| 维度 | 说明 |
|------|------|
| 实现复杂度 | 人天/智能体时 |
| 性能影响 | 对现有性能的影响 |
| 可维护性 | 后续维护成本 |
| 架构兼容性 | 与现有架构的匹配度 |
| 测试难度 | 测试覆盖的难易程度 |
## 5. 并行实现模式
### 5.1 无依赖并行
```
TASK-A (前端) ──┐
├── 并行执行
TASK-B (后端) ──┘
```
### 5.2 有依赖串行
```
TASK-A (后端API) ──→ TASK-B (前端对接)
```
### 5.3 混合模式
```
TASK-A (数据模型) ──┬─→ TASK-B (后端Service) ──┐
│ ├── TASK-E (集成测试)
└─→ TASK-C (前端页面) ──────┘
TASK-D (独立任务) ──┘
```
## 6. 冲突解决机制
### 6.1 文件冲突预防
- 任务拆分阶段识别可能被多个任务修改的文件
- 协调修改顺序或分配不同的修改区域
- 共享文件(如路由配置、类型定义)由单一智能体统一修改
### 6.2 合并冲突处理
- 优先保留功能完整的版本
- 手动合并差异,不自动解决
- 合并后必须重新运行验证矩阵
## 7. 验证策略
### 7.1 本地验证(实现智能体)
- 每次提交前运行受影响的最小测试集
- 确保代码可编译、lint 通过
### 7.2 并行验证(验证智能体)
- 后端测试、前端 lint/build、E2E 测试并行执行
- 生成统一的验证报告
### 7.3 PR 验证(审查智能体)
- 代码审查
- 安全审查
- 性能审查
- 生成审查报告
## 7. E2E 测试流程
### 7.1 E2E 测试架构
- **Playwright CDP E2E**(主验收路径):
- 命令:`cd frontend/admin && npm.cmd run e2e:full:win`
- 协议Playwright 通过 CDP 连接真实浏览器
- 数据库:隔离测试数据库(临时 SQLite 文件)
- 邮件:本地 SMTP 捕获服务(验证邮件发送)
- 信号收集console errors、dialogs、popups、request failures、401 responses
- 多视口desktop 1440x960、tablet 820x1180、mobile 390x844
- **覆盖场景**
- 管理员引导admin-bootstrap
- 公开注册public-registration
- 邮箱激活email-activation
- 登录表面验证login-surface
- 认证工作流auth-workflow
- 响应式登录responsive-login
- 桌面/移动端导航desktop-mobile-navigation
### 7.2 E2E 测试规则
- 必须启动真实后端进程(隔离测试数据库)
- 必须启动真实前端开发服务器
- 必须通过真实浏览器CDP 协议)执行用户操作
- 必须验证真实 API 响应(非 mock
- 必须验证真实数据库状态变化
- 禁止使用 mock 响应替代真实 API 调用
- 禁止在测试中硬编码预期结果而不走真实业务链路
- 禁止跳过认证、权限校验等安全环节直接断言页面状态
### 7.3 未来 E2E 增强方向
- 引入 `agent-browser`bb browse等浏览器自动化工具
- 补充 Playwright 未覆盖的交互场景:
- 设备信任管理
- 批量操作
- 系统设置页
- 管理员管理页
- 登录日志导出
- 增加复杂业务流程的端到端验证
## 8. 文档同步规则
### 8.1 必须更新的文档
| 变更类型 | 必须更新的文档 |
|----------|----------------|
| 功能变更 | `docs/status/REAL_PROJECT_STATUS.md` |
| API 变更 | `docs/API.md` |
| 规则变更 | `docs/team/QUALITY_STANDARD.md` |
| 经验沉淀 | `docs/team/PROJECT_EXPERIENCE_SUMMARY.md` |
| 架构决策 | `docs/decisions/` |
### 8.2 文档更新时机
- 代码合并后立即更新相关文档
- 文档更新作为 PR 的一部分
## 9. 迭代节奏
### 9.1 迭代周期
- 每个迭代周期不超过 2 小时
- 小步快跑,持续验证
### 9.2 迭代流程
1. **规划阶段**10-15 分钟)
- 任务拆分
- 依赖分析
- 智能体分配
2. **实现阶段**60-90 分钟)
- 并行编码
- 本地验证
3. **验证阶段**15-30 分钟)
- 并行验证
- 代码审查
- PR 合并
4. **总结阶段**5-10 分钟)
- 文档同步
- 经验沉淀
## 10. 阻塞处理
### 10.1 阻塞识别
- 智能体无法继续执行任务
- 验证持续失败
- 依赖任务未完成
### 10.2 阻塞处理流程
1. 记录阻塞原因和影响范围
2. 寻找替代方案
3. 阻塞超过 30 分钟上报
4. 调整任务优先级或拆分方式
## 11. 知识沉淀
### 11.1 必须记录的内容
- 解决方案(每次解决的问题)
- 避免方法(每次踩过的坑)
- 验证结果(每次验证通过的命令)
### 11.2 沉淀位置
- 短期经验:`docs/sprints/`
- 长期经验:`docs/team/PROJECT_EXPERIENCE_SUMMARY.md`
- 架构决策:`docs/decisions/`