2026-04-29-REQ-MOD-002.md
2.95 KB
req_id: REQ-MOD-002 date: 2026-04-29 round: 1
reviewer: superpower-code-reviewer
Review: REQ-MOD-002 — round 1
结论
approve
Must-fix
(无)
Nice-to-have
- backend/src/main/java/com/xly/erp/module/mod/service/impl/ModuleServiceImpl.java:111 — 环检测
depth >= MAX_PARENT_DEPTH守卫位于循环体中段,最大执行 51 次 mapper 调用而非 50(cur.equals(id)判断先于守卫)。建议把守卫挪到 for 条件depth < MAX_PARENT_DEPTH或先判 depth 再判 equals。无功能影响,仅语义更精确。 - backend/src/test/java/com/xly/erp/module/mod/controller/ModuleControllerIT.java:263 —
putWithoutJwt_permitAllStub_returns200_andDoesNotChangeCreatedBy与 MOD-001 同名 POST 用例同样硬绑 stub 行为;建议加 javadoc 锚点// REQ-MOD-001 stub: see USR-004 follow-up,便于 USR-004 上线时一次性 grep 替换为 401 期望。 - backend/src/test/java/com/xly/erp/module/mod/controller/ModuleControllerIT.java:188 — happy-path IT 仅断言
sProcedureName/sCreatedBy保留,未端到端断言tCreateDate/sBrandsId/sSubsidiaryId。Service 单测已 captureArgument 验证这些字段在 entity 上为 null(依赖 NOT_NULL 跳过),如要 IT 双重保险可加列断言。 - backend/src/test/java/com/xly/erp/module/mod/service/ModuleServiceImplTest.java:215 — update 用例直接 stub interface default 方法
existsActiveById/selectParentIdById,与 MOD-001 create 用例 stub 抽象方法findActiveFlagById风格不一致。功能上 Mockito 支持;建议统一风格——推荐 MOD-001 改为 stub 默认方法(更直观)。 - backend/src/main/java/com/xly/erp/module/mod/service/impl/ModuleServiceImpl.java:92 —
moduleMapper.updateById(entity)返回值(受影响行数)被丢弃。@Transactional+ 先做 selectById 校验后并发 DELETE 概率极低,但若命中可能 0 行受影响而方法仍返回成功。可断言 affected==1 否则抛 BizException(40400)。 - backend/src/main/java/com/xly/erp/module/mod/dto/UpdateModuleDTO.java:32 —
iParentId/iSortOrder缺@PositiveOrZero/@Min约束。spec 未要求;负数等异常值需要在 service 层走父链失败才抛 40021。
反例 / 测试覆盖缺口
Spec 验收清单(单元 7 + 集成 7 + 工程 3)端到端实现并 41/41 全绿;分层 / 命名 / 统一响应 / 异常处理 / 事务边界 / 安全 stub 均符合 docs/04 规范。
非阻塞缺口:
-
tCreateDate/sBrandsId/sSubsidiaryId在 IT 端未断言保持原值(service 单测已断言 entity 字段 null + NOT_NULL 策略保证不覆盖)。 - 父模块指向
bDeleted=1旧记录是否回 40021 未单独验证(与 MOD-001 review gap #2 同源)。 -
updateById返回 0 行(并发删除)的场景未覆盖。 - DTO
@Size长度溢出(如 sModuleNameZh > 100)路径未单独 IT。 - 环检测
MAX_PARENT_DEPTH超深路径仅有间接覆盖(脏数据 50 层链未构造测试)。