@su-record/vibe 2.9.32 → 2.9.34
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +37 -37
- package/CLAUDE.md +109 -109
- package/LICENSE +21 -21
- package/README.en.md +220 -220
- package/README.md +171 -171
- package/agents/architect-low.md +41 -41
- package/agents/architect-medium.md +59 -59
- package/agents/architect.md +80 -80
- package/agents/build-error-resolver.md +115 -115
- package/agents/compounder.md +261 -261
- package/agents/diagrammer.md +178 -178
- package/agents/docs/api-documenter.md +99 -99
- package/agents/docs/changelog-writer.md +93 -93
- package/agents/e2e-tester.md +294 -294
- package/agents/event/event-comms.md +78 -78
- package/agents/event/event-content.md +68 -68
- package/agents/event/event-image.md +95 -95
- package/agents/event/event-ops.md +84 -84
- package/agents/event/event-scheduler.md +69 -69
- package/agents/event/event-speaker.md +86 -86
- package/agents/explorer-low.md +42 -42
- package/agents/explorer-medium.md +59 -59
- package/agents/explorer.md +48 -48
- package/agents/implementer-low.md +43 -43
- package/agents/implementer-medium.md +52 -52
- package/agents/implementer.md +54 -54
- package/agents/junior-mentor.md +141 -141
- package/agents/planning/requirements-analyst.md +84 -84
- package/agents/planning/ux-advisor.md +83 -83
- package/agents/qa/acceptance-tester.md +86 -86
- package/agents/qa/edge-case-finder.md +93 -93
- package/agents/qa/qa-coordinator.md +131 -131
- package/agents/refactor-cleaner.md +143 -143
- package/agents/research/best-practices-agent.md +199 -199
- package/agents/research/codebase-patterns-agent.md +157 -157
- package/agents/research/framework-docs-agent.md +188 -188
- package/agents/research/security-advisory-agent.md +213 -213
- package/agents/review/architecture-reviewer.md +107 -107
- package/agents/review/complexity-reviewer.md +116 -116
- package/agents/review/data-integrity-reviewer.md +88 -88
- package/agents/review/git-history-reviewer.md +103 -103
- package/agents/review/performance-reviewer.md +86 -86
- package/agents/review/python-reviewer.md +150 -150
- package/agents/review/rails-reviewer.md +139 -139
- package/agents/review/react-reviewer.md +144 -144
- package/agents/review/security-reviewer.md +80 -80
- package/agents/review/simplicity-reviewer.md +140 -140
- package/agents/review/test-coverage-reviewer.md +116 -116
- package/agents/review/typescript-reviewer.md +127 -127
- package/agents/searcher.md +54 -54
- package/agents/simplifier.md +120 -120
- package/agents/teams/debug-team.md +70 -70
- package/agents/teams/dev-team.md +88 -88
- package/agents/teams/docs-team.md +80 -80
- package/agents/teams/figma/figma-analyst.md +52 -52
- package/agents/teams/figma/figma-architect.md +112 -112
- package/agents/teams/figma/figma-auditor.md +82 -82
- package/agents/teams/figma/figma-builder.md +100 -100
- package/agents/teams/figma-team.md +85 -85
- package/agents/teams/fullstack-team.md +83 -83
- package/agents/teams/lite-team.md +69 -69
- package/agents/teams/migration-team.md +78 -78
- package/agents/teams/refactor-team.md +94 -94
- package/agents/teams/research-team.md +86 -86
- package/agents/teams/review-debate-team.md +125 -125
- package/agents/teams/security-team.md +81 -81
- package/agents/tester.md +49 -49
- package/agents/ui/ui-a11y-auditor.md +93 -93
- package/agents/ui/ui-antipattern-detector.md +102 -102
- package/agents/ui/ui-dataviz-advisor.md +69 -69
- package/agents/ui/ui-design-system-gen.md +57 -57
- package/agents/ui/ui-industry-analyzer.md +49 -49
- package/agents/ui/ui-layout-architect.md +65 -65
- package/agents/ui/ui-stack-implementer.md +68 -68
- package/agents/ui/ux-compliance-reviewer.md +81 -81
- package/agents/ui-previewer.md +258 -258
- package/commands/vibe.analyze.md +533 -533
- package/commands/vibe.contract.md +105 -105
- package/commands/vibe.docs.md +33 -33
- package/commands/vibe.event.md +163 -163
- package/commands/vibe.figma.md +600 -600
- package/commands/vibe.harness.md +177 -177
- package/commands/vibe.regress.md +73 -73
- package/commands/vibe.review.md +624 -624
- package/commands/vibe.run.md +1946 -1946
- package/commands/vibe.scaffold.md +195 -195
- package/commands/vibe.spec.md +577 -577
- package/commands/vibe.test.md +49 -49
- package/commands/vibe.trace.md +276 -276
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.verify.md +572 -572
- package/dist/cli/collaborator.js +52 -52
- package/dist/cli/commands/codex-proxy.js +15 -15
- package/dist/cli/commands/config.js +9 -9
- package/dist/cli/commands/evolution.js +12 -12
- package/dist/cli/commands/figma.js +20 -20
- package/dist/cli/commands/info.d.ts.map +1 -1
- package/dist/cli/commands/info.js +48 -46
- package/dist/cli/commands/info.js.map +1 -1
- package/dist/cli/commands/init.d.ts +6 -3
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +60 -30
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/remove.js +14 -14
- package/dist/cli/commands/sentinel.js +27 -27
- package/dist/cli/commands/skills.js +5 -5
- package/dist/cli/commands/slack.js +10 -10
- package/dist/cli/commands/stats.js +6 -6
- package/dist/cli/commands/telegram.js +12 -12
- package/dist/cli/commands/update.d.ts.map +1 -1
- package/dist/cli/commands/update.js +29 -11
- package/dist/cli/commands/update.js.map +1 -1
- package/dist/cli/detect.js +32 -32
- package/dist/cli/index.js +40 -34
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/llm/claude-commands.js +16 -16
- package/dist/cli/llm/config.js +18 -18
- package/dist/cli/llm/gemini-commands.js +16 -16
- package/dist/cli/llm/gpt-commands.js +19 -19
- package/dist/cli/llm/help.js +21 -21
- package/dist/cli/postinstall/cursor-agents.js +32 -32
- package/dist/cli/postinstall/cursor-rules.js +83 -83
- package/dist/cli/postinstall/cursor-skills.js +743 -743
- package/dist/cli/postinstall/main.d.ts.map +1 -1
- package/dist/cli/postinstall/main.js +15 -1
- package/dist/cli/postinstall/main.js.map +1 -1
- package/dist/cli/setup/ProjectSetup.d.ts +25 -6
- package/dist/cli/setup/ProjectSetup.d.ts.map +1 -1
- package/dist/cli/setup/ProjectSetup.js +132 -80
- package/dist/cli/setup/ProjectSetup.js.map +1 -1
- package/dist/cli/setup/Provisioner.js +42 -42
- package/dist/cli/setup.d.ts +1 -1
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +1 -1
- package/dist/cli/setup.js.map +1 -1
- package/dist/infra/lib/DeepInit.js +24 -24
- package/dist/infra/lib/IterationTracker.js +11 -11
- package/dist/infra/lib/PythonParser.js +108 -108
- package/dist/infra/lib/ReviewRace.js +96 -96
- package/dist/infra/lib/SkillFrontmatter.js +28 -28
- package/dist/infra/lib/SkillQualityGate.js +9 -9
- package/dist/infra/lib/SkillRepository.js +159 -159
- package/dist/infra/lib/UltraQA.js +99 -99
- package/dist/infra/lib/autonomy/AuditStore.js +41 -41
- package/dist/infra/lib/autonomy/ConfirmationStore.js +30 -30
- package/dist/infra/lib/autonomy/EventOutbox.js +38 -38
- package/dist/infra/lib/autonomy/PolicyEngine.d.ts +3 -3
- package/dist/infra/lib/autonomy/PolicyEngine.js +18 -18
- package/dist/infra/lib/autonomy/SecuritySentinel.js +1 -1
- package/dist/infra/lib/autonomy/SuggestionStore.js +33 -33
- package/dist/infra/lib/embedding/VectorStore.js +22 -22
- package/dist/infra/lib/evolution/AgentAnalyzer.js +10 -10
- package/dist/infra/lib/evolution/DescriptionOptimizer.js +21 -21
- package/dist/infra/lib/evolution/GenerationRegistry.js +36 -36
- package/dist/infra/lib/evolution/InsightStore.js +90 -90
- package/dist/infra/lib/evolution/ParityTester.js +57 -57
- package/dist/infra/lib/evolution/RollbackManager.js +5 -5
- package/dist/infra/lib/evolution/SkillBenchmark.js +23 -23
- package/dist/infra/lib/evolution/SkillEvalRunner.js +50 -50
- package/dist/infra/lib/evolution/SkillGapDetector.js +10 -10
- package/dist/infra/lib/evolution/UsageTracker.js +28 -28
- package/dist/infra/lib/gemini/orchestration.js +5 -5
- package/dist/infra/lib/gpt/orchestration.js +4 -4
- package/dist/infra/lib/memory/KnowledgeGraph.js +4 -4
- package/dist/infra/lib/memory/MemorySearch.js +57 -57
- package/dist/infra/lib/memory/MemoryStorage.js +181 -181
- package/dist/infra/lib/memory/ObservationStore.js +28 -28
- package/dist/infra/lib/memory/ReflectionStore.js +30 -30
- package/dist/infra/lib/memory/SessionRAGRetriever.js +7 -7
- package/dist/infra/lib/memory/SessionRAGStore.js +225 -225
- package/dist/infra/lib/memory/SessionSummarizer.js +9 -9
- package/dist/infra/orchestrator/AgentManager.js +12 -12
- package/dist/infra/orchestrator/AgentRegistry.js +65 -65
- package/dist/infra/orchestrator/MultiLlmResearch.js +8 -8
- package/dist/infra/orchestrator/SwarmOrchestrator.test.js +16 -16
- package/dist/infra/orchestrator/parallelResearch.js +24 -24
- package/dist/tools/convention/analyzeComplexity.test.js +115 -115
- package/dist/tools/convention/validateCodeQuality.test.js +104 -104
- package/dist/tools/memory/createMemoryTimeline.js +10 -10
- package/dist/tools/memory/getMemoryGraph.js +12 -12
- package/dist/tools/memory/getSessionContext.js +9 -9
- package/dist/tools/memory/linkMemories.js +14 -14
- package/dist/tools/memory/listMemories.js +4 -4
- package/dist/tools/memory/recallMemory.js +4 -4
- package/dist/tools/memory/saveMemory.js +4 -4
- package/dist/tools/memory/searchMemoriesAdvanced.js +23 -23
- package/dist/tools/semantic/analyzeDependencyGraph.js +12 -12
- package/dist/tools/semantic/astGrep.test.js +6 -6
- package/dist/tools/spec/prdParser.test.js +171 -171
- package/dist/tools/spec/specGenerator.js +169 -169
- package/dist/tools/spec/traceabilityMatrix.js +64 -64
- package/dist/tools/spec/traceabilityMatrix.test.js +28 -28
- package/hooks/gemini-hooks.json +73 -73
- package/hooks/hooks.json +134 -134
- package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
- package/hooks/scripts/__tests__/pre-tool-guard.test.js +409 -409
- package/hooks/scripts/__tests__/sentinel-guard.test.js +208 -208
- package/hooks/scripts/auto-commit.js +97 -97
- package/hooks/scripts/auto-format.js +64 -64
- package/hooks/scripts/auto-test.js +81 -81
- package/hooks/scripts/code-check.js +271 -271
- package/hooks/scripts/codex-detect.js +46 -46
- package/hooks/scripts/codex-review-gate.js +80 -80
- package/hooks/scripts/command-log.js +32 -32
- package/hooks/scripts/context-save.js +353 -353
- package/hooks/scripts/evolution-engine.js +91 -91
- package/hooks/scripts/figma-extract.js +768 -768
- package/hooks/scripts/figma-guard.js +219 -219
- package/hooks/scripts/figma-refine.js +315 -315
- package/hooks/scripts/figma-to-scss.js +394 -394
- package/hooks/scripts/figma-validate.js +353 -353
- package/hooks/scripts/hud-status.js +321 -321
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/lib/dispatcher.js +95 -87
- package/hooks/scripts/lib/scope-from-spec.js +276 -276
- package/hooks/scripts/llm-orchestrate.js +645 -645
- package/hooks/scripts/post-edit-dispatcher.js +9 -6
- package/hooks/scripts/post-edit.js +35 -35
- package/hooks/scripts/pr-test-gate.js +52 -52
- package/hooks/scripts/pre-tool-dispatcher.js +9 -1
- package/hooks/scripts/pre-tool-guard.js +259 -259
- package/hooks/scripts/prompt-dispatcher.js +200 -192
- package/hooks/scripts/scope-guard.js +145 -145
- package/hooks/scripts/sentinel-guard.js +130 -130
- package/hooks/scripts/session-start.js +186 -186
- package/hooks/scripts/skill-injector.js +83 -83
- package/hooks/scripts/step-counter.js +45 -45
- package/hooks/scripts/stop-dispatcher.js +9 -6
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +315 -315
- package/languages/csharp-unity.md +515 -515
- package/languages/gdscript-godot.md +470 -470
- package/languages/ruby-rails.md +489 -489
- package/languages/typescript-angular.md +433 -433
- package/languages/typescript-astro.md +416 -416
- package/languages/typescript-electron.md +406 -406
- package/languages/typescript-nestjs.md +524 -524
- package/languages/typescript-svelte.md +407 -407
- package/languages/typescript-tauri.md +365 -365
- package/package.json +106 -106
- package/skills/agents-md/SKILL.md +121 -121
- package/skills/agents-md/rubrics/what-to-keep.md +49 -49
- package/skills/agents-md/templates/agents-md.md +36 -36
- package/skills/arch-guard/SKILL.md +181 -181
- package/skills/arch-guard/agents/detector.md +48 -48
- package/skills/arch-guard/agents/reporter.md +48 -48
- package/skills/arch-guard/agents/rule-generator.md +49 -49
- package/skills/arch-guard/agents/violation-checker.md +51 -51
- package/skills/arch-guard/frameworks/clean-architecture.md +108 -108
- package/skills/arch-guard/frameworks/solid.md +102 -102
- package/skills/arch-guard/scripts/check-boundaries.js +90 -90
- package/skills/arch-guard/templates/arch-rules.json +47 -47
- package/skills/arch-guard/templates/violation-report.md +53 -53
- package/skills/brand-assets/SKILL.md +147 -147
- package/skills/brand-assets/rubrics/asset-checklist.md +98 -98
- package/skills/brand-assets/templates/brand-guide.md +161 -161
- package/skills/capability-loop/SKILL.md +272 -272
- package/skills/capability-loop/agents/capability-designer.md +61 -61
- package/skills/capability-loop/agents/failure-analyst.md +55 -55
- package/skills/capability-loop/agents/implementer.md +50 -50
- package/skills/capability-loop/agents/tester.md +53 -53
- package/skills/capability-loop/templates/capability-spec.md +118 -118
- package/skills/capability-loop/templates/failure-analysis.md +118 -118
- package/skills/characterization-test/SKILL.md +207 -207
- package/skills/characterization-test/agents/behavior-capturer.md +50 -50
- package/skills/characterization-test/agents/coverage-checker.md +54 -54
- package/skills/characterization-test/agents/reporter.md +50 -50
- package/skills/characterization-test/agents/test-writer.md +49 -49
- package/skills/characterization-test/rubrics/coverage-criteria.md +53 -53
- package/skills/characterization-test/templates/test-template.ts +101 -101
- package/skills/chub-usage/SKILL.md +139 -139
- package/skills/claude-md-guide/SKILL.md +351 -351
- package/skills/claude-md-guide/rubrics/anti-patterns.md +88 -88
- package/skills/claude-md-guide/templates/claude-md.md +54 -54
- package/skills/commerce-patterns/SKILL.md +64 -64
- package/skills/commerce-patterns/rubrics/checkout-flow.md +48 -48
- package/skills/commerce-patterns/templates/product-schema.md +85 -85
- package/skills/commit-push-pr/SKILL.md +77 -77
- package/skills/commit-push-pr/agents/change-analyzer.md +55 -55
- package/skills/commit-push-pr/agents/message-writer.md +50 -50
- package/skills/commit-push-pr/agents/pr-writer.md +58 -58
- package/skills/commit-push-pr/agents/reviewer.md +52 -52
- package/skills/commit-push-pr/rubrics/commit-message.md +73 -73
- package/skills/commit-push-pr/templates/pr-body.md +63 -63
- package/skills/context7-usage/SKILL.md +106 -106
- package/skills/context7-usage/rubrics/when-to-use.md +50 -50
- package/skills/create-prd/SKILL.md +90 -90
- package/skills/create-prd/agents/edge-case-finder.md +48 -48
- package/skills/create-prd/agents/prioritizer.md +60 -60
- package/skills/create-prd/agents/requirements-writer.md +48 -48
- package/skills/create-prd/agents/researcher.md +55 -55
- package/skills/create-prd/agents/reviewer.md +54 -54
- package/skills/create-prd/frameworks/jobs-to-be-done.md +96 -96
- package/skills/create-prd/frameworks/rice-scoring.md +97 -97
- package/skills/create-prd/orchestrator.md +70 -70
- package/skills/create-prd/rubrics/completeness.md +58 -58
- package/skills/create-prd/templates/prd.md +139 -139
- package/skills/design-audit/SKILL.md +152 -152
- package/skills/design-audit/agents/a11y-auditor.md +43 -43
- package/skills/design-audit/agents/performance-auditor.md +46 -46
- package/skills/design-audit/agents/responsive-auditor.md +46 -46
- package/skills/design-audit/agents/scorer.md +47 -47
- package/skills/design-audit/agents/slop-detector.md +47 -47
- package/skills/design-audit/frameworks/core-web-vitals.md +107 -107
- package/skills/design-audit/frameworks/wcag-checklist.md +64 -64
- package/skills/design-audit/orchestrator.md +64 -64
- package/skills/design-audit/rubrics/ai-slop-patterns.md +83 -83
- package/skills/design-audit/rubrics/scoring.md +63 -63
- package/skills/design-audit/templates/report.md +88 -88
- package/skills/design-critique/SKILL.md +139 -139
- package/skills/design-critique/rubrics/ux-heuristics.md +143 -143
- package/skills/design-critique/templates/critique-report.md +86 -86
- package/skills/design-distill/SKILL.md +130 -130
- package/skills/design-distill/templates/design-system.md +132 -132
- package/skills/design-normalize/SKILL.md +133 -133
- package/skills/design-normalize/rubrics/token-naming.md +117 -117
- package/skills/design-normalize/templates/token-audit.md +89 -89
- package/skills/design-polish/SKILL.md +131 -131
- package/skills/design-polish/rubrics/polish-checklist.md +68 -68
- package/skills/design-polish/templates/polish-report.md +64 -64
- package/skills/design-teach/SKILL.md +182 -182
- package/skills/design-teach/rubrics/brand-personality.md +73 -73
- package/skills/design-teach/templates/design-context.json +36 -36
- package/skills/devlog/SKILL.md +143 -143
- package/skills/e2e-commerce/SKILL.md +62 -62
- package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
- package/skills/event-comms/SKILL.md +172 -172
- package/skills/event-comms/templates/email-invite.md +99 -99
- package/skills/event-comms/templates/sns-post.md +133 -133
- package/skills/event-ops/SKILL.md +207 -207
- package/skills/event-ops/rubrics/contingency.md +85 -85
- package/skills/event-ops/templates/d-day-checklist.md +65 -65
- package/skills/event-planning/SKILL.md +144 -144
- package/skills/event-planning/rubrics/timeline.md +70 -70
- package/skills/event-planning/templates/event-plan.md +91 -91
- package/skills/exec-plan/SKILL.md +149 -149
- package/skills/exec-plan/agents/decomposer.md +47 -47
- package/skills/exec-plan/agents/dependency-mapper.md +44 -44
- package/skills/exec-plan/agents/estimator.md +43 -43
- package/skills/exec-plan/agents/validator.md +55 -55
- package/skills/exec-plan/orchestrator.md +70 -70
- package/skills/exec-plan/rubrics/complexity-scoring.md +75 -75
- package/skills/exec-plan/templates/plan.md +147 -147
- package/skills/git-worktree/SKILL.md +73 -73
- package/skills/git-worktree/rubrics/when-to-use.md +55 -55
- package/skills/handoff/SKILL.md +110 -110
- package/skills/handoff/agents/context-summarizer.md +51 -51
- package/skills/handoff/agents/document-writer.md +63 -63
- package/skills/handoff/agents/state-collector.md +53 -53
- package/skills/handoff/agents/verifier.md +48 -48
- package/skills/handoff/rubrics/completeness.md +62 -62
- package/skills/handoff/templates/handoff.md +107 -107
- package/skills/parallel-research/SKILL.md +104 -104
- package/skills/parallel-research/agents/best-practices.md +43 -43
- package/skills/parallel-research/agents/codebase-patterns.md +46 -46
- package/skills/parallel-research/agents/framework-docs.md +45 -45
- package/skills/parallel-research/agents/security-advisory.md +46 -46
- package/skills/parallel-research/agents/synthesizer.md +57 -57
- package/skills/parallel-research/experts/best-practices.md +50 -50
- package/skills/parallel-research/experts/codebase-patterns.md +70 -70
- package/skills/parallel-research/experts/framework-docs.md +65 -65
- package/skills/parallel-research/experts/security-advisory.md +69 -69
- package/skills/parallel-research/orchestrator.md +79 -79
- package/skills/parallel-research/templates/awesome-list.md +32 -32
- package/skills/parallel-research/templates/paper.md +88 -88
- package/skills/parallel-research/templates/synthesis.md +101 -101
- package/skills/prioritization-frameworks/SKILL.md +87 -87
- package/skills/prioritization-frameworks/rubrics/frameworks.md +79 -79
- package/skills/prioritization-frameworks/templates/scoring-matrix.md +69 -69
- package/skills/priority-todos/SKILL.md +64 -64
- package/skills/priority-todos/rubrics/prioritization.md +70 -70
- package/skills/priority-todos/templates/todo-board.md +59 -59
- package/skills/seo-checklist/SKILL.md +58 -58
- package/skills/seo-checklist/frameworks/structured-data.md +153 -153
- package/skills/seo-checklist/rubrics/content-seo.md +42 -42
- package/skills/seo-checklist/rubrics/technical-seo.md +48 -48
- package/skills/techdebt/SKILL.md +124 -124
- package/skills/techdebt/agents/analyzer.md +50 -50
- package/skills/techdebt/agents/fixer.md +41 -41
- package/skills/techdebt/agents/reviewer.md +47 -47
- package/skills/techdebt/agents/scanner.md +44 -44
- package/skills/techdebt/orchestrator.md +70 -70
- package/skills/techdebt/rubrics/severity.md +51 -51
- package/skills/techdebt/scripts/scan.js +90 -90
- package/skills/techdebt/templates/report.md +86 -86
- package/skills/tool-fallback/SKILL.md +104 -104
- package/skills/tool-fallback/rubrics/fallback-chain.md +58 -58
- package/skills/typescript-advanced-types/SKILL.md +67 -67
- package/skills/typescript-advanced-types/rubrics/type-patterns.md +109 -109
- package/skills/ui-ux-pro-max/SKILL.md +236 -236
- package/skills/ui-ux-pro-max/reference/color-and-contrast.md +517 -517
- package/skills/ui-ux-pro-max/reference/interaction-design.md +544 -544
- package/skills/ui-ux-pro-max/reference/motion-design.md +591 -591
- package/skills/ui-ux-pro-max/reference/responsive-design.md +463 -463
- package/skills/ui-ux-pro-max/reference/spatial-design.md +390 -390
- package/skills/ui-ux-pro-max/reference/typography.md +455 -455
- package/skills/ui-ux-pro-max/reference/ux-writing.md +469 -469
- package/skills/ui-ux-pro-max/rubrics/interaction-states.md +83 -83
- package/skills/ui-ux-pro-max/rubrics/responsive-breakpoints.md +99 -99
- package/skills/user-personas/SKILL.md +75 -75
- package/skills/user-personas/rubrics/research-methods.md +56 -56
- package/skills/user-personas/templates/persona.md +89 -89
- package/skills/vercel-react-best-practices/SKILL.md +60 -60
- package/skills/vercel-react-best-practices/rubrics/performance.md +82 -82
- package/skills/vercel-react-best-practices/rubrics/server-components.md +86 -86
- package/skills/vibe-contract/SKILL.md +166 -166
- package/skills/vibe-docs/templates/architecture.md +80 -80
- package/skills/vibe-docs/templates/readme.md +84 -84
- package/skills/vibe-docs/templates/release-notes.md +74 -74
- package/skills/vibe-figma/SKILL.md +363 -363
- package/skills/vibe-figma/rubrics/extraction-checklist.md +51 -51
- package/skills/vibe-figma/templates/component-index.md +126 -126
- package/skills/vibe-figma/templates/component-spec.md +168 -168
- package/skills/vibe-figma/templates/figma-handoff.md +100 -100
- package/skills/vibe-figma/templates/remapped-tree.md +277 -277
- package/skills/vibe-figma-convert/SKILL.md +235 -235
- package/skills/vibe-figma-convert/rubrics/conversion-rules.md +141 -141
- package/skills/vibe-figma-convert/templates/component.md +140 -140
- package/skills/vibe-figma-extract/SKILL.md +241 -241
- package/skills/vibe-figma-extract/rubrics/image-rules.md +157 -157
- package/skills/vibe-interview/SKILL.md +358 -358
- package/skills/vibe-interview/checklists/api.md +101 -101
- package/skills/vibe-interview/checklists/feature.md +88 -88
- package/skills/vibe-interview/checklists/library.md +95 -95
- package/skills/vibe-interview/checklists/mobile.md +89 -89
- package/skills/vibe-interview/checklists/webapp.md +97 -97
- package/skills/vibe-interview/checklists/website.md +99 -99
- package/skills/vibe-plan/SKILL.md +254 -254
- package/skills/vibe-regress/SKILL.md +174 -174
- package/skills/vibe-regress/templates/bug.md +44 -44
- package/skills/vibe-regress/templates/test-jest.md +29 -29
- package/skills/vibe-regress/templates/test-vitest.md +30 -30
- package/skills/vibe-spec/SKILL.md +1195 -1195
- package/skills/vibe-spec-review/SKILL.md +726 -726
- package/skills/vibe-test/SKILL.md +140 -140
- package/skills/video-production/SKILL.md +52 -52
- package/skills/video-production/rubrics/quality-checklist.md +58 -58
- package/skills/video-production/templates/production-plan.md +104 -104
- package/vibe/config.json +29 -29
- package/vibe/constitution.md +227 -227
- package/vibe/rules/principles/communication-guide.md +98 -98
- package/vibe/rules/principles/development-philosophy.md +52 -52
- package/vibe/rules/principles/quick-start.md +102 -102
- package/vibe/rules/quality/bdd-contract-testing.md +393 -393
- package/vibe/rules/quality/checklist.md +276 -276
- package/vibe/rules/quality/performance.md +236 -236
- package/vibe/rules/quality/testing-strategy.md +440 -440
- package/vibe/rules/standards/anti-patterns.md +541 -541
- package/vibe/rules/standards/code-structure.md +291 -291
- package/vibe/rules/standards/complexity-metrics.md +313 -313
- package/vibe/rules/standards/git-workflow.md +237 -237
- package/vibe/rules/standards/naming-conventions.md +198 -198
- package/vibe/rules/standards/security.md +305 -305
- package/vibe/rules/writing/document-style.md +74 -74
- package/vibe/setup.sh +31 -31
- package/vibe/templates/claudemd-template.md +74 -74
- package/vibe/templates/constitution-template.md +267 -267
- package/vibe/templates/contract-backend-template.md +526 -526
- package/vibe/templates/contract-frontend-template.md +599 -599
- package/vibe/templates/feature-template.md +96 -96
- package/vibe/templates/plan-template.md +194 -194
- package/vibe/templates/spec-template.md +221 -221
- package/vibe/ui-ux-data/charts.csv +26 -26
- package/vibe/ui-ux-data/colors.csv +97 -97
- package/vibe/ui-ux-data/icons.csv +101 -101
- package/vibe/ui-ux-data/landing.csv +31 -31
- package/vibe/ui-ux-data/products.csv +96 -96
- package/vibe/ui-ux-data/react-performance.csv +45 -45
- package/vibe/ui-ux-data/stacks/astro.csv +54 -54
- package/vibe/ui-ux-data/stacks/flutter.csv +53 -53
- package/vibe/ui-ux-data/stacks/html-tailwind.csv +56 -56
- package/vibe/ui-ux-data/stacks/jetpack-compose.csv +53 -53
- package/vibe/ui-ux-data/stacks/nextjs.csv +53 -53
- package/vibe/ui-ux-data/stacks/nuxt-ui.csv +51 -51
- package/vibe/ui-ux-data/stacks/nuxtjs.csv +59 -59
- package/vibe/ui-ux-data/stacks/react-native.csv +52 -52
- package/vibe/ui-ux-data/stacks/react.csv +54 -54
- package/vibe/ui-ux-data/stacks/shadcn.csv +61 -61
- package/vibe/ui-ux-data/stacks/svelte.csv +54 -54
- package/vibe/ui-ux-data/stacks/swiftui.csv +51 -51
- package/vibe/ui-ux-data/stacks/vue.csv +50 -50
- package/vibe/ui-ux-data/styles.csv +68 -68
- package/vibe/ui-ux-data/typography.csv +57 -57
- package/vibe/ui-ux-data/ui-reasoning.csv +101 -101
- package/vibe/ui-ux-data/ux-guidelines.csv +99 -99
- package/vibe/ui-ux-data/version.json +31 -31
- package/vibe/ui-ux-data/web-interface.csv +31 -31
|
@@ -1,118 +1,118 @@
|
|
|
1
|
-
# Failure Analysis: {{FAILURE_TITLE}}
|
|
2
|
-
|
|
3
|
-
**Date**: {{DATE}}
|
|
4
|
-
**Reporter**: {{REPORTER}}
|
|
5
|
-
**Occurrence count**: {{OCCURRENCE_COUNT}}
|
|
6
|
-
**First seen**: {{FIRST_SEEN_DATE}}
|
|
7
|
-
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
## Failure Description
|
|
11
|
-
|
|
12
|
-
**What happened:**
|
|
13
|
-
{{FAILURE_DESCRIPTION}}
|
|
14
|
-
|
|
15
|
-
**Expected behavior:**
|
|
16
|
-
{{EXPECTED_BEHAVIOR}}
|
|
17
|
-
|
|
18
|
-
**Actual behavior:**
|
|
19
|
-
{{ACTUAL_BEHAVIOR}}
|
|
20
|
-
|
|
21
|
-
**Reproduction steps:**
|
|
22
|
-
1. {{STEP_1}}
|
|
23
|
-
2. {{STEP_2}}
|
|
24
|
-
3. {{STEP_3}}
|
|
25
|
-
|
|
26
|
-
---
|
|
27
|
-
|
|
28
|
-
## Diagnosis
|
|
29
|
-
|
|
30
|
-
Answer all five questions:
|
|
31
|
-
|
|
32
|
-
### 1. Missing Tool?
|
|
33
|
-
> Did the agent lack a command, API, or utility to accomplish the task?
|
|
34
|
-
|
|
35
|
-
{{TOOL_DIAGNOSIS}}
|
|
36
|
-
|
|
37
|
-
- Missing: {{MISSING_TOOL_OR_NONE}}
|
|
38
|
-
- Where to build: {{TOOL_BUILD_LOCATION_OR_NA}}
|
|
39
|
-
|
|
40
|
-
### 2. Missing Guardrail?
|
|
41
|
-
> Should the agent have been prevented from doing this?
|
|
42
|
-
|
|
43
|
-
{{GUARDRAIL_DIAGNOSIS}}
|
|
44
|
-
|
|
45
|
-
- Missing: {{MISSING_GUARDRAIL_OR_NONE}}
|
|
46
|
-
- Where to build: {{GUARDRAIL_BUILD_LOCATION_OR_NA}}
|
|
47
|
-
|
|
48
|
-
### 3. Missing Abstraction?
|
|
49
|
-
> Was the agent repeating work that should be shared code?
|
|
50
|
-
|
|
51
|
-
{{ABSTRACTION_DIAGNOSIS}}
|
|
52
|
-
|
|
53
|
-
- Missing: {{MISSING_ABSTRACTION_OR_NONE}}
|
|
54
|
-
- Where to build: {{ABSTRACTION_BUILD_LOCATION_OR_NA}}
|
|
55
|
-
|
|
56
|
-
### 4. Missing Documentation?
|
|
57
|
-
> Did the agent lack knowledge that should be discoverable?
|
|
58
|
-
|
|
59
|
-
{{DOCUMENTATION_DIAGNOSIS}}
|
|
60
|
-
|
|
61
|
-
- Missing: {{MISSING_DOC_OR_NONE}}
|
|
62
|
-
- Where to add: {{DOC_LOCATION_OR_NA}}
|
|
63
|
-
|
|
64
|
-
### 5. Missing Feedback?
|
|
65
|
-
> Did the agent not know it was doing the wrong thing?
|
|
66
|
-
|
|
67
|
-
{{FEEDBACK_DIAGNOSIS}}
|
|
68
|
-
|
|
69
|
-
- Missing: {{MISSING_FEEDBACK_OR_NONE}}
|
|
70
|
-
- Where to add: {{FEEDBACK_LOCATION_OR_NA}}
|
|
71
|
-
|
|
72
|
-
---
|
|
73
|
-
|
|
74
|
-
## Root Cause
|
|
75
|
-
|
|
76
|
-
**Primary category**: {{TOOL | GUARDRAIL | ABSTRACTION | DOCUMENTATION | FEEDBACK}}
|
|
77
|
-
|
|
78
|
-
**Root cause statement**: {{ROOT_CAUSE_ONE_SENTENCE}}
|
|
79
|
-
|
|
80
|
-
**Contributing factors:**
|
|
81
|
-
- {{FACTOR_1}}
|
|
82
|
-
- {{FACTOR_2}}
|
|
83
|
-
|
|
84
|
-
---
|
|
85
|
-
|
|
86
|
-
## Capability to Build
|
|
87
|
-
|
|
88
|
-
**Capability name**: `{{CAPABILITY_NAME}}`
|
|
89
|
-
|
|
90
|
-
**What to build**: {{CAPABILITY_DESCRIPTION}}
|
|
91
|
-
|
|
92
|
-
**Build plan:**
|
|
93
|
-
1. {{BUILD_STEP_1}}
|
|
94
|
-
2. {{BUILD_STEP_2}}
|
|
95
|
-
3. {{BUILD_STEP_3}}
|
|
96
|
-
|
|
97
|
-
**Files to create/modify:**
|
|
98
|
-
- `{{FILE_1}}` — {{FILE_1_PURPOSE}}
|
|
99
|
-
- `{{FILE_2}}` — {{FILE_2_PURPOSE}}
|
|
100
|
-
|
|
101
|
-
---
|
|
102
|
-
|
|
103
|
-
## Verification
|
|
104
|
-
|
|
105
|
-
- [ ] Original failure reproduced before fix
|
|
106
|
-
- [ ] New capability prevents the failure
|
|
107
|
-
- [ ] Existing tests still pass
|
|
108
|
-
- [ ] New test added that would catch this failure class
|
|
109
|
-
|
|
110
|
-
---
|
|
111
|
-
|
|
112
|
-
## Prevents
|
|
113
|
-
|
|
114
|
-
This capability prevents the following class of failures:
|
|
115
|
-
|
|
116
|
-
> {{FAILURE_CLASS_DESCRIPTION}}
|
|
117
|
-
|
|
118
|
-
Estimated recurrence if not built: {{HIGH | MEDIUM | LOW}}
|
|
1
|
+
# Failure Analysis: {{FAILURE_TITLE}}
|
|
2
|
+
|
|
3
|
+
**Date**: {{DATE}}
|
|
4
|
+
**Reporter**: {{REPORTER}}
|
|
5
|
+
**Occurrence count**: {{OCCURRENCE_COUNT}}
|
|
6
|
+
**First seen**: {{FIRST_SEEN_DATE}}
|
|
7
|
+
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
## Failure Description
|
|
11
|
+
|
|
12
|
+
**What happened:**
|
|
13
|
+
{{FAILURE_DESCRIPTION}}
|
|
14
|
+
|
|
15
|
+
**Expected behavior:**
|
|
16
|
+
{{EXPECTED_BEHAVIOR}}
|
|
17
|
+
|
|
18
|
+
**Actual behavior:**
|
|
19
|
+
{{ACTUAL_BEHAVIOR}}
|
|
20
|
+
|
|
21
|
+
**Reproduction steps:**
|
|
22
|
+
1. {{STEP_1}}
|
|
23
|
+
2. {{STEP_2}}
|
|
24
|
+
3. {{STEP_3}}
|
|
25
|
+
|
|
26
|
+
---
|
|
27
|
+
|
|
28
|
+
## Diagnosis
|
|
29
|
+
|
|
30
|
+
Answer all five questions:
|
|
31
|
+
|
|
32
|
+
### 1. Missing Tool?
|
|
33
|
+
> Did the agent lack a command, API, or utility to accomplish the task?
|
|
34
|
+
|
|
35
|
+
{{TOOL_DIAGNOSIS}}
|
|
36
|
+
|
|
37
|
+
- Missing: {{MISSING_TOOL_OR_NONE}}
|
|
38
|
+
- Where to build: {{TOOL_BUILD_LOCATION_OR_NA}}
|
|
39
|
+
|
|
40
|
+
### 2. Missing Guardrail?
|
|
41
|
+
> Should the agent have been prevented from doing this?
|
|
42
|
+
|
|
43
|
+
{{GUARDRAIL_DIAGNOSIS}}
|
|
44
|
+
|
|
45
|
+
- Missing: {{MISSING_GUARDRAIL_OR_NONE}}
|
|
46
|
+
- Where to build: {{GUARDRAIL_BUILD_LOCATION_OR_NA}}
|
|
47
|
+
|
|
48
|
+
### 3. Missing Abstraction?
|
|
49
|
+
> Was the agent repeating work that should be shared code?
|
|
50
|
+
|
|
51
|
+
{{ABSTRACTION_DIAGNOSIS}}
|
|
52
|
+
|
|
53
|
+
- Missing: {{MISSING_ABSTRACTION_OR_NONE}}
|
|
54
|
+
- Where to build: {{ABSTRACTION_BUILD_LOCATION_OR_NA}}
|
|
55
|
+
|
|
56
|
+
### 4. Missing Documentation?
|
|
57
|
+
> Did the agent lack knowledge that should be discoverable?
|
|
58
|
+
|
|
59
|
+
{{DOCUMENTATION_DIAGNOSIS}}
|
|
60
|
+
|
|
61
|
+
- Missing: {{MISSING_DOC_OR_NONE}}
|
|
62
|
+
- Where to add: {{DOC_LOCATION_OR_NA}}
|
|
63
|
+
|
|
64
|
+
### 5. Missing Feedback?
|
|
65
|
+
> Did the agent not know it was doing the wrong thing?
|
|
66
|
+
|
|
67
|
+
{{FEEDBACK_DIAGNOSIS}}
|
|
68
|
+
|
|
69
|
+
- Missing: {{MISSING_FEEDBACK_OR_NONE}}
|
|
70
|
+
- Where to add: {{FEEDBACK_LOCATION_OR_NA}}
|
|
71
|
+
|
|
72
|
+
---
|
|
73
|
+
|
|
74
|
+
## Root Cause
|
|
75
|
+
|
|
76
|
+
**Primary category**: {{TOOL | GUARDRAIL | ABSTRACTION | DOCUMENTATION | FEEDBACK}}
|
|
77
|
+
|
|
78
|
+
**Root cause statement**: {{ROOT_CAUSE_ONE_SENTENCE}}
|
|
79
|
+
|
|
80
|
+
**Contributing factors:**
|
|
81
|
+
- {{FACTOR_1}}
|
|
82
|
+
- {{FACTOR_2}}
|
|
83
|
+
|
|
84
|
+
---
|
|
85
|
+
|
|
86
|
+
## Capability to Build
|
|
87
|
+
|
|
88
|
+
**Capability name**: `{{CAPABILITY_NAME}}`
|
|
89
|
+
|
|
90
|
+
**What to build**: {{CAPABILITY_DESCRIPTION}}
|
|
91
|
+
|
|
92
|
+
**Build plan:**
|
|
93
|
+
1. {{BUILD_STEP_1}}
|
|
94
|
+
2. {{BUILD_STEP_2}}
|
|
95
|
+
3. {{BUILD_STEP_3}}
|
|
96
|
+
|
|
97
|
+
**Files to create/modify:**
|
|
98
|
+
- `{{FILE_1}}` — {{FILE_1_PURPOSE}}
|
|
99
|
+
- `{{FILE_2}}` — {{FILE_2_PURPOSE}}
|
|
100
|
+
|
|
101
|
+
---
|
|
102
|
+
|
|
103
|
+
## Verification
|
|
104
|
+
|
|
105
|
+
- [ ] Original failure reproduced before fix
|
|
106
|
+
- [ ] New capability prevents the failure
|
|
107
|
+
- [ ] Existing tests still pass
|
|
108
|
+
- [ ] New test added that would catch this failure class
|
|
109
|
+
|
|
110
|
+
---
|
|
111
|
+
|
|
112
|
+
## Prevents
|
|
113
|
+
|
|
114
|
+
This capability prevents the following class of failures:
|
|
115
|
+
|
|
116
|
+
> {{FAILURE_CLASS_DESCRIPTION}}
|
|
117
|
+
|
|
118
|
+
Estimated recurrence if not built: {{HIGH | MEDIUM | LOW}}
|
|
@@ -1,207 +1,207 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: characterization-test
|
|
3
|
-
tier: core
|
|
4
|
-
description: "Lock existing behavior with characterization tests before modifying code. Use BEFORE any refactor, rewrite, or large-scale modification of existing code — especially legacy code without tests. Captures current input/output behavior as test cases so regressions are caught immediately. Must use this skill when touching files >200 lines with no existing tests, when user says 'refactor', 'rewrite', 'modernize', or 'clean up' existing code."
|
|
5
|
-
triggers: [legacy, characterization test, lock behavior, regression prevention, before refactor, large file]
|
|
6
|
-
priority: 65
|
|
7
|
-
---
|
|
8
|
-
|
|
9
|
-
# Characterization Test Skill
|
|
10
|
-
|
|
11
|
-
> **Philosophy: "Never change what you cannot verify"**
|
|
12
|
-
|
|
13
|
-
Lock existing behavior with snapshot/characterization tests before modifying code. This prevents regressions in legacy, complex, or unfamiliar codebases.
|
|
14
|
-
|
|
15
|
-
## Pre-check (K1)
|
|
16
|
-
|
|
17
|
-
> Are you modifying existing code with uncertain behavior? If the code is new (you just wrote it), well-tested, or trivially simple, skip characterization tests and write regular unit tests instead.
|
|
18
|
-
|
|
19
|
-
## When to Use
|
|
20
|
-
|
|
21
|
-
| Scenario | Signal |
|
|
22
|
-
|----------|--------|
|
|
23
|
-
| Legacy file (>500 lines) | Large files with accumulated behavior |
|
|
24
|
-
| Complex branching | Multiple if/else, switch, ternary chains |
|
|
25
|
-
| API endpoint modification | Request/response contract must be preserved |
|
|
26
|
-
| Database schema change | Migration must preserve existing data semantics |
|
|
27
|
-
| Refactoring request | "refactor", "clean up", "simplify" keywords |
|
|
28
|
-
| Unfamiliar code | No prior context about the module |
|
|
29
|
-
|
|
30
|
-
## Core Workflow
|
|
31
|
-
|
|
32
|
-
```
|
|
33
|
-
ANALYZE → GENERATE → VERIFY → CHANGE → REGRESS → RECONCILE
|
|
34
|
-
```
|
|
35
|
-
|
|
36
|
-
### Step 1: ANALYZE
|
|
37
|
-
|
|
38
|
-
Explore the target code to understand its current behavior.
|
|
39
|
-
|
|
40
|
-
**Parallel exploration** (use sub-agents when available):
|
|
41
|
-
- Read the target file(s)
|
|
42
|
-
- Identify all public exports / API surface
|
|
43
|
-
- Map branching paths (if/else, switch, try/catch)
|
|
44
|
-
- List external dependencies and side effects
|
|
45
|
-
- Check for existing tests
|
|
46
|
-
|
|
47
|
-
**Analysis checklist:**
|
|
48
|
-
- [ ] All public functions identified
|
|
49
|
-
- [ ] Input parameter ranges documented
|
|
50
|
-
- [ ] Edge cases listed (null, empty, boundary values)
|
|
51
|
-
- [ ] Side effects cataloged (DB writes, file I/O, network calls)
|
|
52
|
-
- [ ] Error paths mapped
|
|
53
|
-
|
|
54
|
-
### Step 2: GENERATE
|
|
55
|
-
|
|
56
|
-
Create characterization tests that capture current behavior as-is.
|
|
57
|
-
|
|
58
|
-
**TypeScript template:**
|
|
59
|
-
```typescript
|
|
60
|
-
import { describe, it, expect } from 'vitest';
|
|
61
|
-
|
|
62
|
-
describe('[ModuleName] characterization tests', () => {
|
|
63
|
-
// Happy path - capture normal behavior
|
|
64
|
-
it('should [describe current behavior]', () => {
|
|
65
|
-
const result = targetFunction(normalInput);
|
|
66
|
-
// Snapshot the ACTUAL output, not what you THINK it should be
|
|
67
|
-
expect(result).toMatchSnapshot();
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
// Edge cases - capture boundary behavior
|
|
71
|
-
it('should handle empty input', () => {
|
|
72
|
-
const result = targetFunction('');
|
|
73
|
-
expect(result).toMatchSnapshot();
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
// Error paths - capture failure modes
|
|
77
|
-
it('should handle invalid input', () => {
|
|
78
|
-
expect(() => targetFunction(null)).toThrowErrorMatchingSnapshot();
|
|
79
|
-
});
|
|
80
|
-
});
|
|
81
|
-
```
|
|
82
|
-
|
|
83
|
-
**Python template:**
|
|
84
|
-
```python
|
|
85
|
-
import pytest
|
|
86
|
-
|
|
87
|
-
class TestModuleNameCharacterization:
|
|
88
|
-
"""Lock existing behavior before modification."""
|
|
89
|
-
|
|
90
|
-
def test_normal_behavior(self, snapshot):
|
|
91
|
-
result = target_function(normal_input)
|
|
92
|
-
assert result == snapshot
|
|
93
|
-
|
|
94
|
-
def test_empty_input(self, snapshot):
|
|
95
|
-
result = target_function("")
|
|
96
|
-
assert result == snapshot
|
|
97
|
-
|
|
98
|
-
def test_invalid_input(self):
|
|
99
|
-
with pytest.raises(Exception) as exc_info:
|
|
100
|
-
target_function(None)
|
|
101
|
-
assert str(exc_info.value) # Capture error message
|
|
102
|
-
```
|
|
103
|
-
|
|
104
|
-
**Key principles:**
|
|
105
|
-
- Test ACTUAL behavior, not expected behavior
|
|
106
|
-
- Use `toMatchSnapshot()` / snapshot assertions
|
|
107
|
-
- Cover every public function
|
|
108
|
-
- Include edge cases and error paths
|
|
109
|
-
- Do NOT fix bugs in characterization tests
|
|
110
|
-
|
|
111
|
-
### Step 3: VERIFY
|
|
112
|
-
|
|
113
|
-
Run the characterization tests to confirm they pass with current code.
|
|
114
|
-
|
|
115
|
-
```bash
|
|
116
|
-
# TypeScript
|
|
117
|
-
npx vitest run --reporter=verbose [test-file]
|
|
118
|
-
|
|
119
|
-
# Python
|
|
120
|
-
pytest -v [test-file]
|
|
121
|
-
```
|
|
122
|
-
|
|
123
|
-
- All tests MUST pass before proceeding
|
|
124
|
-
- If any test fails, the characterization is wrong — fix the test, not the code
|
|
125
|
-
- Update snapshots if needed: `npx vitest run -u [test-file]`
|
|
126
|
-
|
|
127
|
-
### Step 4: CHANGE
|
|
128
|
-
|
|
129
|
-
Now implement the requested modification.
|
|
130
|
-
|
|
131
|
-
- Make changes incrementally
|
|
132
|
-
- Run characterization tests after each change
|
|
133
|
-
- Any unexpected test failure = potential regression
|
|
134
|
-
|
|
135
|
-
### Step 5: REGRESS
|
|
136
|
-
|
|
137
|
-
Run full characterization test suite after all changes.
|
|
138
|
-
|
|
139
|
-
```bash
|
|
140
|
-
npx vitest run [characterization-test-file]
|
|
141
|
-
```
|
|
142
|
-
|
|
143
|
-
- **All passing**: Changes preserve existing behavior
|
|
144
|
-
- **Expected failures**: Tests for intentionally changed behavior
|
|
145
|
-
- **Unexpected failures**: STOP — investigate regression
|
|
146
|
-
|
|
147
|
-
### Step 6: RECONCILE
|
|
148
|
-
|
|
149
|
-
Update characterization tests to match new intended behavior.
|
|
150
|
-
|
|
151
|
-
- Review each failing test individually
|
|
152
|
-
- Confirm the failure is due to intentional change
|
|
153
|
-
- Update snapshot: `npx vitest run -u`
|
|
154
|
-
- Add NEW tests for new behavior
|
|
155
|
-
- Document why each test changed
|
|
156
|
-
|
|
157
|
-
## Scenario-Specific Workflows
|
|
158
|
-
|
|
159
|
-
### Legacy File (>500 lines)
|
|
160
|
-
|
|
161
|
-
1. Generate function-level characterization tests
|
|
162
|
-
2. Focus on public API surface first
|
|
163
|
-
3. Add integration tests for cross-function flows
|
|
164
|
-
4. Refactor in small increments
|
|
165
|
-
|
|
166
|
-
### Complex Branching
|
|
167
|
-
|
|
168
|
-
1. Map all branches with a decision tree
|
|
169
|
-
2. Write one test per branch path
|
|
170
|
-
3. Include boundary values for each condition
|
|
171
|
-
4. Test combinations of related conditions
|
|
172
|
-
|
|
173
|
-
### API Endpoint
|
|
174
|
-
|
|
175
|
-
1. Capture request/response pairs for all routes
|
|
176
|
-
2. Test all HTTP methods, status codes, headers
|
|
177
|
-
3. Include authentication/authorization paths
|
|
178
|
-
4. Test error responses and validation messages
|
|
179
|
-
|
|
180
|
-
### Database Schema
|
|
181
|
-
|
|
182
|
-
1. Create fixtures with representative data
|
|
183
|
-
2. Test queries before and after migration
|
|
184
|
-
3. Verify data integrity post-migration
|
|
185
|
-
4. Test rollback scenarios
|
|
186
|
-
|
|
187
|
-
## Integration with VIBE Workflow
|
|
188
|
-
|
|
189
|
-
### With `/vibe.spec`
|
|
190
|
-
Add characterization test phase to SPEC before implementation:
|
|
191
|
-
```
|
|
192
|
-
## Pre-Implementation
|
|
193
|
-
- [ ] Characterization tests written for affected modules
|
|
194
|
-
- [ ] All characterization tests passing
|
|
195
|
-
```
|
|
196
|
-
|
|
197
|
-
### With `/vibe.run`
|
|
198
|
-
The implementation agent should:
|
|
199
|
-
1. Check for characterization tests before modifying files
|
|
200
|
-
2. Run them before and after changes
|
|
201
|
-
3. Flag any unexpected failures
|
|
202
|
-
|
|
203
|
-
### With `/vibe.review`
|
|
204
|
-
Review agents verify:
|
|
205
|
-
- Characterization tests exist for modified legacy code
|
|
206
|
-
- No regressions in existing behavior
|
|
207
|
-
- New behavior has corresponding new tests
|
|
1
|
+
---
|
|
2
|
+
name: characterization-test
|
|
3
|
+
tier: core
|
|
4
|
+
description: "Lock existing behavior with characterization tests before modifying code. Use BEFORE any refactor, rewrite, or large-scale modification of existing code — especially legacy code without tests. Captures current input/output behavior as test cases so regressions are caught immediately. Must use this skill when touching files >200 lines with no existing tests, when user says 'refactor', 'rewrite', 'modernize', or 'clean up' existing code."
|
|
5
|
+
triggers: [legacy, characterization test, lock behavior, regression prevention, before refactor, large file]
|
|
6
|
+
priority: 65
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# Characterization Test Skill
|
|
10
|
+
|
|
11
|
+
> **Philosophy: "Never change what you cannot verify"**
|
|
12
|
+
|
|
13
|
+
Lock existing behavior with snapshot/characterization tests before modifying code. This prevents regressions in legacy, complex, or unfamiliar codebases.
|
|
14
|
+
|
|
15
|
+
## Pre-check (K1)
|
|
16
|
+
|
|
17
|
+
> Are you modifying existing code with uncertain behavior? If the code is new (you just wrote it), well-tested, or trivially simple, skip characterization tests and write regular unit tests instead.
|
|
18
|
+
|
|
19
|
+
## When to Use
|
|
20
|
+
|
|
21
|
+
| Scenario | Signal |
|
|
22
|
+
|----------|--------|
|
|
23
|
+
| Legacy file (>500 lines) | Large files with accumulated behavior |
|
|
24
|
+
| Complex branching | Multiple if/else, switch, ternary chains |
|
|
25
|
+
| API endpoint modification | Request/response contract must be preserved |
|
|
26
|
+
| Database schema change | Migration must preserve existing data semantics |
|
|
27
|
+
| Refactoring request | "refactor", "clean up", "simplify" keywords |
|
|
28
|
+
| Unfamiliar code | No prior context about the module |
|
|
29
|
+
|
|
30
|
+
## Core Workflow
|
|
31
|
+
|
|
32
|
+
```
|
|
33
|
+
ANALYZE → GENERATE → VERIFY → CHANGE → REGRESS → RECONCILE
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
### Step 1: ANALYZE
|
|
37
|
+
|
|
38
|
+
Explore the target code to understand its current behavior.
|
|
39
|
+
|
|
40
|
+
**Parallel exploration** (use sub-agents when available):
|
|
41
|
+
- Read the target file(s)
|
|
42
|
+
- Identify all public exports / API surface
|
|
43
|
+
- Map branching paths (if/else, switch, try/catch)
|
|
44
|
+
- List external dependencies and side effects
|
|
45
|
+
- Check for existing tests
|
|
46
|
+
|
|
47
|
+
**Analysis checklist:**
|
|
48
|
+
- [ ] All public functions identified
|
|
49
|
+
- [ ] Input parameter ranges documented
|
|
50
|
+
- [ ] Edge cases listed (null, empty, boundary values)
|
|
51
|
+
- [ ] Side effects cataloged (DB writes, file I/O, network calls)
|
|
52
|
+
- [ ] Error paths mapped
|
|
53
|
+
|
|
54
|
+
### Step 2: GENERATE
|
|
55
|
+
|
|
56
|
+
Create characterization tests that capture current behavior as-is.
|
|
57
|
+
|
|
58
|
+
**TypeScript template:**
|
|
59
|
+
```typescript
|
|
60
|
+
import { describe, it, expect } from 'vitest';
|
|
61
|
+
|
|
62
|
+
describe('[ModuleName] characterization tests', () => {
|
|
63
|
+
// Happy path - capture normal behavior
|
|
64
|
+
it('should [describe current behavior]', () => {
|
|
65
|
+
const result = targetFunction(normalInput);
|
|
66
|
+
// Snapshot the ACTUAL output, not what you THINK it should be
|
|
67
|
+
expect(result).toMatchSnapshot();
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
// Edge cases - capture boundary behavior
|
|
71
|
+
it('should handle empty input', () => {
|
|
72
|
+
const result = targetFunction('');
|
|
73
|
+
expect(result).toMatchSnapshot();
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
// Error paths - capture failure modes
|
|
77
|
+
it('should handle invalid input', () => {
|
|
78
|
+
expect(() => targetFunction(null)).toThrowErrorMatchingSnapshot();
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
**Python template:**
|
|
84
|
+
```python
|
|
85
|
+
import pytest
|
|
86
|
+
|
|
87
|
+
class TestModuleNameCharacterization:
|
|
88
|
+
"""Lock existing behavior before modification."""
|
|
89
|
+
|
|
90
|
+
def test_normal_behavior(self, snapshot):
|
|
91
|
+
result = target_function(normal_input)
|
|
92
|
+
assert result == snapshot
|
|
93
|
+
|
|
94
|
+
def test_empty_input(self, snapshot):
|
|
95
|
+
result = target_function("")
|
|
96
|
+
assert result == snapshot
|
|
97
|
+
|
|
98
|
+
def test_invalid_input(self):
|
|
99
|
+
with pytest.raises(Exception) as exc_info:
|
|
100
|
+
target_function(None)
|
|
101
|
+
assert str(exc_info.value) # Capture error message
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
**Key principles:**
|
|
105
|
+
- Test ACTUAL behavior, not expected behavior
|
|
106
|
+
- Use `toMatchSnapshot()` / snapshot assertions
|
|
107
|
+
- Cover every public function
|
|
108
|
+
- Include edge cases and error paths
|
|
109
|
+
- Do NOT fix bugs in characterization tests
|
|
110
|
+
|
|
111
|
+
### Step 3: VERIFY
|
|
112
|
+
|
|
113
|
+
Run the characterization tests to confirm they pass with current code.
|
|
114
|
+
|
|
115
|
+
```bash
|
|
116
|
+
# TypeScript
|
|
117
|
+
npx vitest run --reporter=verbose [test-file]
|
|
118
|
+
|
|
119
|
+
# Python
|
|
120
|
+
pytest -v [test-file]
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
- All tests MUST pass before proceeding
|
|
124
|
+
- If any test fails, the characterization is wrong — fix the test, not the code
|
|
125
|
+
- Update snapshots if needed: `npx vitest run -u [test-file]`
|
|
126
|
+
|
|
127
|
+
### Step 4: CHANGE
|
|
128
|
+
|
|
129
|
+
Now implement the requested modification.
|
|
130
|
+
|
|
131
|
+
- Make changes incrementally
|
|
132
|
+
- Run characterization tests after each change
|
|
133
|
+
- Any unexpected test failure = potential regression
|
|
134
|
+
|
|
135
|
+
### Step 5: REGRESS
|
|
136
|
+
|
|
137
|
+
Run full characterization test suite after all changes.
|
|
138
|
+
|
|
139
|
+
```bash
|
|
140
|
+
npx vitest run [characterization-test-file]
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
- **All passing**: Changes preserve existing behavior
|
|
144
|
+
- **Expected failures**: Tests for intentionally changed behavior
|
|
145
|
+
- **Unexpected failures**: STOP — investigate regression
|
|
146
|
+
|
|
147
|
+
### Step 6: RECONCILE
|
|
148
|
+
|
|
149
|
+
Update characterization tests to match new intended behavior.
|
|
150
|
+
|
|
151
|
+
- Review each failing test individually
|
|
152
|
+
- Confirm the failure is due to intentional change
|
|
153
|
+
- Update snapshot: `npx vitest run -u`
|
|
154
|
+
- Add NEW tests for new behavior
|
|
155
|
+
- Document why each test changed
|
|
156
|
+
|
|
157
|
+
## Scenario-Specific Workflows
|
|
158
|
+
|
|
159
|
+
### Legacy File (>500 lines)
|
|
160
|
+
|
|
161
|
+
1. Generate function-level characterization tests
|
|
162
|
+
2. Focus on public API surface first
|
|
163
|
+
3. Add integration tests for cross-function flows
|
|
164
|
+
4. Refactor in small increments
|
|
165
|
+
|
|
166
|
+
### Complex Branching
|
|
167
|
+
|
|
168
|
+
1. Map all branches with a decision tree
|
|
169
|
+
2. Write one test per branch path
|
|
170
|
+
3. Include boundary values for each condition
|
|
171
|
+
4. Test combinations of related conditions
|
|
172
|
+
|
|
173
|
+
### API Endpoint
|
|
174
|
+
|
|
175
|
+
1. Capture request/response pairs for all routes
|
|
176
|
+
2. Test all HTTP methods, status codes, headers
|
|
177
|
+
3. Include authentication/authorization paths
|
|
178
|
+
4. Test error responses and validation messages
|
|
179
|
+
|
|
180
|
+
### Database Schema
|
|
181
|
+
|
|
182
|
+
1. Create fixtures with representative data
|
|
183
|
+
2. Test queries before and after migration
|
|
184
|
+
3. Verify data integrity post-migration
|
|
185
|
+
4. Test rollback scenarios
|
|
186
|
+
|
|
187
|
+
## Integration with VIBE Workflow
|
|
188
|
+
|
|
189
|
+
### With `/vibe.spec`
|
|
190
|
+
Add characterization test phase to SPEC before implementation:
|
|
191
|
+
```
|
|
192
|
+
## Pre-Implementation
|
|
193
|
+
- [ ] Characterization tests written for affected modules
|
|
194
|
+
- [ ] All characterization tests passing
|
|
195
|
+
```
|
|
196
|
+
|
|
197
|
+
### With `/vibe.run`
|
|
198
|
+
The implementation agent should:
|
|
199
|
+
1. Check for characterization tests before modifying files
|
|
200
|
+
2. Run them before and after changes
|
|
201
|
+
3. Flag any unexpected failures
|
|
202
|
+
|
|
203
|
+
### With `/vibe.review`
|
|
204
|
+
Review agents verify:
|
|
205
|
+
- Characterization tests exist for modified legacy code
|
|
206
|
+
- No regressions in existing behavior
|
|
207
|
+
- New behavior has corresponding new tests
|