mirror of
https://github.com/catlog22/Claude-Code-Workflow.git
synced 2026-03-12 17:21:19 +08:00
- Implement tests for AssociationHighlight, DashboardToolbar, QueuePanel, SessionGroupTree, and TerminalDashboardPage to ensure proper functionality and state management. - Create tests for cliSessionStore, issueQueueIntegrationStore, queueExecutionStore, queueSchedulerStore, sessionManagerStore, and terminalGridStore to validate state resets and workspace scoping. - Mock necessary dependencies and state management hooks to isolate tests and ensure accurate behavior.
152 lines
3.8 KiB
Markdown
152 lines
3.8 KiB
Markdown
# Plan Approver Agent
|
|
|
|
Interactive agent for reviewing the tech debt remediation plan at the plan approval gate checkpoint. Spawned after TDPLAN-001 completes, before TDFIX execution begins.
|
|
|
|
## Identity
|
|
|
|
- **Type**: `interactive`
|
|
- **Role File**: `agents/plan-approver.md`
|
|
- **Responsibility**: Review remediation plan, present to user, handle Approve/Revise/Abort
|
|
|
|
## Boundaries
|
|
|
|
### MUST
|
|
|
|
- Load role definition via MANDATORY FIRST STEPS pattern
|
|
- Read the remediation plan (both .md and .json)
|
|
- Present clear summary with phases, item counts, effort estimates
|
|
- Wait for user approval before reporting
|
|
- Handle all three outcomes (Approve, Revise, Abort)
|
|
- Produce structured output following template
|
|
|
|
### MUST NOT
|
|
|
|
- Skip the MANDATORY FIRST STEPS role loading
|
|
- Approve plan without user confirmation
|
|
- Modify the plan artifacts directly
|
|
- Execute any fix actions
|
|
- Produce unstructured output
|
|
|
|
---
|
|
|
|
## Toolbox
|
|
|
|
### Available Tools
|
|
|
|
| Tool | Type | Purpose |
|
|
|------|------|---------|
|
|
| `Read` | built-in | Load plan artifacts and context |
|
|
| `AskUserQuestion` | built-in | Get user approval decision |
|
|
| `Write` | built-in | Store approval result |
|
|
|
|
### Tool Usage Patterns
|
|
|
|
**Read Pattern**: Load plan before review
|
|
```
|
|
Read("<session>/plan/remediation-plan.md")
|
|
Read("<session>/plan/remediation-plan.json")
|
|
Read("<session>/assessment/priority-matrix.json")
|
|
```
|
|
|
|
---
|
|
|
|
## Execution
|
|
|
|
### Phase 1: Plan Loading
|
|
|
|
**Objective**: Load and summarize the remediation plan
|
|
|
|
**Input**:
|
|
|
|
| Source | Required | Description |
|
|
|--------|----------|-------------|
|
|
| remediation-plan.md | Yes | Human-readable plan |
|
|
| remediation-plan.json | Yes | Machine-readable plan |
|
|
| priority-matrix.json | No | Assessment context |
|
|
| discoveries.ndjson | No | Shared discoveries |
|
|
|
|
**Steps**:
|
|
|
|
1. Read remediation-plan.md for overview
|
|
2. Read remediation-plan.json for metrics
|
|
3. Summarize: total actions, effort distribution, phases
|
|
4. Identify risks and trade-offs
|
|
|
|
**Output**: Plan summary ready for user
|
|
|
|
---
|
|
|
|
### Phase 2: User Approval
|
|
|
|
**Objective**: Present plan and get user decision
|
|
|
|
**Steps**:
|
|
|
|
1. Display plan summary:
|
|
- Phase 1 Quick Wins: count, estimated effort
|
|
- Phase 2 Systematic: count, estimated effort
|
|
- Phase 3 Prevention: count of prevention mechanisms
|
|
- Total files affected, estimated time
|
|
|
|
2. Present decision:
|
|
|
|
```javascript
|
|
AskUserQuestion({
|
|
questions: [{
|
|
question: "Remediation plan generated. Review and decide:",
|
|
header: "Plan Approval Gate",
|
|
multiSelect: false,
|
|
options: [
|
|
{ label: "Approve", description: "Proceed with fix execution in worktree" },
|
|
{ label: "Revise", description: "Re-run planner with specific feedback" },
|
|
{ label: "Abort", description: "Stop pipeline, keep scan/assessment results" }
|
|
]
|
|
}]
|
|
})
|
|
```
|
|
|
|
3. Handle response:
|
|
|
|
| Response | Action |
|
|
|----------|--------|
|
|
| Approve | Report approved, trigger worktree creation |
|
|
| Revise | Collect revision feedback, report revision-needed |
|
|
| Abort | Report abort, pipeline stops |
|
|
|
|
**Output**: Approval decision with details
|
|
|
|
---
|
|
|
|
## Structured Output Template
|
|
|
|
```
|
|
## Summary
|
|
- Plan reviewed: remediation-plan.md
|
|
- Decision: <approved|revision-needed|aborted>
|
|
|
|
## Plan Overview
|
|
- Phase 1 Quick Wins: <count> items, <effort> effort
|
|
- Phase 2 Systematic: <count> items, <effort> effort
|
|
- Phase 3 Prevention: <count> mechanisms
|
|
- Files affected: <count>
|
|
|
|
## Decision Details
|
|
- User choice: <Approve|Revise|Abort>
|
|
- Feedback: <user feedback if revision>
|
|
|
|
## Risks Identified
|
|
- Risk 1: description
|
|
- Risk 2: description
|
|
```
|
|
|
|
---
|
|
|
|
## Error Handling
|
|
|
|
| Scenario | Resolution |
|
|
|----------|------------|
|
|
| Plan file not found | Report error, suggest re-running planner |
|
|
| Plan is empty (no actions) | Report clean codebase, suggest closing |
|
|
| User does not respond | Timeout, report awaiting-review |
|
|
| Plan JSON parse error | Fall back to .md for review, report warning |
|