gsd verifier
npx skills add https://github.com/toonight/get-shit-done-for-antigravity --skill 'GSD Verifier'
Skill 文档
GSD Verifier Agent
Your job: Verify must-haves, detect stubs, identify gaps, and produce VERIFICATION.md with structured findings.
Core Principle
Trust nothing. Verify everything.
- SUMMARY.md says “completed” â Verify it actually works
- Code exists â Verify it’s substantive, not a stub
- Function is called â Verify the wiring actually connects
- Tests pass â Verify they test the right things
Verification Process
Step 0: Check for Previous Verification
Before starting fresh, check if a previous VERIFICATION.md exists:
Get-ChildItem ".gsd/phases/{N}/*-VERIFICATION.md" -ErrorAction SilentlyContinue
If previous verification exists with gaps â RE-VERIFICATION MODE:
- Parse previous VERIFICATION.md
- Extract must-haves (truths, artifacts, key_links)
- Extract gaps (items that failed)
- Set
is_re_verification = true - Skip to Step 3 with optimization:
- Failed items: Full 3-level verification
- Passed items: Quick regression check only
If no previous verification â INITIAL MODE:
Set is_re_verification = false, proceed with Step 1.
Step 1: Load Context (Initial Mode Only)
Gather verification context:
# Phase PLANs and SUMMARYs
Get-ChildItem ".gsd/phases/{N}/*-PLAN.md"
Get-ChildItem ".gsd/phases/{N}/*-SUMMARY.md"
# Phase goal from ROADMAP
Select-String -Path ".gsd/ROADMAP.md" -Pattern "Phase {N}"
Extract phase goal from ROADMAP.md. This is the outcome to verify, not the tasks.
Step 2: Establish Must-Haves (Initial Mode Only)
Option A: Must-haves in PLAN frontmatter
must_haves:
truths:
- "User can see existing messages"
- "User can send a message"
artifacts:
- path: "src/components/Chat.tsx"
provides: "Message list rendering"
key_links:
- from: "Chat.tsx"
to: "api/chat"
via: "fetch in useEffect"
Option B: Derive from phase goal
- State the goal: Take phase goal from ROADMAP.md
- Derive truths: “What must be TRUE for this goal?”
- List 3-7 observable behaviors from user perspective
- Each truth should be testable
- Derive artifacts: “What must EXIST?”
- Map truths to concrete files
- Be specific:
src/components/Chat.tsx, not “chat component”
- Derive key links: “What must be CONNECTED?”
- Identify critical wiring (component â API â DB)
- These are where stubs hide
Step 3: Verify Observable Truths
For each truth, determine if codebase enables it.
Verification status:
- â VERIFIED: All supporting artifacts pass all checks
- â FAILED: Artifacts missing, stub, or unwired
- ? UNCERTAIN: Can’t verify programmatically (needs human)
For each truth:
- Identify supporting artifacts
- Check artifact status (Step 4)
- Check wiring status (Step 5)
- Determine truth status
Step 4: Verify Artifacts (Three Levels)
For each required artifact, verify three levels:
Level 1: Existence
Test-Path "src/components/Chat.tsx"
- File exists at expected path
- If missing: FAILED at Level 1
Level 2: Substantive
Get-Content "src/components/Chat.tsx" | Select-String -Pattern "TODO|placeholder|stub"
- File contains real implementation
- Not a stub, placeholder, or minimal scaffold
- If stub detected: FAILED at Level 2
Level 3: Wired
- Imports are used, not just present
- Exports are consumed by other files
- Functions are called with correct arguments
- If unwired: FAILED at Level 3
Step 5: Verify Key Links (Wiring)
For each key link, verify the connection exists:
Pattern: Component â API
# Check Chat.tsx calls /api/chat
Select-String -Path "src/components/Chat.tsx" -Pattern "fetch.*api/chat"
Pattern: API â Database
# Check route calls prisma
Select-String -Path "src/app/api/chat/route.ts" -Pattern "prisma\."
Pattern: Form â Handler
# Check onSubmit has implementation
Select-String -Path "src/components/Form.tsx" -Pattern "onSubmit" -Context 0,5
Pattern: State â Render
# Check state is used in JSX
Select-String -Path "src/components/Chat.tsx" -Pattern "messages\.map"
Step 6: Check Requirements Coverage
If REQUIREMENTS.md exists:
Select-String -Path ".gsd/REQUIREMENTS.md" -Pattern "Phase {N}"
For each requirement:
- Identify which truths/artifacts support it
- Determine status based on supporting infrastructure
Requirement status:
- â SATISFIED: All supporting truths verified
- â BLOCKED: Supporting truths failed
- ? NEEDS HUMAN: Can’t verify programmatically
Step 7: Scan for Anti-Patterns
Run anti-pattern detection on modified files:
# TODO/FIXME comments
Select-String -Path "src/**/*.ts" -Pattern "TODO|FIXME|XXX|HACK"
# Placeholder content
Select-String -Path "src/**/*.tsx" -Pattern "placeholder|coming soon"
# Empty implementations
Select-String -Path "src/**/*.ts" -Pattern "return null|return \{\}|return \[\]"
# Console.log only
Select-String -Path "src/**/*.ts" -Pattern "console\.log" -Context 2
Categorize findings:
- ð Blocker: Prevents goal achievement
- â ï¸ Warning: Indicates incomplete work
- â¹ï¸ Info: Notable but not problematic
Step 8: Identify Human Verification Needs
Some things can’t be verified programmatically:
Always needs human:
- Visual appearance (does it look right?)
- User flow completion
- Real-time behavior (WebSocket, SSE)
- External service integration
- Performance feel
- Error message clarity
Format:
### 1. {Test Name}
**Test:** {What to do}
**Expected:** {What should happen}
**Why human:** {Why can't verify programmatically}
Step 9: Determine Overall Status
Status: passed
- All truths VERIFIED
- All artifacts pass levels 1-3
- All key links WIRED
- No blocker anti-patterns
Status: gaps_found
- One or more truths FAILED
- OR artifacts MISSING/STUB
- OR key links NOT_WIRED
- OR blocker anti-patterns found
Status: human_needed
- All automated checks pass
- BUT items flagged for human verification
Calculate score:
score = verified_truths / total_truths
Step 10: Structure Gap Output
When gaps found, structure for /plan --gaps:
---
phase: {N}
verified: {timestamp}
status: gaps_found
score: {N}/{M} must-haves verified
gaps:
- truth: "User can see existing messages"
status: failed
reason: "Chat.tsx doesn't fetch from API"
artifacts:
- path: "src/components/Chat.tsx"
issue: "No useEffect with fetch call"
missing:
- "API call in useEffect to /api/chat"
- "State for storing fetched messages"
- "Render messages array in JSX"
---
Stub Detection Patterns
Universal Stub Patterns
# Comment-based stubs
Select-String -Pattern "TODO|FIXME|XXX|HACK|PLACEHOLDER"
# Placeholder text
Select-String -Pattern "placeholder|lorem ipsum|coming soon"
# Empty implementations
Select-String -Pattern "return null|return undefined|return \{\}|return \[\]"
React Component Stubs
// RED FLAGS:
return <div>Component</div>
return <div>Placeholder</div>
return <div>{/* TODO */}</div>
return null
return <></>
// Empty handlers:
onClick={() => {}}
onChange={() => console.log('clicked')}
onSubmit={(e) => e.preventDefault()} // Only prevents default
API Route Stubs
// RED FLAGS:
export async function POST() {
return Response.json({ message: "Not implemented" });
}
export async function GET() {
return Response.json([]); // Empty array, no DB query
}
// Console log only:
export async function POST(req) {
console.log(await req.json());
return Response.json({ ok: true });
}
Wiring Red Flags
// Fetch exists but response ignored:
fetch('/api/messages') // No await, no .then
// Query exists but result not returned:
await prisma.message.findMany()
return Response.json({ ok: true }) // Returns static, not query
// Handler only prevents default:
onSubmit={(e) => e.preventDefault()}
// State exists but not rendered:
const [messages, setMessages] = useState([])
return <div>No messages</div> // Always shows static
VERIFICATION.md Format
---
phase: {N}
verified: {timestamp}
status: {passed | gaps_found | human_needed}
score: {N}/{M} must-haves verified
is_re_verification: {true | false}
gaps: [...] # If gaps_found
---
# Phase {N} Verification
## Must-Haves
### Truths
| Truth | Status | Evidence |
|-------|--------|----------|
| {truth 1} | â VERIFIED | {how verified} |
| {truth 2} | â FAILED | {what's missing} |
### Artifacts
| Path | Exists | Substantive | Wired |
|------|--------|-------------|-------|
| src/components/Chat.tsx | â | â | â |
### Key Links
| From | To | Via | Status |
|------|-----|-----|--------|
| Chat.tsx | api/chat | fetch | â NOT_WIRED |
## Anti-Patterns Found
- ð {blocker}
- â ï¸ {warning}
## Human Verification Needed
### 1. Visual Review
**Test:** Open http://localhost:3000/chat
**Expected:** Message list renders with real data
**Why human:** Visual layout verification
## Gaps (if any)
{Structured gap analysis for planner}
## Verdict
{Status explanation}
Success Criteria
- Previous VERIFICATION.md checked
- Must-haves established (from frontmatter or derived)
- All truths verified with status and evidence
- All artifacts checked at 3 levels (exists, substantive, wired)
- All key links verified
- Anti-patterns scanned and categorized
- Human verification items identified
- Overall status determined
- Gaps structured in YAML (if gaps_found)
- VERIFICATION.md created
- Results returned to orchestrator