# 项目状态变更日志实施计划 > **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:** 统一在 `CcdiProjectServiceImpl` 中收口项目状态日志。项目创建时记录初始状态日志,后续通过 `updateProjectStatus` 处理的状态变更统一记录“变更前/变更后/操作人”日志,并在状态未变化时避免重复输出。 **Tech Stack:** Java 21、Spring Boot 3、MyBatis Plus、SLF4J/Logback、JUnit 5、Mockito --- ### Task 1: 明确状态变更入口 **Files:** - Modify: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiProjectServiceImpl.java` - Check: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiBankTagServiceImpl.java` - [ ] **Step 1: 盘点项目状态变更入口** 确认项目状态仅在项目创建默认置为“进行中”以及 `updateProjectStatus` 方法中发生持久化变更。 - [ ] **Step 2: 确认日志收口位置** 确保打标流程等调用方继续复用 `updateProjectStatus`,不在调用方分散新增重复日志。 ### Task 2: 先补失败测试 **Files:** - Test: `ccdi-project/src/test/java/com/ruoyi/ccdi/project/service/impl/CcdiProjectServiceImplTest.java` - [ ] **Step 1: 为项目创建补日志测试** 编写测试验证创建项目成功后输出初始状态日志,日志内容包含 `projectId`、`projectName`、状态和值。 - [ ] **Step 2: 为状态切换补日志测试** 编写测试验证 `updateProjectStatus` 在状态真实变化时输出状态变更日志,并包含旧状态、新状态、操作人。 - [ ] **Step 3: 为重复状态写入补日志约束测试** 编写测试验证当目标状态与当前状态一致时,不重复输出状态变更日志。 - [ ] **Step 4: 运行单测确认先失败** Run: `mvn -pl ccdi-project -Dtest=CcdiProjectServiceImplTest test` Expected: 新增日志相关断言失败,证明测试覆盖到新增行为。 ### Task 3: 实现统一日志 **Files:** - Modify: `ccdi-project/src/main/java/com/ruoyi/ccdi/project/service/impl/CcdiProjectServiceImpl.java` - [ ] **Step 1: 为服务类补日志能力** 引入 `@Slf4j` 或等效 Logger,保持与模块现有日志风格一致。 - [ ] **Step 2: 在项目创建后记录初始状态** 在项目持久化成功后输出“项目状态初始化”日志。 - [ ] **Step 3: 在状态变更时记录统一日志** 在 `updateProjectStatus` 中记录“项目状态变更”日志,打印项目标识、项目名称、旧状态、新状态、操作人。 - [ ] **Step 4: 避免无效重复日志** 当旧状态与新状态一致时,不输出状态变更日志,但保留现有更新时间写入行为。 ### Task 4: 补实施记录并验证 **Files:** - Create: `docs/reports/implementation/2026-03-18-项目状态变更日志实施记录.md` - [ ] **Step 1: 记录本次实施内容** 补充实施记录,说明状态日志覆盖范围、代码修改点和测试结果。 - [ ] **Step 2: 运行最终验证** Run: `mvn -pl ccdi-project -Dtest=CcdiProjectServiceImplTest,CcdiBankTagServiceImplTest test` Expected: 相关测试全部通过,确认状态日志不影响现有打标状态流转。