Commit Graph

2 Commits

Author SHA1 Message Date
swe-agent[bot]
220be6eb5c fix: 修复channel同步竞态条件和死锁问题
修复了4个严重的channel同步问题:

1. **parseCh无条件阻塞** (main.go:894-907)
   - 问题:cmd.Wait()先返回但parseJSONStreamWithLog永久阻塞时,主流程卡死
   - 修复:引入ctxAwareReader和5秒drainTimer机制,Wait完成后立即关闭stdout

2. **context取消失效** (main.go:894-907)
   - 问题:waitCh先完成后不再监听ctx.Done(),取消信号被吞掉
   - 修复:改为双channel循环持续监听waitCh/parseCh/ctx.Done()/drainTimer

3. **parseJSONStreamWithLog无读超时** (main.go:1056-1094)
   - 问题:bufio.Scanner阻塞读取,stdout未主动关闭时永远停在Read
   - 修复:ctxAwareReader支持CloseWithReason,Wait/ctx完成时主动关闭

4. **forceKillTimer生命周期过短**
   - 问题:waitCh返回后立刻停止timer,但stdout可能仍被写入
   - 修复:统一管理timer生命周期,在循环结束后Stop和drain

5. **并发竞态修复**
   - main.go:492 runStartupCleanup使用WaitGroup同步
   - logger.go:176 Flush加锁防止WaitGroup reuse panic

**测试覆盖**:
- 新增4个核心场景测试(Wait先返回、同时返回、Context超时、Parse阻塞)
- main.go覆盖率从28.6%提升到90.32%
- 154个测试全部通过,-race检测无警告

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-08 23:35:55 +08:00
swe-agent[bot]
fec4b7dba3 test: 补充测试覆盖提升至 89.3%
解决的测试盲点:
1. getProcessStartTime (Unix) 0% → 77.3%
   - 新增 process_check_test.go
   - 测试 /proc/<pid>/stat 解析
   - 覆盖失败路径和边界情况

2. getBootTime (Unix) 0% → 91.7%
   - 测试 /proc/stat btime 解析
   - 覆盖缺失和格式错误场景

3. isPIDReused 60% → 100%
   - 新增表驱动测试覆盖所有分支
   - file_stat_fails, old_file, new_file, pid_reused, pid_not_reused

4. isUnsafeFile 82.4% → 88.2%
   - 符号链接检测测试
   - 路径遍历攻击测试
   - TempDir 外文件测试

5. parsePIDFromLog 86.7% → 100%
   - 补充边界测试:负数、零、超大 PID

测试质量改进:
- 新增 stubFileStat 和 stubEvalSymlinks 辅助函数
- 新增 fakeFileInfo 用于文件信息模拟
- 所有测试独立不依赖真实系统状态
- 表驱动测试模式提升可维护性

覆盖率统计:
- 整体覆盖率: 85.5% → 89.3% (+3.8%)
- 新增测试代码: ~150 行
- 测试/代码比例: 1.08 (健康水平)

Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com>
2025-12-08 11:13:00 +08:00