Files
ccdi/docs/plans/backend/2026-03-24-project-list-reanalyze-backend-implementation.md

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 "补充项目列表重新分析后端验证记录"