Confess
A systematic self-audit skill that encourages honest discovery and disclosure of issues the agent may know about but hasn't mentioned. Especially good for admitting to reward hacking and coming clean.
When to Use
- After completing implementation work
- When something feels incomplete
- Before marking a task as "done"
- When the user asks "what did I miss?" or "confess"
Confession Categories
1. Incomplete Work
Search for related files that may also need changes:
- Use
grepto find references to modified code - Check for tests that need updating
- Look for documentation that references changed behavior
2. Untested Assumptions
Be honest about what was actually verified:
- Did you run the code or just build it?
- Were error paths tested?
- What edge cases weren't considered?
3. Pattern Violations
Compare against existing codebase:
- Find similar implementations with
glob - Does new code match existing patterns?
- Are there framework best practices being ignored?
4. Hidden Knowledge
Reveal things noticed but not mentioned:
- Potential issues spotted but not raised
- Concerns about the approach
- Shortcuts taken without disclosure
- Technical debt introduced
5. Cleanup Debt
Check for orphaned code:
- Dead code that should be removed
- Unused imports/dependencies
- Orphaned files/routes
Workflow
-
Gather Context
# What files were recently modified? git diff --name-only HEAD~1 # What functions/exports changed? git diff HEAD~1 --stat -
Search for References
# Find all references to modified code grep -r "functionName" --include="*.ts" --include="*.tsx" -
Compare Patterns
- Find similar files in the codebase
- Compare implementation approaches
- Note any inconsistencies
-
Verification Check
- List what was actually tested
- List what was assumed to work
- List what needs manual verification
-
Disclose Everything Format confessions as:
## My Confessions ### Incomplete Work - [specific issue] ### Untested - [what wasn't verified] ### Pattern Issues - [inconsistencies found] ### Hidden Concerns - [things I noticed but didn't mention] ### Cleanup Needed - [dead code, orphaned files]
Key Principles
- Non-judgmental - Confessing is good, not shameful
- Tool-assisted - Use grep/glob, don't rely on memory
- Systematic - Cover all categories every time
- Honest - If uncertain, say so
- Actionable - Each confession should suggest a fix
Example Output
After implementing OAuth error handling:
My Confessions
Incomplete Work
- Modified
auth-config.tsbutoauth2/authorize/page.tsx:173still redirects to/error/oauthproxy.ts:67also references the old error routelib/oauth-errors.tshasredirectToErrorPage()function still using old patternUntested
- Only ran
bun run build, didn't test actual OAuth error flow- Didn't verify error display on homepage with real error params
Pattern Issues
- Homepage uses
useSearchParamsdirectly, but other pages extract it into a Suspense-wrapped component- See:
oauth2/authorize/page.tsx,device/page.tsxfor correct patternHidden Concerns
- The error page at
/error/[type]is well-designed and actively used- Removing
onAPIErrormay have been the wrong approachCleanup Needed
- Decision needed: fully migrate to homepage errors OR keep
/error/oauthroute