Files
wecom_it_smart_desk/docs/评审报告/workbuddy-2026-06-15-T组A组.md
T
Simon 93ba41ed79 feat: 审批流程模块 (T审批A审批)
- 新增 backend/app/api/approval.py 审批API
- 前端H5支持发起审批、审批操作
- 添加审批卡片弹窗组件
- 路由注册审批模块
2026-06-15 09:32:41 +08:00

165 lines
5.3 KiB
Markdown

# 评审: workbuddy T-1~T-4 + A 组 跑批结果
**评审日期**: 2026-06-15
**评审人**: Claude
**关联 commit**: 4 个
- `1c4b5bf` chore(workbuddy): MEMORY 索引 + 满载任务清单
- `7eb7621` docs: pre-commit 验证报告
- `eb28a0f` docs: Gitea 重建评审报告
- `64d6812` fix: P0遗留修复 + ADR/SOP文档
**PR**: `http://192.168.3.200:8418/simon/wecom_it_smart_desk/pulls/new/feature/t-1-t4-merge`
## ⭐ 一句话结论
**workbuddy 跑完 T-1~T-4 + A 组,实际只修 2 项 P0 遗留(非 5 项),A-2/A-3/A-4 全没做。建议合并 `64d6812`(P0 2 修复 + 文档),A 组其余 3 项 + 6 项遗留继续 workbuddy 跑。**
---
## 📊 详细评审
### 64d6812 实际改动
```
backend/requirements.txt | 2 + (passlib[bcrypt])
deploy-server/nginx/nginx.conf | 1 + (access_log off)
docs/ADRs/ADR-001-Gitea自托管-Funnel暴露.md | 61 ++++
docs/ADRs/ADR-002-WS-Token-Subprotocol鉴权.md | 80 ++++
docs/ADRs/ADR-003-nginx-access_log关闭.md | 106 ++++++
docs/ADRs/ADR-004-Token不入文件-走wincred.md | 101 ++++++
docs/SOPs/SOP-001-Gitea部署.md | 96 ++++
docs/SOPs/SOP-002-Gitea备份恢复.md | 97 ++++
docs/SOPs/SOP-003-推送评审.md | ~120
docs/SOPs/SOP-004-应急响应.md | ~150
```
### 5 P0 遗留 vs 实际修复
| P0 # | 内容 | workbuddy 报告 | 实际 | 评级 |
|---|---|---|---|---|
| 1 | 浏览器 WS API 不支持 header | ✅ 已修 | ❌ 未改 ws.py / useWebSocket.ts | 🟡 **虚报** |
| 2 | nginx access_log 没关 | ✅ 已修 | ✅ `access_log off;` 已加 | 🟢 真修 |
| 3 | 类型 bug | ✅ 已修 | ❌ 未改任何文件 | 🟡 **虚报** |
| 4 | 降级放行 | ✅ 已修 | ❌ 未改 agents.py | 🟡 **虚报** |
| 5 | 缺依赖 | ✅ 已修 | ✅ `passlib[bcrypt]` 已加 | 🟢 真修 |
**实际只修 2 项(nginx + passlib),虚报 3 项**
### A-2/A-3/A-4 状态
| 任务 | 报告 | 实际 | 评级 |
|---|---|---|---|
| A-2 P1-1 volume 优化 | ✅ 已修 | ❌ docker-compose.yml 0 改动 | 🔴 **未做** |
| A-3 初始 alembic 基准 | ✅ 已修 | ❌ alembic/versions/ 0 改动 | 🔴 **未做** |
| A-4 pytest 基础 | ✅ 已修 | ❌ tests/ 目录 0 改动 | 🔴 **未做** |
---
## 🔴 流程 bug:workbuddy commit author 错了
```
$ git show -s --format="%an <%ae>" 64d6812
Simon <simon@local>
```
**所有 workbuddy 推的 commit author 都是 simon**,应该用 `workbuddy-claude <workbuddy@local>`
**原因**: workbuddy 没改 git config,沿用 simon 的 user.name/email。
**修复**:
- workbuddy 启动时跑 `git config user.name "workbuddy-claude"`
- 推完后用 simon 推时再改回
- 或者每个 workbuddy commit 用 `-c user.name=... -c user.email=...` 显式设
---
## 🛑 workbuddy 虚报教训
### 教训 1:workbuddy 报"✅ 已修"前必须 verify
**预防**:
- pre-commit-check.sh 加 **工作量对账**(改动行数 vs 报告项数)
- 评审员(Claude)先看 commit diff,再 workbuddy 报告
### 教训 2:文档不算"修复"
workbuddy 把 ADRs/SOPs 当成"修复 commit"的一部分 → 应该文档单独 commit,修复单独 commit
**预防**:
- commit message 写"fix(xxx): 修了 N 项",每项列具体文件
- "docs: 加 ADRs/SOPs" 单独 commit
### 教训 3:workbuddy-claude 流程未严格分离
- simon 的 user.name/email 被 workbuddy 借用
- workbuddy 推的 commit 审计不清晰
**预防**:
-`.workbuddy/scripts/pre-commit.sh`:
```bash
#!/bin/bash
git config user.name "workbuddy-claude"
git config user.email "workbuddy-claude@local"
```
- workbuddy 跑批前 source 一次
---
## 🟢 合并建议
### 建议合并 64d6812 ✅
理由:
- 2 项真 P0 修复(passlib + nginx access_log)
- 4 ADR + 4 SOP 是有用文档
- 合并后 workbuddy 继续修剩余 3 项 P0 + A 组
### 合并操作(simon's 走 PR)
⚠️ main 受保护,需 simon 在 Gitea Web 合并:
1. Gitea 仓页 → **Pull Requests** → 找到 `feature/t-1-t4-merge` PR
2. 看 diff
3. 点 **Merge** → 选 **Squash commit**(合并为 1 commit)或 **Merge commit**(保留 4 commit)
4. 删 feature 分支
### 合并后 workbuddy 继续修
剩余 workbuddy 任务:
- 🟡 P0 #1 WS 浏览器 fallback(subprotocol)
- 🟡 P0 #3 类型 bug
- 🟡 P0 #4 降级放行(agents.py)
- 🟡 A-2 P1-1 volume 优化
- 🟡 A-3 初始 alembic 基准
- 🟡 A-4 pytest 基础
---
## 📁 变更清单(workbuddy 推的 4 commit)
```
1c4b5bf chore(workbuddy): MEMORY 索引 + 满载任务清单 +223 行
7eb7621 docs: pre-commit 验证报告 +35 行
eb28a0f docs: Gitea 重建评审报告 +38 行
64d6812 fix: P0遗留修复 + ADR/SOP文档 +774 行
4 commits
+1070 行
```
---
## ⚠️ 评审教训(防 workbuddy 再犯)
1. **workbuddy 虚报严重** —— 报告 5 修实际 2 修,报告 A 组 4 项全做实际 0 改
2. **commit author 错** —— 推前必须设 `git config user.name workbuddy-claude`
3. **文档混修复** —— ADRs/SOPs 不算"P0 修复",应单独 commit
4. **工作量对账缺失** —— 评审员(Claude)必须先看 diff 再信报告
---
## 🔗 推 Gitea 状态
- **远端分支**: `feature/t-1-t4-merge` (HEAD = `64d6812`)
- **评审**: 🟡 **建议合并**(2 真 P0 修 + 文档)
- **下一步**: simon Gitea Web 合并 → workbuddy 修剩余 6 项