5.1 KiB
Special Check Family Asset Liability Detail Redesign 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: 本次设计明确“不新增后端字段、不调整控制器、服务和 Mapper 口径”。后端实施只围绕现有 summary + incomeDetail + assetDetail + debtDetail 结构做回归锁定:通过增强服务层和 SQL 结构测试,确认前端改版所需的总额、风险等级和原始条目字段已完整存在;若测试通过,则不修改生产代码。
Tech Stack: Java 21, Spring Boot 3, MyBatis XML, Maven, JUnit 5
File Map
- Modify:
ccdi-project/src/test/java/com/ruoyi/ccdi/project/service/impl/CcdiProjectSpecialCheckServiceImplTest.java- 锁定详情
summary与前端改版所需字段的一致性
- 锁定详情
- Modify:
ccdi-project/src/test/java/com/ruoyi/ccdi/project/mapper/CcdiProjectSpecialCheckMapperDetailSqlTest.java- 锁定明细 SQL 继续返回前端聚合所需原始字段
- Create:
docs/reports/implementation/2026-03-25-special-check-family-asset-liability-detail-redesign-backend-record.md- 记录本次后端为零生产代码改动的边界
- Create:
docs/tests/records/2026-03-25-special-check-family-asset-liability-detail-redesign-backend-verification.md- 记录后端回归验证结果
Task 1: 锁定后端详情契约回归
Files:
-
Modify:
ccdi-project/src/test/java/com/ruoyi/ccdi/project/service/impl/CcdiProjectSpecialCheckServiceImplTest.java -
Modify:
ccdi-project/src/test/java/com/ruoyi/ccdi/project/mapper/CcdiProjectSpecialCheckMapperDetailSqlTest.java -
Step 1: Write the failing test
在现有测试基础上补充以下断言:
-
summary中的totalIncome / totalDebt / totalAsset / riskLevelCode / riskLevelName可直接复用到前端改版 -
SQL 继续返回
asset_main_type / asset_sub_type / current_value -
SQL 继续返回
debt_main_type / debt_sub_type / principal_balance -
不引入新的后端聚合字段,不依赖额外 VO
-
Step 2: Run test to verify it fails
Run:
mvn test -pl ccdi-project -Dtest=CcdiProjectSpecialCheckServiceImplTest,CcdiProjectSpecialCheckMapperDetailSqlTest
Expected:
-
FAIL -
原因是新增回归断言尚未补齐
-
Step 3: Write minimal implementation
只修改测试,不动生产代码:
-
在服务层测试中补充
summary字段复用断言 -
在 Mapper SQL 测试中补充类型字段与金额字段断言
-
明确当前接口足以支撑前端按类型聚合与风险结论展示
-
Step 4: Run test to verify it passes
Run:
mvn test -pl ccdi-project -Dtest=CcdiProjectSpecialCheckServiceImplTest,CcdiProjectSpecialCheckMapperDetailSqlTest
Expected:
-
PASS -
Step 5: Commit
git add ccdi-project/src/test/java/com/ruoyi/ccdi/project/service/impl/CcdiProjectSpecialCheckServiceImplTest.java ccdi-project/src/test/java/com/ruoyi/ccdi/project/mapper/CcdiProjectSpecialCheckMapperDetailSqlTest.java
git commit -m "补充专项核查展开区后端回归测试"
Task 2: 完成后端验证与记录
Files:
-
Create:
docs/reports/implementation/2026-03-25-special-check-family-asset-liability-detail-redesign-backend-record.md -
Create:
docs/tests/records/2026-03-25-special-check-family-asset-liability-detail-redesign-backend-verification.md -
Step 1: Write the failing test
这里不新增代码断言,先整理验证目标:
-
后端生产代码零变更
-
详情契约继续满足前端改版输入要求
-
聚焦专项核查详情相关测试,不扩大到无关模块
-
Step 2: Run test to verify it fails
Run:
mvn test -pl ccdi-project -Dtest=CcdiProjectSpecialCheckServiceImplTest,CcdiProjectSpecialCheckMapperDetailSqlTest,CcdiProjectSpecialCheckControllerTest
Expected:
-
在测试与文档未补齐前,至少一项为
FAIL或文档缺失 -
Step 3: Write minimal implementation
补齐两份文档:
-
后端实施记录写清:
- 本次不修改控制器、服务、Mapper、VO
- 仅增强回归测试,确认接口可继续支撑前端改版
-
后端验证记录写清:
- 运行命令
- 通过结果
- “零生产代码改动”的核对结论
-
Step 4: Run test to verify it passes
Run:
mvn test -pl ccdi-project -Dtest=CcdiProjectSpecialCheckServiceImplTest,CcdiProjectSpecialCheckMapperDetailSqlTest,CcdiProjectSpecialCheckControllerTest
Expected:
-
PASS -
工作区内无
ccdi-project/src/main生产代码改动 -
Step 5: Commit
git add docs/reports/implementation/2026-03-25-special-check-family-asset-liability-detail-redesign-backend-record.md docs/tests/records/2026-03-25-special-check-family-asset-liability-detail-redesign-backend-verification.md
git commit -m "补充专项核查展开区后端验证记录"