2026-03-24 12:20:58 +08:00
# Project List Reanalyze Backend Implementation Plan
> **For agentic workers:** REQUIRED: Use superpowers:subagent-driven-development (if subagents available) or superpowers:executing-plans to implement this plan. Steps use checkbox (`- [ ]`) syntax for tracking.
**Goal:** 确认并验证项目管理列表“重新分析”复用现有项目级重打标链路即可满足“重新打标并重新计算人数”的后端要求,不新增额外接口或并行逻辑。
**Architecture:** 后端实现保持不改代码的最短路径,继续复用 `CcdiBankTagController -> ProjectBankTagRebuildCoordinator -> CcdiBankTagServiceImpl -> CcdiProjectOverviewServiceImpl` 这条现有链路。实施工作集中在边界核验、接口契约回归、关键测试运行和实施记录沉淀,确保前端接入后不会因为后端口径不清而额外返工。
**Tech Stack:** Java 21, Spring Boot 3, JUnit 5, Mockito, Maven
2026-03-24 12:24:52 +08:00
## 后端验收清单
- `POST /ccdi/project/tags/rebuild` 支持只传 `projectId`
- 手动提交后项目状态会切换为 `3-打标中`
- 打标成功后会调用 `refreshOverviewEmployeeResults(projectId, operator)`
- `refreshOverviewEmployeeResults(projectId, operator)` 会同步刷新高/中/低风险人数
## 最小化实现结论
- 本次后端不新增接口
- 本次后端不新增服务分支
- 本次后端不新增人数重算调用
2026-03-24 12:20:58 +08:00
---
### Task 1: 核验现有后端链路已覆盖需求
**Files:**
- Modify: `docs/plans/backend/2026-03-24-project-list-reanalyze-backend-implementation.md`
- Reference: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/controller/CcdiBankTagController.java`
- Reference: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/ProjectBankTagRebuildCoordinator.java`
- Reference: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiBankTagServiceImpl.java`
- Reference: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiProjectOverviewServiceImpl.java`
- [ ] **Step 1: Write the acceptance checklist **
先在计划中明确本次后端必须被验证的四个事实:
- `POST /ccdi/project/tags/rebuild` 支持只传 `projectId`
- 手动提交后项目状态会切换为 `3-打标中`
- 打标成功后会调用 `refreshOverviewEmployeeResults(projectId, operator)`
- `refreshOverviewEmployeeResults(...)` 会同步刷新高/中/低风险人数
- [ ] **Step 2: Run repository grep to verify the call chain **
Run:
```bash
rg -n "refreshOverviewEmployeeResults|submitManual|/rebuild|updateProjectStatus\\(projectId, CcdiProjectStatusConstants.TAGGING" ccdi-project/src/main/java -S
```
Expected:
- 能同时看到控制器入口、协调器提交流程、`TAGGING` 状态切换和人数重算调用
- [ ] **Step 3: Keep implementation minimal **
如果上述四个事实都成立,则明确记录:
- 本次后端不新增接口
- 本次后端不新增服务分支
- 本次后端不新增人数重算调用
- [ ] **Step 4: Commit **
```bash
git add docs/plans/backend/2026-03-24-project-list-reanalyze-backend-implementation.md
git commit -m "补充项目列表重新分析后端实施计划"
```
### Task 2: 运行关键后端测试锁定现有契约
**Files:**
- Test: `ccdi-project/src/test/java/com/ruoyi/ccdi/project/controller/CcdiBankTagControllerTest.java`
- Test: `ccdi-project/src/test/java/com/ruoyi/ccdi/project/service/impl/ProjectBankTagRebuildCoordinatorTest.java`
- Test: `ccdi-project/src/test/java/com/ruoyi/ccdi/project/service/impl/CcdiBankTagServiceRiskCountRefreshTest.java`
- [ ] **Step 1: Run controller and coordinator contract tests **
Run:
```bash
mvn -pl ccdi-project -Dtest=CcdiBankTagControllerTest,ProjectBankTagRebuildCoordinatorTest test
```
Expected:
- `PASS`
- 能证明手动重打标入口、运行中防重提交流程和归档保护逻辑都已存在
- [ ] **Step 2: Run risk count refresh test **
Run:
```bash
mvn -pl ccdi-project -Dtest=CcdiBankTagServiceRiskCountRefreshTest test
```
Expected:
- `PASS`
- 能证明重打标成功后会刷新员工结果并同步更新项目风险人数
- [ ] **Step 3: If any test fails, inspect before changing code **
若失败,先检查是否为环境或依赖问题,再决定是否需要补充代码;本次默认目标是不产生新的后端代码改动。
- [ ] **Step 4: Commit **
```bash
git status --short
```
Expected:
- 若仅运行测试无文件变化,则本任务无需代码提交
### Task 3: 补充后端验证记录与边界说明
**Files:**
- Create: `docs/tests/records/2026-03-24-project-list-reanalyze-backend-verification.md`
- Create: `docs/reports/implementation/2026-03-24-project-list-reanalyze-backend-record.md`
- [ ] **Step 1: Write verification skeleton **
创建后端验证记录,至少包含:
```markdown
# 项目管理列表重新分析后端验证记录
## 验证范围
- 手动重打标接口可直接复用于列表页
- 重打标开始后项目进入打标中
- 重打标成功后自动重算项目风险人数
- 运行中任务和归档项目保留既有后端保护
```
- [ ] **Step 2: Record exact commands and results **
把实际执行的测试命令和结果写入验证记录:
```bash
mvn -pl ccdi-project -Dtest=CcdiBankTagControllerTest,ProjectBankTagRebuildCoordinatorTest,CcdiBankTagServiceRiskCountRefreshTest test
```
Expected:
- 记录通过或失败原因
- [ ] **Step 3: Write the implementation record **
在 `docs/reports/implementation/2026-03-24-project-list-reanalyze-backend-record.md` 中写明:
- 为什么本次后端不需要改代码
- 现有复用链路覆盖了哪些需求
- 已验证的保护场景有哪些
- 后续仅由前端接线即可进入实现阶段
- [ ] **Step 4: Commit **
```bash
git add docs/tests/records/2026-03-24-project-list-reanalyze-backend-verification.md docs/reports/implementation/2026-03-24-project-list-reanalyze-backend-record.md
git commit -m "补充项目列表重新分析后端验证记录"
```