dev-workflows-fullstack/skills/recipe-prepare-implementation/SKILL.md
Verifies the work plan is implementable end-to-end and resolves verification-lane / fixture / E2E-environment gaps before the build phase begins. Use when "implement-ready/verification readiness/lane setup/E2E environment missing" is mentioned, or before any build phase begins on a work plan whose readiness has not been preflight-checked.
npx skillsauth add shinpr/claude-code-workflows recipe-prepare-implementationInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Context: Optional readiness phase between work-plan approval and recipe-*-build. Confirms the implementation will be observable from Phase 1 onward and resolves any gaps via Phase 0 tasks. Exits no-op when the readiness criteria already pass, so the recipe is safe to invoke unconditionally.
Core Identity: "I am an orchestrator." (see subagents-orchestration-guide skill)
Execution Protocol:
Implementation Readiness: header to ready and persisting the Readiness Report section. No code or test files are touched.Work plan: $ARGUMENTS
Run before any recipe-*-build invocation when ANY of the following hold:
When none of the above hold, the readiness scan in Step 2 will find zero failing criteria and the recipe exits no-op (see Context at the top of this skill).
Each criterion is a measurable check producing pass, fail, or not_applicable with cited evidence.
| ID | Criterion | Pass evidence | |----|-----------|---------------| | R1 | Verification Strategy references resolve | Every command, file path, function, endpoint, and test referenced in the work plan's Verification Strategy section either exists in the codebase (verified via Glob/Grep) or is the deliverable of a task already in this plan | | R2 | E2E preconditions addressed | When E2E skeletons exist: every precondition mentioned in skeleton comments (seed data, auth fixture, env var, external mock) is present in the codebase or covered by a Phase 0 task in this plan | | R3 | Phase 1 observability | The first implementation phase contains at least one task whose Operation Verification Methods can execute at task completion using only artifacts that exist before the task starts (existing code, prior Phase 0 task deliverables, or the task's own outputs) | | R4 | UI rendering surface | When the plan implements UI components: a fixture entry, dev route, Storybook story, or equivalent rendering surface exists for the impacted components, OR a Phase 0 task adds one | | R5 | Local lane procedure | The work plan or a referenced doc records the commands needed to start the system locally for manual verification (start commands, default ports, seed steps) |
R4 and R5 are evaluated only when their triggering signals appear in the work plan; otherwise mark not_applicable.
# Verify the work plan exists
! ls -la docs/plans/*.md | grep -v template | tail -5
State check:
Read the work plan path passed in $ARGUMENTS. Extract:
For each criterion R1–R5:
pass / fail / not_applicablepass, the unresolved reference for fail, the missing trigger signal for not_applicableBuild the Readiness Report (see Output Format) regardless of outcome.
When every applicable criterion is pass (zero fail):
## Implementation Readiness Report section in the work plan immediately after the header block, using the same Readiness Report markdown defined in Output Format belowImplementation Readiness: line to ready (insert it after Related Issue/PR: if absent)outcome: ready, gaps_resolved: 0When one or more criteria are fail → proceed to Step 4.
For each fail criterion:
Determine the smallest concrete task that closes the gap (examples: "Add fixture entry for ComponentX covering loading/empty/error states", "Add seed script for E2E user fixtures", "Document local startup commands in docs/run/local.md")
Decide the task's layer by matching every target file path against the markers below:
**/api/**, **/server/**, **/services/**, **/backend/**, **/handlers/**, **/repositories/****/components/**, **/pages/**, **/web/**, **/frontend/**, **/*.tsx, **/*.jsxdocs/**, scripts/**, root-level configs, fixture data files outside the markers above) → escalate to user; ask the user to either (a) decide which layer's executor / quality-fixer should run the task, or (b) update the markers if the project uses different pathsApply the rules in the order above. The first matching rule wins; "unrecognized" is the final fallback rather than a catch-all that defaults to backend.
Create a Phase 0 task file at docs/plans/tasks/{plan-name}-backend-task-prep-{NN}.md (backend) or docs/plans/tasks/{plan-name}-frontend-task-prep-{NN}.md (frontend) using the task template from documentation-criteria skill. The -task-prep- segment lets recipe-prepare-implementation distinguish prep tasks from implementation tasks while keeping the existing {plan-name}-{layer}-task-* matcher used by other recipes
Update the work plan to insert these tasks as Phase 0 (before Phase 1)
Present the proposed resolution task list to the user with AskUserQuestion. Proceed only after explicit approval — this is the single human gate inside this recipe.
For each resolution task, run the standard 4-step cycle (see subagents-orchestration-guide "Task Management: 4-Step Cycle"):
*-backend-task-prep-* → subagent_type: "dev-workflows-fullstack:task-executor"*-frontend-task-prep-* → subagent_type: "dev-workflows-fullstack:task-executor-frontend"*-backend-task-prep-* → "dev-workflows-fullstack:quality-fixer"*-frontend-task-prep-* → "dev-workflows-fullstack:quality-fixer-frontend"approvedAppend the Scope Boundary block (below) to every subagent prompt.
Re-scan: Re-run the Step 2 readiness scan after all resolution tasks are committed.
Persist Readiness Report into work plan body: Append (or replace, if already present) a ## Implementation Readiness Report section in the work plan immediately after the header block. Use the same Readiness Report markdown defined in Output Format below. Downstream recipe--build / recipe--implement read this section when the header is escalated to surface remaining gaps to the user.
Update work plan header: Locate the line Implementation Readiness: pending in the work plan and rewrite it based on the re-scan outcome:
| Re-scan result | New header value |
|----------------|------------------|
| All applicable criteria pass | Implementation Readiness: ready |
| One or more fail remain | Implementation Readiness: escalated |
If the line is absent (older work plan format), insert it after the Related Issue/PR: line.
Final Cleanup: Delete every prep task file this recipe created for the current {plan-name} (docs/plans/tasks/{plan-name}-backend-task-prep-*.md and docs/plans/tasks/{plan-name}-frontend-task-prep-*.md) AND the phase-completion file generated for prep phases (docs/plans/tasks/{plan-name}-phase0-completion.md when present, since prep tasks live in Phase 0). Prep task files for other plans are out of scope — this recipe deletes only what it created for the current run. Their work is committed; docs/plans/ is ephemeral working state and is not retained between recipe runs. The work plan itself is preserved for the downstream recipe--build / recipe--implement.
Exit:
| Re-scan result | Action |
|----------------|--------|
| All applicable criteria pass | Exit with outcome: ready, gaps_resolved: N and final Readiness Report |
| One or more fail remain | Exit with outcome: escalated — present remaining failures to the user with the next-action recommendation. Treat the re-scan as the terminal evaluation; further resolution requires the user to re-invoke this recipe with updated inputs. |
Append the following block to every subagent prompt invoked from this recipe:
Scope boundary for subagents:
Operate within the task scope and referenced files in the prompt.
Use loaded skills to execute that scope.
Escalate when the required fix or investigation falls outside that scope.
Final report presented to the user at exit:
## Implementation Readiness Report
Work plan: [path]
Outcome: ready | escalated
Gaps resolved: [N]
### Readiness Criteria
| ID | Result | Evidence |
|----|--------|----------|
| R1 | pass / fail / not_applicable | [file:line OR "missing: <unresolved reference>"] |
| R2 | ... | ... |
| R3 | ... | ... |
| R4 | ... | ... |
| R5 | ... | ... |
### Resolution Tasks Executed (when gaps_resolved > 0)
- [task file path] — [one-line summary] — committed
- ...
### Remaining Gaps (when outcome is escalated)
- [criterion ID]: [unresolved reference] — Next action: [recommendation]
pass, OR resolution tasks generated, approved, and executed via the 4-step cycle## Implementation Readiness Report section persisted into the work plan bodyImplementation Readiness: line updated to ready or escalateddocs/plans/tasks/documentation
Guides subagent coordination through implementation workflows. Use when orchestrating multiple agents, managing workflow phases, or determining autonomous execution mode.
documentation
Guides subagent coordination through implementation workflows. Use when orchestrating multiple agents, managing workflow phases, or determining autonomous execution mode.
documentation
Guides subagent coordination through implementation workflows. Use when orchestrating multiple agents, managing workflow phases, or determining autonomous execution mode.
documentation
Guides subagent coordination through implementation workflows. Use when orchestrating multiple agents, managing workflow phases, or determining autonomous execution mode.