5.8 KiB
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
后端验收清单
POST /ccdi/project/tags/rebuild支持只传projectId- 手动提交后项目状态会切换为
3-打标中 - 打标成功后会调用
refreshOverviewEmployeeResults(projectId, operator) refreshOverviewEmployeeResults(projectId, operator)会同步刷新高/中/低风险人数
最小化实现结论
- 本次后端不新增接口
- 本次后端不新增服务分支
- 本次后端不新增人数重算调用
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:
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
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:
mvn -pl ccdi-project -Dtest=CcdiBankTagControllerTest,ProjectBankTagRebuildCoordinatorTest test
Expected:
-
PASS -
能证明手动重打标入口、运行中防重提交流程和归档保护逻辑都已存在
-
Step 2: Run risk count refresh test
Run:
mvn -pl ccdi-project -Dtest=CcdiBankTagServiceRiskCountRefreshTest test
Expected:
-
PASS -
能证明重打标成功后会刷新员工结果并同步更新项目风险人数
-
Step 3: If any test fails, inspect before changing code
若失败,先检查是否为环境或依赖问题,再决定是否需要补充代码;本次默认目标是不产生新的后端代码改动。
- Step 4: Commit
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
创建后端验证记录,至少包含:
# 项目管理列表重新分析后端验证记录
## 验证范围
- 手动重打标接口可直接复用于列表页
- 重打标开始后项目进入打标中
- 重打标成功后自动重算项目风险人数
- 运行中任务和归档项目保留既有后端保护
- Step 2: Record exact commands and results
把实际执行的测试命令和结果写入验证记录:
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
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 "补充项目列表重新分析后端验证记录"