# PLAN.md — recordingtest > 다음에 할 일의 *우선순위 큐*. 에이전트는 상단부터 집어든다. > 비자명한 항목은 `/contract ` → `docs/contracts/.md` 로 Sprint Contract 먼저 작성. ## P0 — 지금 바로 1. **훅 동작 검증** — SessionStart/Stop/Guard 3개 shell 스크립트를 실제로 트리거시켜 확인 - 의존: jq 설치 여부 확인 ## P0.5 — 아키텍처 정렬 3a. **3-tier 분리 refactor 2단계** (`docs/contracts/generic-sut-split.md`) — 1단계(신규 모듈 신설)는 commit `pending`로 완료. 2단계는 기존 `EgPlugin`/`EngineBridge`/`EngineBridge.Client` **rename + 폴더 이동** + ArchitectureTests. 단일 BREAKING 커밋. CLAUDE.md §8.1 규칙 준수. ## P1 — 라이브 검증 (사용자 환경 필요) 4. **engine-bridge v3 라이브 검증** — `HmegDirectStateProvider` wire-up 완료. EgBim adapter의 Space/Viewport 람다를 실값으로 매핑 (`Editor03.PluginInterface` 또는 SUT-side AppManager 진입점 필요 — Q1~Q7). 라이브에서 `curl /scene /camera /selection` 으로 확인. 5. ~~recorder Gap I-1~~ — **deferred**. UIA poller PoC 결과 본질적 한계 확인 (AutomationPeer 부재 컨트롤은 못 봄). generic WPF DLL injection 또는 AutomationPeer AI 부착 PoC가 선결. ## Follow-ups (non-blocking) - **sut-prober snake_case JSON** — `JsonNamingPolicy.SnakeCaseLower` 적용. Evaluator가 pass 처리했지만 contract 엄격 준수를 위해 권장. ## P2 — 통합 7. **test-runner** — 시나리오 일괄 실행 + 실패 triage - 의존: recorder + player + normalizer + diff-reporter 전부 8. **engine-bridge 탐색** — HmEG PDB 리플렉션으로 카메라/선택 상태 접근 가능 여부 확인 - Sprint Contract 필요 9. **AutomationPeer PR 전략 PoC** — SUT fork에 AI로 AutomationPeer 자동 부착 샘플 ## P3 — 상시 - **Scaffolding review** (PoC 3개마다) - **.claude/ 비계 감사** — 기사 원칙: 불필요한 비계 제거 - **history 파일 누락 체크** — Stop hook이 경고 ## 규칙 - 항목을 집을 때 PROGRESS.md의 "In progress"에 기록하고 본인(에이전트명/세션) 명시. - 비자명한 P0/P1/P2 항목은 반드시 Sprint Contract 먼저. - Generator와 Evaluator는 같은 세션이 겸하지 않는다. - 완료 시: evaluator pass → PROGRESS.md Done 이동 → PLAN.md 제거 → history 작성 → `/handoff`.