Files
ccdi/docs/plans/2026-03-13-employee-family-asset-import-split-backend-implementation.md

10 KiB
Raw Blame History

员工资产导入与亲属资产导入拆分后端实施计划

For Claude: REQUIRED SUB-SKILL: Use superpowers:executing-plans to implement this plan task-by-task.

Goal: 将员工资产导入与亲属资产导入拆成两套独立后端接口与服务,确保员工页仅导入本人资产、亲属页仅导入亲属资产。

Architecture: 保留现有亲属资产导入控制器与服务作为“亲属专用导入链路”新增一套员工资产专用导入控制器、Excel 模型、失败记录 VO 与异步导入服务。两套链路分别使用不同权限、模板和归属匹配规则,不再共享“本人/亲属兜底识别”逻辑。

Tech Stack: Java 21, Spring Boot 3, MyBatis Plus, Redis, EasyExcel, JUnit 5, Mockito


Task 1: 固化拆分后的导入规则测试

Files:

  • Modify: ccdi-info-collection/src/test/java/com/ruoyi/info/collection/service/CcdiAssetInfoImportServiceImplTest.java
  • Create: ccdi-info-collection/src/test/java/com/ruoyi/info/collection/service/CcdiBaseStaffAssetImportServiceImplTest.java
  • Modify: ccdi-info-collection/src/test/java/com/ruoyi/info/collection/controller/CcdiAssetInfoControllerTest.java
  • Create: ccdi-info-collection/src/test/java/com/ruoyi/info/collection/controller/CcdiBaseStaffAssetImportControllerTest.java

Step 1: 写亲属资产导入失败测试

  • CcdiAssetInfoImportServiceImplTest 增加用例:
    • 员工本人身份证号导入时失败
    • 失败文案为亲属资产专用文案
  • CcdiAssetInfoControllerTest 校验模板标题为“亲属资产信息”

Step 2: 运行测试确认当前失败

Run:

mvn test -pl ccdi-info-collection -am "-Dtest=CcdiAssetInfoImportServiceImplTest,CcdiAssetInfoControllerTest" "-Dsurefire.failIfNoSpecifiedTests=false"

Expected:

  • 新增断言失败
  • 失败原因是当前实现仍允许员工本人资产命中

Step 3: 写员工资产导入测试

  • 新增 CcdiBaseStaffAssetImportServiceImplTest
  • 覆盖以下场景:
    • 员工本人身份证号导入成功
    • 亲属证件号导入失败
    • Redis key 使用员工资产独立前缀
  • 新增 CcdiBaseStaffAssetImportControllerTest
  • 覆盖模板标题、任务创建、状态与失败记录查询

Step 4: 再次运行测试确认失败点准确

Run:

mvn test -pl ccdi-info-collection -am "-Dtest=CcdiBaseStaffAssetImportServiceImplTest,CcdiBaseStaffAssetImportControllerTest" "-Dsurefire.failIfNoSpecifiedTests=false"

Expected:

  • 因类与实现尚不存在而失败

Step 5: 提交测试脚手架

git add ccdi-info-collection/src/test/java/com/ruoyi/info/collection/service/CcdiAssetInfoImportServiceImplTest.java ccdi-info-collection/src/test/java/com/ruoyi/info/collection/service/CcdiBaseStaffAssetImportServiceImplTest.java ccdi-info-collection/src/test/java/com/ruoyi/info/collection/controller/CcdiAssetInfoControllerTest.java ccdi-info-collection/src/test/java/com/ruoyi/info/collection/controller/CcdiBaseStaffAssetImportControllerTest.java
git commit -m "补充资产导入拆分后端失败测试"

Task 2: 收敛亲属资产导入为亲属专用链路

Files:

  • Modify: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/controller/CcdiAssetInfoController.java
  • Modify: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/impl/CcdiAssetInfoImportServiceImpl.java
  • Modify: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/excel/CcdiAssetInfoExcel.java
  • Modify: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/vo/AssetImportFailureVO.java
  • Modify: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/mapper/CcdiAssetInfoMapper.java
  • Modify: ccdi-info-collection/src/main/resources/mapper/info/collection/CcdiAssetInfoMapper.xml

Step 1: 最小实现修改

  • CcdiAssetInfoImportServiceImpl 的归属匹配改为只调用 selectOwnerCandidatesByRelationCertNos
  • 删除员工本人兜底逻辑
  • 恢复亲属资产专用错误文案
  • 将 Excel 首列表头改为“亲属证件号*”
  • 将 controller 标题、swagger 文案、日志标题改回亲属资产专用表述
  • 权限仅保留 ccdi:staffFmyRelation:import

Step 2: 运行亲属资产相关测试

Run:

mvn test -pl ccdi-info-collection -am "-Dtest=CcdiAssetInfoImportServiceImplTest,CcdiAssetInfoControllerTest" "-Dsurefire.failIfNoSpecifiedTests=false"

Expected:

  • 亲属资产测试全部通过

Step 3: 检查无多余员工导入逻辑残留

Run:

git grep -n "selectOwnerCandidatesByPersonIds|hasAnyPermi('ccdi:employee:import" -- "ccdi-info-collection/src/main/java/**/*.java" "ccdi-info-collection/src/main/resources/**/*.xml"

Expected:

  • CcdiAssetInfo* 相关文件不再包含员工资产导入特有逻辑

Step 4: 提交

git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/controller/CcdiAssetInfoController.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/impl/CcdiAssetInfoImportServiceImpl.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/excel/CcdiAssetInfoExcel.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/vo/AssetImportFailureVO.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/mapper/CcdiAssetInfoMapper.java ccdi-info-collection/src/main/resources/mapper/info/collection/CcdiAssetInfoMapper.xml
git commit -m "收敛亲属资产导入为亲属专用逻辑"

Task 3: 新增员工资产导入后端接口与模型

Files:

  • Create: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/controller/CcdiBaseStaffAssetImportController.java
  • Create: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/ICcdiBaseStaffAssetImportService.java
  • Create: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/impl/CcdiBaseStaffAssetImportServiceImpl.java
  • Create: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/excel/CcdiBaseStaffAssetInfoExcel.java
  • Create: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/vo/BaseStaffAssetImportFailureVO.java

Step 1: 写最小接口定义

  • 定义员工资产导入 service 接口:
    • importAssetInfo
    • importAssetInfoAsync
    • getImportStatus
    • getImportFailures

Step 2: 写 controller 最小实现

  • 提供以下接口:
    • POST /ccdi/baseStaff/asset/importTemplate
    • POST /ccdi/baseStaff/asset/importData
    • GET /ccdi/baseStaff/asset/importStatus/{taskId}
    • GET /ccdi/baseStaff/asset/importFailures/{taskId}
  • 权限使用 ccdi:employee:import

Step 3: 写 Excel 与失败记录模型

  • CcdiBaseStaffAssetInfoExcel 首列使用“员工身份证号*”
  • BaseStaffAssetImportFailureVO 字段与员工资产模板保持一致

Step 4: 运行员工资产 controller 测试

Run:

mvn test -pl ccdi-info-collection -am "-Dtest=CcdiBaseStaffAssetImportControllerTest" "-Dsurefire.failIfNoSpecifiedTests=false"

Expected:

  • controller 测试通过

Step 5: 提交

git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/controller/CcdiBaseStaffAssetImportController.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/ICcdiBaseStaffAssetImportService.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/impl/CcdiBaseStaffAssetImportServiceImpl.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/excel/CcdiBaseStaffAssetInfoExcel.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/domain/vo/BaseStaffAssetImportFailureVO.java
git commit -m "新增员工资产导入后端接口"

Task 4: 实现员工资产归属匹配与异步导入

Files:

  • Modify: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/impl/CcdiBaseStaffAssetImportServiceImpl.java
  • Modify: ccdi-info-collection/src/main/java/com/ruoyi/info/collection/mapper/CcdiAssetInfoMapper.java
  • Modify: ccdi-info-collection/src/main/resources/mapper/info/collection/CcdiAssetInfoMapper.xml

Step 1: 写最小匹配实现

  • 在 mapper 中新增 selectOwnerCandidatesByBaseStaffIdCards
  • SQL 只查询 ccdi_base_staff.id_card
  • service 只按员工身份证号匹配
  • 不查亲属关系表

Step 2: 写导入成功逻辑

  • 复制 Excel 到 CcdiAssetInfo
  • 强制 familyId = personId = 员工身份证号
  • 使用独立 Redis 前缀,例如 import:baseStaffAsset:

Step 3: 写失败逻辑

  • 未命中员工表时报错
  • 失败文案使用员工资产专用文案

Step 4: 运行员工资产 service 测试

Run:

mvn test -pl ccdi-info-collection -am "-Dtest=CcdiBaseStaffAssetImportServiceImplTest" "-Dsurefire.failIfNoSpecifiedTests=false"

Expected:

  • 员工资产 service 测试通过

Step 5: 提交

git add ccdi-info-collection/src/main/java/com/ruoyi/info/collection/service/impl/CcdiBaseStaffAssetImportServiceImpl.java ccdi-info-collection/src/main/java/com/ruoyi/info/collection/mapper/CcdiAssetInfoMapper.java ccdi-info-collection/src/main/resources/mapper/info/collection/CcdiAssetInfoMapper.xml
git commit -m "实现员工资产导入归属匹配"

Task 5: 执行回归验证

Files:

  • Modify: docs/plans/2026-03-13-employee-family-asset-import-split-design.md

Step 1: 运行后端定向测试

Run:

mvn test -pl ccdi-info-collection -am "-Dtest=CcdiAssetInfoImportServiceImplTest,CcdiAssetInfoControllerTest,CcdiBaseStaffAssetImportServiceImplTest,CcdiBaseStaffAssetImportControllerTest" "-Dsurefire.failIfNoSpecifiedTests=false"

Expected:

  • 相关测试全部通过

Step 2: 做源码断言检查

Run:

git grep -n "/ccdi/baseStaff/asset|/ccdi/assetInfo" -- "ccdi-info-collection/src/main/java/**/*.java"

Expected:

  • 员工与亲属两套接口都存在
  • 路由职责清晰

Step 3: 更新设计文档的实现状态说明

  • 在设计文档末尾补充“已完成实现验证”的简短说明

Step 4: 提交

git add docs/plans/2026-03-13-employee-family-asset-import-split-design.md
git commit -m "完成资产导入拆分后端验证"