6.9 KiB
{Task Title}
Plan quality: {grade} ({score}/100) — {APPROVE | APPROVE_WITH_NOTES | REVISE | REPLAN}
Generated by ultraplan-local v{version} on {YYYY-MM-DD}
Context
Why this change is needed. The problem or need it addresses, what prompted it, and the intended outcome. Reference the spec file if one was used.
Architecture Diagram
graph TD
subgraph "Changes in this plan"
%% C4-style component diagram showing what the plan touches
%% Highlight modified components, new components, and connections
end
Replace with actual Mermaid diagram showing the components this plan modifies, their relationships, and the data flow between them.
Codebase Analysis
- Tech stack: {languages, frameworks, build tools}
- Key patterns: {architecture patterns, conventions observed}
- Relevant files: {paths to files that will be read or modified}
- Reusable code: {existing functions, utilities, abstractions to leverage}
- External tech (researched): {technologies that were looked up via research-scout}
- Recent git activity: {relevant recent commits, active branches, code ownership}
Research Sources
Omit this section when no external research was conducted.
| Technology | Source | Key Findings | Confidence |
|---|---|---|---|
| {name} | {URL} | {summary} | {high/med/low} |
Implementation Plan
Each step targets 1–2 files and one focused change. Steps follow TDD structure when the project has tests.
Step 1: {description}
- Files:
path/to/file.ts - Changes: {exactly what to modify — no placeholders, no "update as needed"}
- Reuses: {existing function/pattern from codebase, with file path}
- Test first:
- File:
path/to/test.ts(existing | new) - Verifies: {what the test checks}
- Pattern:
path/to/existing-test.ts(follow this style)
- File:
- Verify:
{exact command}→ expected:{output} - On failure: {revert | retry | skip | escalate} — {specific instructions}
- Checkpoint:
git commit -m "{conventional commit message}"
Step 2: {description}
- Files:
path/to/file.ts - Changes: {exactly what to modify}
- Reuses: {existing function/pattern}
- Test first:
- File:
path/to/test.ts(existing | new) - Verifies: {what the test checks}
- Pattern:
path/to/existing-test.ts
- File:
- Verify:
{exact command}→ expected:{output} - On failure: {revert | retry | skip | escalate} — {specific instructions}
- Checkpoint:
git commit -m "{conventional commit message}"
For projects without tests: omit "Test first" and keep "Verify" with a concrete command (e.g., run the app, check output, curl an endpoint).
Failure recovery rules
- On failure: revert — undo this step's changes (
git checkout -- {files}), do NOT proceed - On failure: retry — attempt once more with the alternative approach described, then revert if still failing
- On failure: skip — this step is non-critical; continue to next step and note the skip
- On failure: escalate — stop execution entirely; the issue requires human judgment
- Checkpoint — after each step succeeds, commit changes so subsequent failures cannot corrupt completed work
Alternatives Considered
| Approach | Pros | Cons | Why rejected |
|---|---|---|---|
| {name} | ... | ... | ... |
Test Strategy
- Framework: {test framework and runner}
- Existing patterns: {how tests are structured in this codebase}
- New tests in this plan: {N} tests across {N} steps
Tests to write
| Type | File | Verifies | Model test |
|---|---|---|---|
| Unit | path/to/test |
{what it tests} | path/to/existing-test |
For projects without tests: describe manual verification approach instead.
Risks and Mitigations
| Priority | Risk | Location | Impact | Mitigation |
|---|---|---|---|---|
| {Critical/High/Medium/Low} | {description} | file:line |
{what happens} | {how to handle} |
Assumptions
Things the planner could not verify from codebase or research. Each assumption is a risk — review before executing.
| # | Assumption | Why unverifiable | Impact if wrong |
|---|---|---|---|
| 1 | {what we assumed} | {why we couldn't check} | {what breaks} |
If this list has 3+ items, the plan may need additional investigation before execution.
Verification
End-to-end checks that prove the plan was implemented correctly.
{exact command}→ expected:{exact output or behavior}{exact command}→ expected:{exact output or behavior}
Estimated Scope
- Files to modify: {N}
- Files to create: {N}
- Complexity: {low | medium | high}
Execution Strategy
Include this section when the plan has more than 5 implementation steps. Omit for small plans (≤ 5 steps) — ultraexecute will run them sequentially in a single session.
The execution strategy groups steps into sessions and organizes sessions into waves. Sessions in the same wave can run in parallel. Sessions in later waves depend on earlier waves completing first.
Session 1: {title}
- Steps: {step numbers, e.g., 1, 2, 3}
- Wave: {wave number}
- Depends on: {session numbers, or "none"}
- Scope fence:
- Touch: {files this session may modify}
- Never touch: {files reserved for other sessions}
Session 2: {title}
- Steps: {step numbers}
- Wave: {wave number}
- Depends on: {session numbers, or "none"}
- Scope fence:
- Touch: {files}
- Never touch: {files}
Execution Order
- Wave 1: {session list} (parallel)
- Wave 2: {session list} (after Wave 1)
Grouping rules applied
- Steps sharing files → same session
- Steps in independent modules → separate sessions (parallelizable)
- 3–5 steps per session (target)
- Sessions ordered by dependency, waves by independence
Plan Quality Score
| Dimension | Weight | Score | Notes |
|---|---|---|---|
| Structural integrity | 0.15 | {0–100} | {step ordering, dependencies} |
| Step quality | 0.20 | {0–100} | {granularity, specificity, TDD} |
| Coverage completeness | 0.20 | {0–100} | {spec → steps, no gaps} |
| Specification quality | 0.15 | {0–100} | {no placeholders, clear criteria} |
| Risk & pre-mortem | 0.15 | {0–100} | {failure modes addressed} |
| Headless readiness | 0.15 | {0–100} | {On failure + Checkpoint per step} |
| Weighted total | 1.00 | {score} | Grade: {A/B/C/D} |
Adversarial review:
- Plan critic: {verdict — findings count by severity, key issues}
- Scope guardian: {verdict — ALIGNED / CREEP / GAP / MIXED}
Revisions
Added by adversarial review. Omit if no revisions were needed.
| # | Finding | Severity | Resolution |
|---|---|---|---|
| 1 | {what was wrong} | {blocker/major/minor} | {how it was fixed} |