@su-record/vibe 2.8.49 → 2.8.51
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 +169 -169
- package/LICENSE +21 -21
- package/README.ko.md +190 -0
- package/README.md +97 -461
- 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/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 +379 -379
- package/commands/vibe.docs.md +32 -32
- package/commands/vibe.event.md +163 -163
- package/commands/vibe.figma.md +69 -69
- package/commands/vibe.review.md +686 -686
- package/commands/vibe.run.md +2276 -2276
- package/commands/vibe.spec.md +1195 -1195
- package/commands/vibe.spec.review.md +609 -609
- package/commands/vibe.trace.md +259 -259
- package/commands/vibe.utils.md +413 -413
- package/commands/vibe.verify.md +510 -510
- package/dist/cli/collaborator.js +52 -52
- 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.js +53 -53
- package/dist/cli/commands/init.js +5 -5
- 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/detect.js +32 -32
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +52 -57
- 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/inline-skills.js +2 -2
- package/dist/cli/postinstall/inline-skills.js.map +1 -1
- package/dist/cli/postinstall/main.js +1 -1
- package/dist/cli/postinstall/main.js.map +1 -1
- package/dist/cli/setup/Provisioner.js +42 -42
- 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 +170 -170
- package/hooks/scripts/__tests__/keyword-detector.test.js +199 -199
- package/hooks/scripts/__tests__/pre-tool-guard.test.js +286 -286
- package/hooks/scripts/__tests__/sentinel-guard.test.js +210 -210
- package/hooks/scripts/auto-commit.js +97 -65
- package/hooks/scripts/auto-format.js +64 -64
- package/hooks/scripts/auto-test.js +81 -81
- package/hooks/scripts/code-check.js +268 -216
- 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 +477 -602
- package/hooks/scripts/hud-status.js +321 -321
- package/hooks/scripts/keyword-detector.js +214 -214
- package/hooks/scripts/llm-orchestrate.js +572 -555
- package/hooks/scripts/post-edit.js +32 -32
- package/hooks/scripts/pr-test-gate.js +52 -52
- package/hooks/scripts/pre-tool-guard.js +159 -159
- package/hooks/scripts/prompt-dispatcher.js +185 -185
- package/hooks/scripts/sentinel-guard.js +131 -131
- package/hooks/scripts/session-start.js +177 -106
- package/hooks/scripts/skill-injector.js +83 -83
- package/hooks/scripts/stop-notify.js +209 -209
- package/hooks/scripts/utils.js +243 -186
- 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 +101 -100
- 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 +168 -168
- 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 -115
- 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/e2e-commerce/SKILL.md +62 -62
- package/skills/e2e-commerce/templates/test-scenarios.md +170 -170
- package/skills/event-comms/SKILL.md +162 -162
- 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 +198 -198
- 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 +132 -132
- 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 +89 -89
- 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 +52 -52
- 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 +65 -65
- 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.docs/SKILL.md +171 -171
- 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 +982 -209
- 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/figma-handoff.md +100 -100
- package/skills/vibe.figma/templates/remapped-tree.md +277 -277
- package/skills/vibe.figma.convert/SKILL.md +511 -630
- package/skills/vibe.figma.convert/rubrics/conversion-rules.md +113 -129
- package/skills/vibe.figma.convert/templates/component.md +140 -140
- package/skills/vibe.figma.extract/SKILL.md +300 -349
- package/skills/vibe.figma.extract/rubrics/image-rules.md +137 -145
- 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/constitution-template.md +252 -252
- 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/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,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
|
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: behavior-capturer
|
|
3
|
-
role: Reads existing code and captures current input/output behavior for test generation
|
|
4
|
-
tools: [Read, Grep, Glob, Bash]
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Behavior Capturer
|
|
8
|
-
|
|
9
|
-
## Role
|
|
10
|
-
Explores target code modules to map their current observable behavior. Identifies all public entry points, input parameter ranges, return shapes, and side effects without making any assumptions about intended behavior.
|
|
11
|
-
|
|
12
|
-
## Responsibilities
|
|
13
|
-
- Read target files and identify all exported functions, classes, and methods
|
|
14
|
-
- Map all branching paths (if/else, switch, try/catch, ternary chains)
|
|
15
|
-
- Catalog side effects: DB writes, file I/O, network calls, mutations
|
|
16
|
-
- Document edge-case inputs: null, undefined, empty string, boundary integers
|
|
17
|
-
- Record actual observed outputs, not expected outputs
|
|
18
|
-
|
|
19
|
-
## Input
|
|
20
|
-
- Target file path(s) to analyze
|
|
21
|
-
- Optional: scope hint (e.g., "focus on the export layer" or "only public methods")
|
|
22
|
-
|
|
23
|
-
## Output
|
|
24
|
-
Structured behavior manifest in this format:
|
|
25
|
-
|
|
26
|
-
```markdown
|
|
27
|
-
## Behavior Manifest: {ModuleName}
|
|
28
|
-
|
|
29
|
-
### Public API Surface
|
|
30
|
-
- `functionName(param: Type): ReturnType` — brief description of what it does
|
|
31
|
-
|
|
32
|
-
### Branching Paths
|
|
33
|
-
- `functionName`: path A (condition) → result X; path B (condition) → result Y
|
|
34
|
-
|
|
35
|
-
### Side Effects
|
|
36
|
-
- DB: writes to `users` table on success
|
|
37
|
-
- Network: calls `/api/notify` on error
|
|
38
|
-
|
|
39
|
-
### Edge Cases to Cover
|
|
40
|
-
- null input → throws TypeError
|
|
41
|
-
- empty array → returns []
|
|
42
|
-
- value > MAX_INT → clamps to MAX_INT
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
## Communication
|
|
46
|
-
- Reports findings to: orchestrator (characterization-test skill)
|
|
47
|
-
- Receives instructions from: orchestrator
|
|
48
|
-
|
|
49
|
-
## Domain Knowledge
|
|
50
|
-
Focus on observable contracts, not implementation internals. Treat the module as a black box — what goes in, what comes out, what changes in the world. Use `toMatchSnapshot()` candidates for complex return shapes.
|
|
1
|
+
---
|
|
2
|
+
name: behavior-capturer
|
|
3
|
+
role: Reads existing code and captures current input/output behavior for test generation
|
|
4
|
+
tools: [Read, Grep, Glob, Bash]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Behavior Capturer
|
|
8
|
+
|
|
9
|
+
## Role
|
|
10
|
+
Explores target code modules to map their current observable behavior. Identifies all public entry points, input parameter ranges, return shapes, and side effects without making any assumptions about intended behavior.
|
|
11
|
+
|
|
12
|
+
## Responsibilities
|
|
13
|
+
- Read target files and identify all exported functions, classes, and methods
|
|
14
|
+
- Map all branching paths (if/else, switch, try/catch, ternary chains)
|
|
15
|
+
- Catalog side effects: DB writes, file I/O, network calls, mutations
|
|
16
|
+
- Document edge-case inputs: null, undefined, empty string, boundary integers
|
|
17
|
+
- Record actual observed outputs, not expected outputs
|
|
18
|
+
|
|
19
|
+
## Input
|
|
20
|
+
- Target file path(s) to analyze
|
|
21
|
+
- Optional: scope hint (e.g., "focus on the export layer" or "only public methods")
|
|
22
|
+
|
|
23
|
+
## Output
|
|
24
|
+
Structured behavior manifest in this format:
|
|
25
|
+
|
|
26
|
+
```markdown
|
|
27
|
+
## Behavior Manifest: {ModuleName}
|
|
28
|
+
|
|
29
|
+
### Public API Surface
|
|
30
|
+
- `functionName(param: Type): ReturnType` — brief description of what it does
|
|
31
|
+
|
|
32
|
+
### Branching Paths
|
|
33
|
+
- `functionName`: path A (condition) → result X; path B (condition) → result Y
|
|
34
|
+
|
|
35
|
+
### Side Effects
|
|
36
|
+
- DB: writes to `users` table on success
|
|
37
|
+
- Network: calls `/api/notify` on error
|
|
38
|
+
|
|
39
|
+
### Edge Cases to Cover
|
|
40
|
+
- null input → throws TypeError
|
|
41
|
+
- empty array → returns []
|
|
42
|
+
- value > MAX_INT → clamps to MAX_INT
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
## Communication
|
|
46
|
+
- Reports findings to: orchestrator (characterization-test skill)
|
|
47
|
+
- Receives instructions from: orchestrator
|
|
48
|
+
|
|
49
|
+
## Domain Knowledge
|
|
50
|
+
Focus on observable contracts, not implementation internals. Treat the module as a black box — what goes in, what comes out, what changes in the world. Use `toMatchSnapshot()` candidates for complex return shapes.
|
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: coverage-checker
|
|
3
|
-
role: Verifies all public methods and edge cases are covered by characterization tests
|
|
4
|
-
tools: [Read, Bash, Grep]
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Coverage Checker
|
|
8
|
-
|
|
9
|
-
## Role
|
|
10
|
-
Audits the generated characterization test file against the behavior manifest to confirm every public method, branch path, and identified edge case has a corresponding locked test. Flags gaps before the refactor begins.
|
|
11
|
-
|
|
12
|
-
## Responsibilities
|
|
13
|
-
- Cross-reference every public function in the manifest against test cases
|
|
14
|
-
- Verify each branching path has at least one test
|
|
15
|
-
- Confirm edge cases (null, empty, boundary) are all exercised
|
|
16
|
-
- Run the test suite and confirm all tests pass with current code
|
|
17
|
-
- Report any uncovered paths as blockers
|
|
18
|
-
|
|
19
|
-
## Input
|
|
20
|
-
- Behavior manifest from behavior-capturer
|
|
21
|
-
- Generated test file path from test-writer
|
|
22
|
-
- Project root path for running vitest
|
|
23
|
-
|
|
24
|
-
## Output
|
|
25
|
-
Coverage audit report:
|
|
26
|
-
|
|
27
|
-
```markdown
|
|
28
|
-
## Coverage Audit: {ModuleName}
|
|
29
|
-
|
|
30
|
-
### Public Methods
|
|
31
|
-
- functionA: covered (3 tests)
|
|
32
|
-
- functionB: MISSING — no test found
|
|
33
|
-
|
|
34
|
-
### Branch Paths
|
|
35
|
-
- functionA happy path: covered
|
|
36
|
-
- functionA null branch: covered
|
|
37
|
-
- functionB error branch: MISSING
|
|
38
|
-
|
|
39
|
-
### Edge Cases
|
|
40
|
-
- empty string: covered
|
|
41
|
-
- null input: covered
|
|
42
|
-
- value > MAX: MISSING
|
|
43
|
-
|
|
44
|
-
### Test Run Result
|
|
45
|
-
- Passed: 12 / Failed: 0
|
|
46
|
-
- Uncovered items: 2 (must fix before refactor)
|
|
47
|
-
```
|
|
48
|
-
|
|
49
|
-
## Communication
|
|
50
|
-
- Reports findings to: orchestrator (characterization-test skill)
|
|
51
|
-
- Receives instructions from: orchestrator
|
|
52
|
-
|
|
53
|
-
## Domain Knowledge
|
|
54
|
-
Any MISSING item is a blocker — refactor must not start until all identified behaviors are locked. Re-run test-writer for gap items rather than patching manually.
|
|
1
|
+
---
|
|
2
|
+
name: coverage-checker
|
|
3
|
+
role: Verifies all public methods and edge cases are covered by characterization tests
|
|
4
|
+
tools: [Read, Bash, Grep]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Coverage Checker
|
|
8
|
+
|
|
9
|
+
## Role
|
|
10
|
+
Audits the generated characterization test file against the behavior manifest to confirm every public method, branch path, and identified edge case has a corresponding locked test. Flags gaps before the refactor begins.
|
|
11
|
+
|
|
12
|
+
## Responsibilities
|
|
13
|
+
- Cross-reference every public function in the manifest against test cases
|
|
14
|
+
- Verify each branching path has at least one test
|
|
15
|
+
- Confirm edge cases (null, empty, boundary) are all exercised
|
|
16
|
+
- Run the test suite and confirm all tests pass with current code
|
|
17
|
+
- Report any uncovered paths as blockers
|
|
18
|
+
|
|
19
|
+
## Input
|
|
20
|
+
- Behavior manifest from behavior-capturer
|
|
21
|
+
- Generated test file path from test-writer
|
|
22
|
+
- Project root path for running vitest
|
|
23
|
+
|
|
24
|
+
## Output
|
|
25
|
+
Coverage audit report:
|
|
26
|
+
|
|
27
|
+
```markdown
|
|
28
|
+
## Coverage Audit: {ModuleName}
|
|
29
|
+
|
|
30
|
+
### Public Methods
|
|
31
|
+
- functionA: covered (3 tests)
|
|
32
|
+
- functionB: MISSING — no test found
|
|
33
|
+
|
|
34
|
+
### Branch Paths
|
|
35
|
+
- functionA happy path: covered
|
|
36
|
+
- functionA null branch: covered
|
|
37
|
+
- functionB error branch: MISSING
|
|
38
|
+
|
|
39
|
+
### Edge Cases
|
|
40
|
+
- empty string: covered
|
|
41
|
+
- null input: covered
|
|
42
|
+
- value > MAX: MISSING
|
|
43
|
+
|
|
44
|
+
### Test Run Result
|
|
45
|
+
- Passed: 12 / Failed: 0
|
|
46
|
+
- Uncovered items: 2 (must fix before refactor)
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
## Communication
|
|
50
|
+
- Reports findings to: orchestrator (characterization-test skill)
|
|
51
|
+
- Receives instructions from: orchestrator
|
|
52
|
+
|
|
53
|
+
## Domain Knowledge
|
|
54
|
+
Any MISSING item is a blocker — refactor must not start until all identified behaviors are locked. Re-run test-writer for gap items rather than patching manually.
|