claude-code-pilot 2.0.0 → 3.1.0
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/README.md +76 -97
- package/bin/install.js +267 -250
- package/manifest.json +5 -18
- package/package.json +5 -7
- package/src/agents/build-error-resolver.md +114 -0
- package/src/agents/ccp-advisor-researcher.md +104 -0
- package/src/agents/ccp-assumptions-analyzer.md +105 -0
- package/{gsd/agents/gsd-codebase-mapper.md → src/agents/ccp-codebase-mapper.md} +7 -7
- package/{gsd/agents/gsd-debugger.md → src/agents/ccp-debugger.md} +125 -8
- package/{gsd/agents/gsd-executor.md → src/agents/ccp-executor.md} +31 -20
- package/{gsd/agents/gsd-integration-checker.md → src/agents/ccp-integration-checker.md} +2 -2
- package/{gsd/agents/gsd-nyquist-auditor.md → src/agents/ccp-nyquist-auditor.md} +3 -3
- package/{gsd/agents/gsd-phase-researcher.md → src/agents/ccp-phase-researcher.md} +127 -13
- package/{gsd/agents/gsd-plan-checker.md → src/agents/ccp-plan-checker.md} +57 -21
- package/{gsd/agents/gsd-planner.md → src/agents/ccp-planner.md} +61 -23
- package/{gsd/agents/gsd-project-researcher.md → src/agents/ccp-project-researcher.md} +33 -6
- package/{gsd/agents/gsd-research-synthesizer.md → src/agents/ccp-research-synthesizer.md} +11 -11
- package/{gsd/agents/gsd-roadmapper.md → src/agents/ccp-roadmapper.md} +39 -10
- package/src/agents/ccp-ui-auditor.md +439 -0
- package/src/agents/ccp-ui-checker.md +300 -0
- package/src/agents/ccp-ui-researcher.md +357 -0
- package/{gsd/agents/gsd-verifier.md → src/agents/ccp-verifier.md} +81 -15
- package/src/agents/cpp-build-resolver.md +90 -0
- package/src/agents/cpp-reviewer.md +72 -0
- package/src/agents/database-reviewer.md +91 -0
- package/{ecc → src}/agents/doc-updater.md +1 -1
- package/src/agents/docs-lookup.md +68 -0
- package/src/agents/flutter-reviewer.md +243 -0
- package/src/agents/gan-evaluator.md +209 -0
- package/src/agents/gan-generator.md +131 -0
- package/src/agents/gan-planner.md +99 -0
- package/src/agents/go-build-resolver.md +94 -0
- package/src/agents/go-reviewer.md +76 -0
- package/src/agents/harness-optimizer.md +35 -0
- package/src/agents/java-build-resolver.md +153 -0
- package/src/agents/java-reviewer.md +92 -0
- package/src/agents/kotlin-build-resolver.md +118 -0
- package/src/agents/kotlin-reviewer.md +159 -0
- package/src/agents/loop-operator.md +36 -0
- package/src/agents/opensource-forker.md +198 -0
- package/src/agents/opensource-packager.md +249 -0
- package/src/agents/opensource-sanitizer.md +188 -0
- package/src/agents/performance-optimizer.md +446 -0
- package/src/agents/planner.md +212 -0
- package/src/agents/python-reviewer.md +98 -0
- package/src/agents/pytorch-build-resolver.md +120 -0
- package/src/agents/refactor-cleaner.md +85 -0
- package/src/agents/rust-build-resolver.md +148 -0
- package/src/agents/rust-reviewer.md +94 -0
- package/src/agents/typescript-reviewer.md +112 -0
- package/src/available-rules/README.md +80 -0
- package/src/available-rules/cpp/coding-style.md +44 -0
- package/src/available-rules/cpp/hooks.md +39 -0
- package/src/available-rules/cpp/patterns.md +51 -0
- package/src/available-rules/cpp/security.md +51 -0
- package/src/available-rules/cpp/testing.md +44 -0
- package/src/available-rules/csharp/coding-style.md +72 -0
- package/src/available-rules/csharp/hooks.md +25 -0
- package/src/available-rules/csharp/patterns.md +50 -0
- package/src/available-rules/csharp/security.md +58 -0
- package/src/available-rules/csharp/testing.md +46 -0
- package/src/available-rules/java/coding-style.md +114 -0
- package/src/available-rules/java/hooks.md +18 -0
- package/src/available-rules/java/patterns.md +146 -0
- package/src/available-rules/java/security.md +100 -0
- package/src/available-rules/java/testing.md +131 -0
- package/src/available-rules/kotlin/hooks.md +17 -0
- package/src/available-rules/rust/coding-style.md +151 -0
- package/src/available-rules/rust/hooks.md +16 -0
- package/src/available-rules/rust/patterns.md +168 -0
- package/src/available-rules/rust/security.md +141 -0
- package/src/available-rules/rust/testing.md +154 -0
- package/src/commands/ccp/add-backlog.md +76 -0
- package/{gsd/commands-gsd → src/commands/ccp}/add-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/add-tests.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/add-todo.md +4 -4
- package/src/commands/ccp/aside.md +165 -0
- package/{gsd/commands-gsd → src/commands/ccp}/audit-milestone.md +3 -3
- package/src/commands/ccp/audit-uat.md +24 -0
- package/src/commands/ccp/autonomous.md +41 -0
- package/src/commands/ccp/build-fix.md +67 -0
- package/{gsd/commands-gsd → src/commands/ccp}/check-todos.md +3 -3
- package/{ecc/commands → src/commands/ccp}/checkpoint.md +12 -7
- package/{gsd/commands-gsd → src/commands/ccp}/cleanup.md +3 -3
- package/src/commands/ccp/code-review.md +45 -0
- package/{gsd/commands-gsd → src/commands/ccp}/complete-milestone.md +9 -9
- package/src/commands/ccp/context-budget.md +30 -0
- package/src/commands/ccp/cpp-build.md +174 -0
- package/src/commands/ccp/cpp-review.md +133 -0
- package/src/commands/ccp/cpp-test.md +252 -0
- package/{gsd/commands-gsd → src/commands/ccp}/debug.md +14 -9
- package/src/commands/ccp/discuss-phase.md +64 -0
- package/src/commands/ccp/do.md +30 -0
- package/src/commands/ccp/docs-update.md +48 -0
- package/src/commands/ccp/docs.md +32 -0
- package/src/commands/ccp/e2e.md +365 -0
- package/src/commands/ccp/eval.md +125 -0
- package/{ecc/commands → src/commands/ccp}/evolve.md +5 -5
- package/src/commands/ccp/execute-phase.md +59 -0
- package/src/commands/ccp/fast.md +30 -0
- package/src/commands/ccp/forensics.md +56 -0
- package/src/commands/ccp/go-build.md +184 -0
- package/src/commands/ccp/go-review.md +149 -0
- package/src/commands/ccp/go-test.md +269 -0
- package/src/commands/ccp/gradle-build.md +71 -0
- package/src/commands/ccp/harness-audit.md +76 -0
- package/{gsd/commands-gsd → src/commands/ccp}/health.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/help.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/insert-phase.md +3 -3
- package/src/commands/ccp/kotlin-build.md +175 -0
- package/src/commands/ccp/kotlin-review.md +141 -0
- package/src/commands/ccp/kotlin-test.md +313 -0
- package/{ecc/commands → src/commands/ccp}/learn.md +7 -2
- package/{gsd/commands-gsd → src/commands/ccp}/list-phase-assumptions.md +2 -2
- package/src/commands/ccp/manager.md +39 -0
- package/{gsd/commands-gsd → src/commands/ccp}/map-codebase.md +7 -7
- package/src/commands/ccp/milestone-summary.md +51 -0
- package/{ecc/commands → src/commands/ccp}/model-route.md +6 -1
- package/{gsd/commands-gsd → src/commands/ccp}/new-milestone.md +8 -8
- package/{gsd/commands-gsd → src/commands/ccp}/new-project.md +8 -8
- package/src/commands/ccp/next.md +24 -0
- package/src/commands/ccp/note.md +34 -0
- package/src/commands/ccp/orchestrate.md +232 -0
- package/{gsd/commands-gsd → src/commands/ccp}/pause-work.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/plan-milestone-gaps.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/plan-phase.md +9 -7
- package/src/commands/ccp/plan.md +115 -0
- package/src/commands/ccp/plant-seed.md +28 -0
- package/src/commands/ccp/pr-branch.md +25 -0
- package/src/commands/ccp/profile-user.md +46 -0
- package/{gsd/commands-gsd → src/commands/ccp}/progress.md +3 -3
- package/src/commands/ccp/prompt-optimize.md +39 -0
- package/src/commands/ccp/prune.md +25 -0
- package/src/commands/ccp/python-review.md +298 -0
- package/{ecc/commands → src/commands/ccp}/quality-gate.md +7 -2
- package/{gsd/commands-gsd → src/commands/ccp}/quick.md +10 -8
- package/src/commands/ccp/refactor-clean.md +85 -0
- package/{gsd/commands-gsd → src/commands/ccp}/remove-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/research-phase.md +17 -12
- package/{ecc/commands → src/commands/ccp}/resume-session.md +9 -8
- package/{gsd/commands-gsd → src/commands/ccp}/resume-work.md +3 -3
- package/src/commands/ccp/review-backlog.md +61 -0
- package/src/commands/ccp/review.md +37 -0
- package/src/commands/ccp/rules-distill.md +12 -0
- package/src/commands/ccp/rust-build.md +188 -0
- package/src/commands/ccp/rust-review.md +143 -0
- package/src/commands/ccp/rust-test.md +309 -0
- package/{ecc/commands → src/commands/ccp}/save-session.md +2 -1
- package/src/commands/ccp/secure-phase.md +35 -0
- package/src/commands/ccp/session-report.md +19 -0
- package/{ecc/commands → src/commands/ccp}/sessions.md +39 -34
- package/src/commands/ccp/set-profile.md +12 -0
- package/{gsd/commands-gsd → src/commands/ccp}/settings.md +5 -5
- package/src/commands/ccp/setup-pm.md +81 -0
- package/{kit/commands → src/commands/ccp}/setup-refresh.md +4 -3
- package/{kit/commands → src/commands/ccp}/setup.md +67 -40
- package/src/commands/ccp/ship.md +23 -0
- package/src/commands/ccp/skill-create.md +172 -0
- package/src/commands/ccp/skill-health.md +51 -0
- package/src/commands/ccp/stats.md +18 -0
- package/src/commands/ccp/tdd.md +329 -0
- package/src/commands/ccp/test-coverage.md +74 -0
- package/src/commands/ccp/thread.md +127 -0
- package/{kit/commands → src/commands/ccp}/tool-guide.md +2 -1
- package/src/commands/ccp/ui-phase.md +34 -0
- package/src/commands/ccp/ui-review.md +32 -0
- package/src/commands/ccp/update-codemaps.md +77 -0
- package/src/commands/ccp/update-docs.md +89 -0
- package/{gsd/commands-gsd → src/commands/ccp}/update.md +5 -5
- package/{gsd/commands-gsd → src/commands/ccp}/validate-phase.md +3 -3
- package/{gsd/commands-gsd → src/commands/ccp}/verify-work.md +5 -5
- package/{ecc/commands → src/commands/ccp}/verify.md +5 -0
- package/src/commands/ccp/workstreams.md +68 -0
- package/{ecc → src}/examples/CLAUDE.md +4 -4
- package/{ecc → src}/examples/django-api-CLAUDE.md +5 -5
- package/{ecc → src}/examples/go-microservice-CLAUDE.md +6 -6
- package/{ecc → src}/examples/rust-api-CLAUDE.md +4 -4
- package/{ecc → src}/examples/saas-nextjs-CLAUDE.md +8 -8
- package/{gsd/hooks/gsd-context-monitor.js → src/hooks/ccp-context-monitor.js} +3 -3
- package/src/hooks/ccp-prompt-guard.js +96 -0
- package/{gsd/hooks/gsd-statusline.js → src/hooks/ccp-statusline.js} +7 -7
- package/src/hooks/ccp-workflow-guard.js +94 -0
- package/src/hooks/config-protection.js +141 -0
- package/{kit → src}/hooks/kit-check-update.js +7 -4
- package/src/hooks/mcp-health-check.js +620 -0
- package/{ecc/scripts → src}/hooks/run-with-flags-shell.sh +1 -1
- package/{ecc/scripts → src}/hooks/run-with-flags.js +74 -13
- package/src/hooks/session-end-marker.js +29 -0
- package/{ecc/scripts → src}/hooks/session-end.js +83 -40
- package/{ecc/scripts → src}/hooks/session-start.js +76 -10
- package/{ecc/scripts → src}/lib/hook-flags.js +8 -4
- package/{ecc/scripts → src}/lib/project-detect.js +2 -1
- package/{ecc/scripts → src}/lib/session-manager.d.ts +5 -1
- package/{ecc/scripts → src}/lib/session-manager.js +202 -92
- package/{ecc/scripts → src}/lib/utils.d.ts +23 -1
- package/{ecc/scripts → src}/lib/utils.js +91 -3
- package/{gsd/get-shit-done/bin/gsd-tools.cjs → src/pilot/bin/ccp-tools.cjs} +257 -86
- package/{gsd/get-shit-done → src/pilot}/bin/lib/commands.cjs +1 -1
- package/src/pilot/bin/lib/config.cjs +444 -0
- package/src/pilot/bin/lib/core.cjs +1190 -0
- package/src/pilot/bin/lib/init.cjs +1281 -0
- package/src/pilot/bin/lib/model-profiles.cjs +67 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/phase.cjs +2 -2
- package/src/pilot/bin/lib/security.cjs +382 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/state.cjs +1 -1
- package/src/pilot/bin/lib/uat.cjs +282 -0
- package/{gsd/get-shit-done → src/pilot}/bin/lib/verify.cjs +10 -10
- package/{gsd/get-shit-done → src/pilot}/references/continuation-format.md +16 -16
- package/{gsd/get-shit-done → src/pilot}/references/decimal-phase-calculation.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/git-integration.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/git-planning-commit.md +4 -4
- package/src/pilot/references/mcp-servers.json +153 -0
- package/{gsd/get-shit-done → src/pilot}/references/model-profile-resolution.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/references/model-profiles.md +20 -20
- package/{gsd/get-shit-done → src/pilot}/references/phase-argument-parsing.md +4 -4
- package/{gsd/get-shit-done → src/pilot}/references/planning-config.md +15 -15
- package/{gsd/get-shit-done → src/pilot}/references/ui-brand.md +5 -5
- package/{gsd/get-shit-done → src/pilot}/references/verification-patterns.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/DEBUG.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/UAT.md +3 -3
- package/src/pilot/templates/UI-SPEC.md +100 -0
- package/{gsd/get-shit-done → src/pilot}/templates/VALIDATION.md +1 -1
- package/src/pilot/templates/claude-md.md +122 -0
- package/{gsd/get-shit-done → src/pilot}/templates/codebase/architecture.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/codebase/structure.md +13 -13
- package/{gsd/get-shit-done → src/pilot}/templates/context.md +4 -4
- package/src/pilot/templates/copilot-instructions.md +7 -0
- package/{gsd/get-shit-done → src/pilot}/templates/debug-subagent-prompt.md +4 -4
- package/src/pilot/templates/dev-preferences.md +21 -0
- package/{gsd/get-shit-done → src/pilot}/templates/discovery.md +2 -2
- package/src/pilot/templates/discussion-log.md +63 -0
- package/{gsd/get-shit-done → src/pilot}/templates/phase-prompt.md +12 -12
- package/{gsd/get-shit-done → src/pilot}/templates/planner-subagent-prompt.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/templates/project.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/templates/research.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/state.md +2 -2
- package/{gsd/get-shit-done → src/pilot}/templates/summary-complex.md +1 -1
- package/{gsd/get-shit-done → src/pilot}/workflows/add-phase.md +11 -11
- package/{gsd/get-shit-done → src/pilot}/workflows/add-tests.md +15 -15
- package/{gsd/get-shit-done → src/pilot}/workflows/add-todo.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/workflows/audit-milestone.md +24 -16
- package/src/pilot/workflows/audit-uat.md +109 -0
- package/src/pilot/workflows/autonomous.md +891 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/check-todos.md +10 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/cleanup.md +3 -3
- package/{gsd/get-shit-done → src/pilot}/workflows/complete-milestone.md +19 -16
- package/{gsd/get-shit-done → src/pilot}/workflows/diagnose-issues.md +9 -4
- package/{gsd/get-shit-done → src/pilot}/workflows/discovery-phase.md +8 -8
- package/src/pilot/workflows/discuss-phase-assumptions.md +653 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/discuss-phase.md +407 -49
- package/src/pilot/workflows/do.md +104 -0
- package/src/pilot/workflows/docs-update.md +1165 -0
- package/src/pilot/workflows/execute-phase.md +821 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/execute-plan.md +79 -28
- package/src/pilot/workflows/fast.md +105 -0
- package/src/pilot/workflows/forensics.md +265 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/health.md +34 -11
- package/src/pilot/workflows/help.md +767 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/insert-phase.md +10 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/list-phase-assumptions.md +4 -4
- package/src/pilot/workflows/manager.md +362 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/map-codebase.md +27 -17
- package/src/pilot/workflows/milestone-summary.md +223 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/new-milestone.md +135 -33
- package/{gsd/get-shit-done → src/pilot}/workflows/new-project.md +152 -79
- package/src/pilot/workflows/next.md +97 -0
- package/src/pilot/workflows/node-repair.md +92 -0
- package/src/pilot/workflows/note.md +156 -0
- package/src/pilot/workflows/pause-work.md +177 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/plan-milestone-gaps.md +10 -11
- package/src/pilot/workflows/plan-phase.md +859 -0
- package/src/pilot/workflows/plant-seed.md +169 -0
- package/src/pilot/workflows/pr-branch.md +129 -0
- package/src/pilot/workflows/profile-user.md +452 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/progress.md +95 -34
- package/{gsd/get-shit-done → src/pilot}/workflows/quick.md +33 -21
- package/{gsd/get-shit-done → src/pilot}/workflows/remove-phase.md +14 -14
- package/{gsd/get-shit-done → src/pilot}/workflows/research-phase.md +18 -10
- package/{gsd/get-shit-done → src/pilot}/workflows/resume-project.md +37 -18
- package/src/pilot/workflows/review.md +244 -0
- package/src/pilot/workflows/secure-phase.md +164 -0
- package/src/pilot/workflows/session-report.md +146 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/set-profile.md +7 -7
- package/{gsd/get-shit-done → src/pilot}/workflows/settings.md +75 -22
- package/src/pilot/workflows/ship.md +228 -0
- package/src/pilot/workflows/stats.md +60 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/transition.md +57 -17
- package/src/pilot/workflows/ui-phase.md +302 -0
- package/src/pilot/workflows/ui-review.md +165 -0
- package/{gsd/get-shit-done → src/pilot}/workflows/update.md +88 -58
- package/{gsd/get-shit-done → src/pilot}/workflows/validate-phase.md +24 -17
- package/{gsd/get-shit-done → src/pilot}/workflows/verify-phase.md +26 -15
- package/{gsd/get-shit-done → src/pilot}/workflows/verify-work.md +89 -37
- package/{ecc → src}/rules/common/agents.md +1 -0
- package/src/rules/common/code-review.md +124 -0
- package/{ecc → src}/rules/common/coding-style.md +21 -0
- package/src/rules/zh/README.md +108 -0
- package/src/rules/zh/agents.md +50 -0
- package/src/rules/zh/code-review.md +124 -0
- package/src/rules/zh/coding-style.md +48 -0
- package/src/rules/zh/development-workflow.md +44 -0
- package/src/rules/zh/git-workflow.md +24 -0
- package/src/rules/zh/hooks.md +30 -0
- package/src/rules/zh/patterns.md +31 -0
- package/src/rules/zh/performance.md +55 -0
- package/src/rules/zh/security.md +29 -0
- package/src/rules/zh/testing.md +29 -0
- package/src/skills/agentic-engineering/SKILL.md +63 -0
- package/src/skills/ai-first-engineering/SKILL.md +51 -0
- package/src/skills/ai-regression-testing/SKILL.md +385 -0
- package/src/skills/api-design/SKILL.md +523 -0
- package/src/skills/architecture-decision-records/SKILL.md +179 -0
- package/src/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/src/skills/autonomous-loops/SKILL.md +610 -0
- package/src/skills/backend-patterns/SKILL.md +598 -0
- package/src/skills/benchmark/SKILL.md +87 -0
- package/src/skills/blueprint/SKILL.md +90 -0
- package/src/skills/browser-qa/SKILL.md +81 -0
- package/src/skills/bun-runtime/SKILL.md +84 -0
- package/src/skills/claude-api/SKILL.md +337 -0
- package/src/skills/codebase-onboarding/SKILL.md +233 -0
- package/src/skills/coding-standards/SKILL.md +530 -0
- package/src/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/src/skills/context-budget/SKILL.md +135 -0
- package/{ecc → src}/skills/continuous-learning-v2/SKILL.md +6 -6
- package/{ecc → src}/skills/continuous-learning-v2/agents/observer-loop.sh +1 -1
- package/{ecc → src}/skills/continuous-learning-v2/agents/observer.md +1 -1
- package/src/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/src/skills/cpp-coding-standards/SKILL.md +723 -0
- package/src/skills/cpp-testing/SKILL.md +324 -0
- package/src/skills/database-migrations/SKILL.md +429 -0
- package/src/skills/deep-research/SKILL.md +155 -0
- package/src/skills/deployment-patterns/SKILL.md +427 -0
- package/src/skills/design-system/SKILL.md +82 -0
- package/src/skills/django-patterns/SKILL.md +734 -0
- package/src/skills/django-security/SKILL.md +593 -0
- package/src/skills/django-tdd/SKILL.md +729 -0
- package/src/skills/django-verification/SKILL.md +469 -0
- package/src/skills/docker-patterns/SKILL.md +364 -0
- package/src/skills/documentation-lookup/SKILL.md +90 -0
- package/src/skills/e2e-testing/SKILL.md +326 -0
- package/src/skills/eval-harness/SKILL.md +270 -0
- package/src/skills/exa-search/SKILL.md +103 -0
- package/src/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/src/skills/frontend-patterns/SKILL.md +642 -0
- package/src/skills/gan-style-harness/SKILL.md +278 -0
- package/src/skills/git-workflow/SKILL.md +715 -0
- package/src/skills/golang-patterns/SKILL.md +674 -0
- package/src/skills/golang-testing/SKILL.md +720 -0
- package/src/skills/hexagonal-architecture/SKILL.md +276 -0
- package/src/skills/iterative-retrieval/SKILL.md +211 -0
- package/src/skills/java-coding-standards/SKILL.md +147 -0
- package/src/skills/jpa-patterns/SKILL.md +151 -0
- package/src/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/src/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/src/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/src/skills/kotlin-patterns/SKILL.md +711 -0
- package/src/skills/kotlin-testing/SKILL.md +824 -0
- package/src/skills/laravel-patterns/SKILL.md +415 -0
- package/src/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/src/skills/laravel-security/SKILL.md +285 -0
- package/src/skills/laravel-tdd/SKILL.md +283 -0
- package/src/skills/laravel-verification/SKILL.md +179 -0
- package/src/skills/mcp-server-patterns/SKILL.md +67 -0
- package/src/skills/nextjs-turbopack/SKILL.md +44 -0
- package/src/skills/nuxt4-patterns/SKILL.md +100 -0
- package/src/skills/opensource-pipeline/SKILL.md +255 -0
- package/src/skills/perl-patterns/SKILL.md +504 -0
- package/src/skills/perl-security/SKILL.md +503 -0
- package/src/skills/perl-testing/SKILL.md +475 -0
- package/src/skills/postgres-patterns/SKILL.md +147 -0
- package/src/skills/project-flow-ops/SKILL.md +111 -0
- package/src/skills/project-guidelines-example/SKILL.md +349 -0
- package/src/skills/prompt-optimizer/SKILL.md +397 -0
- package/src/skills/python-patterns/SKILL.md +750 -0
- package/src/skills/python-testing/SKILL.md +816 -0
- package/src/skills/pytorch-patterns/SKILL.md +396 -0
- package/src/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/src/skills/repo-scan/SKILL.md +78 -0
- package/src/skills/rules-distill/SKILL.md +264 -0
- package/src/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/src/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/src/skills/rust-patterns/SKILL.md +499 -0
- package/src/skills/rust-testing/SKILL.md +500 -0
- package/src/skills/safety-guard/SKILL.md +69 -0
- package/src/skills/search-first/SKILL.md +161 -0
- package/src/skills/security-review/SKILL.md +495 -0
- package/src/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/src/skills/security-scan/SKILL.md +165 -0
- package/src/skills/springboot-patterns/SKILL.md +314 -0
- package/src/skills/springboot-security/SKILL.md +272 -0
- package/src/skills/springboot-tdd/SKILL.md +158 -0
- package/src/skills/springboot-verification/SKILL.md +231 -0
- package/src/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/src/skills/tdd-workflow/SKILL.md +410 -0
- package/src/skills/token-budget-advisor/SKILL.md +133 -0
- package/{ecc/skills/verification-loop-SKILL.md → src/skills/verification-loop/SKILL.md} +1 -1
- package/src/skills/workspace-surface-audit/SKILL.md +125 -0
- package/ecc/scripts/hooks/session-end-marker.js +0 -15
- package/gsd/LICENSE +0 -21
- package/gsd/commands-gsd/discuss-phase.md +0 -90
- package/gsd/commands-gsd/execute-phase.md +0 -41
- package/gsd/commands-gsd/join-discord.md +0 -18
- package/gsd/commands-gsd/reapply-patches.md +0 -123
- package/gsd/commands-gsd/set-profile.md +0 -34
- package/gsd/get-shit-done/bin/lib/config.cjs +0 -169
- package/gsd/get-shit-done/bin/lib/core.cjs +0 -492
- package/gsd/get-shit-done/bin/lib/init.cjs +0 -710
- package/gsd/get-shit-done/workflows/execute-phase.md +0 -459
- package/gsd/get-shit-done/workflows/help.md +0 -489
- package/gsd/get-shit-done/workflows/pause-work.md +0 -122
- package/gsd/get-shit-done/workflows/plan-phase.md +0 -560
- package/gsd/hooks/gsd-check-update.js +0 -81
- package/kit/CLAUDE.md +0 -43
- package/kit/commands/kit/update.md +0 -46
- package/kit/mcp.json +0 -10
- package/kit/rules/code-style.md +0 -24
- /package/{ecc → src}/agents/architect.md +0 -0
- /package/{ecc → src}/agents/code-reviewer.md +0 -0
- /package/{ecc → src}/agents/e2e-runner.md +0 -0
- /package/{ecc → src}/agents/security-reviewer.md +0 -0
- /package/{ecc → src}/agents/tdd-guide.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/golang/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/kotlin/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/perl/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/php/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/python/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/swift/testing.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/coding-style.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/hooks.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/patterns.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/security.md +0 -0
- /package/{ecc/rules → src/available-rules}/typescript/testing.md +0 -0
- /package/{ecc → src}/contexts/dev.md +0 -0
- /package/{ecc → src}/contexts/research.md +0 -0
- /package/{ecc → src}/contexts/review.md +0 -0
- /package/{ecc → src}/examples/user-CLAUDE.md +0 -0
- /package/{ecc/scripts → src}/hooks/check-hook-enabled.js +0 -0
- /package/{ecc/scripts → src}/hooks/evaluate-session.js +0 -0
- /package/{ecc/scripts → src}/hooks/pre-compact.js +0 -0
- /package/{ecc/scripts → src}/hooks/suggest-compact.js +0 -0
- /package/{ecc/scripts → src}/lib/package-manager.d.ts +0 -0
- /package/{ecc/scripts → src}/lib/package-manager.js +0 -0
- /package/{ecc/scripts → src}/lib/resolve-formatter.js +0 -0
- /package/{ecc/scripts → src}/lib/session-aliases.d.ts +0 -0
- /package/{ecc/scripts → src}/lib/session-aliases.js +0 -0
- /package/{ecc/scripts → src}/lib/shell-split.js +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/frontmatter.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/milestone.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/roadmap.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/bin/lib/template.cjs +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/checkpoints.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/questioning.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/references/tdd.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/concerns.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/conventions.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/integrations.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/stack.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/codebase/testing.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/config.json +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/continue-here.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/milestone-archive.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/milestone.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/requirements.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/ARCHITECTURE.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/FEATURES.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/PITFALLS.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/STACK.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/research-project/SUMMARY.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/retrospective.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/roadmap.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary-minimal.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary-standard.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/summary.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/user-setup.md +0 -0
- /package/{gsd/get-shit-done → src/pilot}/templates/verification-report.md +0 -0
- /package/{ecc → src}/rules/common/development-workflow.md +0 -0
- /package/{ecc → src}/rules/common/git-workflow.md +0 -0
- /package/{ecc → src}/rules/common/hooks.md +0 -0
- /package/{ecc → src}/rules/common/patterns.md +0 -0
- /package/{ecc → src}/rules/common/performance.md +0 -0
- /package/{ecc → src}/rules/common/security.md +0 -0
- /package/{ecc → src}/rules/common/testing.md +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/agents/start-observer.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/config.json +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/hooks/observe.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/detect-project.sh +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -0
- /package/{ecc → src}/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -0
- /package/{ecc → src}/skills/strategic-compact/SKILL.md +0 -0
- /package/{ecc → src}/skills/strategic-compact/suggest-compact.sh +0 -0
|
@@ -0,0 +1,410 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: tdd-workflow
|
|
3
|
+
description: Use this skill when writing new features, fixing bugs, or refactoring code. Enforces test-driven development with 80%+ coverage including unit, integration, and E2E tests.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Test-Driven Development Workflow
|
|
8
|
+
|
|
9
|
+
This skill ensures all code development follows TDD principles with comprehensive test coverage.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- Writing new features or functionality
|
|
14
|
+
- Fixing bugs or issues
|
|
15
|
+
- Refactoring existing code
|
|
16
|
+
- Adding API endpoints
|
|
17
|
+
- Creating new components
|
|
18
|
+
|
|
19
|
+
## Core Principles
|
|
20
|
+
|
|
21
|
+
### 1. Tests BEFORE Code
|
|
22
|
+
ALWAYS write tests first, then implement code to make tests pass.
|
|
23
|
+
|
|
24
|
+
### 2. Coverage Requirements
|
|
25
|
+
- Minimum 80% coverage (unit + integration + E2E)
|
|
26
|
+
- All edge cases covered
|
|
27
|
+
- Error scenarios tested
|
|
28
|
+
- Boundary conditions verified
|
|
29
|
+
|
|
30
|
+
### 3. Test Types
|
|
31
|
+
|
|
32
|
+
#### Unit Tests
|
|
33
|
+
- Individual functions and utilities
|
|
34
|
+
- Component logic
|
|
35
|
+
- Pure functions
|
|
36
|
+
- Helpers and utilities
|
|
37
|
+
|
|
38
|
+
#### Integration Tests
|
|
39
|
+
- API endpoints
|
|
40
|
+
- Database operations
|
|
41
|
+
- Service interactions
|
|
42
|
+
- External API calls
|
|
43
|
+
|
|
44
|
+
#### E2E Tests (Playwright)
|
|
45
|
+
- Critical user flows
|
|
46
|
+
- Complete workflows
|
|
47
|
+
- Browser automation
|
|
48
|
+
- UI interactions
|
|
49
|
+
|
|
50
|
+
## TDD Workflow Steps
|
|
51
|
+
|
|
52
|
+
### Step 1: Write User Journeys
|
|
53
|
+
```
|
|
54
|
+
As a [role], I want to [action], so that [benefit]
|
|
55
|
+
|
|
56
|
+
Example:
|
|
57
|
+
As a user, I want to search for markets semantically,
|
|
58
|
+
so that I can find relevant markets even without exact keywords.
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
### Step 2: Generate Test Cases
|
|
62
|
+
For each user journey, create comprehensive test cases:
|
|
63
|
+
|
|
64
|
+
```typescript
|
|
65
|
+
describe('Semantic Search', () => {
|
|
66
|
+
it('returns relevant markets for query', async () => {
|
|
67
|
+
// Test implementation
|
|
68
|
+
})
|
|
69
|
+
|
|
70
|
+
it('handles empty query gracefully', async () => {
|
|
71
|
+
// Test edge case
|
|
72
|
+
})
|
|
73
|
+
|
|
74
|
+
it('falls back to substring search when Redis unavailable', async () => {
|
|
75
|
+
// Test fallback behavior
|
|
76
|
+
})
|
|
77
|
+
|
|
78
|
+
it('sorts results by similarity score', async () => {
|
|
79
|
+
// Test sorting logic
|
|
80
|
+
})
|
|
81
|
+
})
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
### Step 3: Run Tests (They Should Fail)
|
|
85
|
+
```bash
|
|
86
|
+
npm test
|
|
87
|
+
# Tests should fail - we haven't implemented yet
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
### Step 4: Implement Code
|
|
91
|
+
Write minimal code to make tests pass:
|
|
92
|
+
|
|
93
|
+
```typescript
|
|
94
|
+
// Implementation guided by tests
|
|
95
|
+
export async function searchMarkets(query: string) {
|
|
96
|
+
// Implementation here
|
|
97
|
+
}
|
|
98
|
+
```
|
|
99
|
+
|
|
100
|
+
### Step 5: Run Tests Again
|
|
101
|
+
```bash
|
|
102
|
+
npm test
|
|
103
|
+
# Tests should now pass
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
### Step 6: Refactor
|
|
107
|
+
Improve code quality while keeping tests green:
|
|
108
|
+
- Remove duplication
|
|
109
|
+
- Improve naming
|
|
110
|
+
- Optimize performance
|
|
111
|
+
- Enhance readability
|
|
112
|
+
|
|
113
|
+
### Step 7: Verify Coverage
|
|
114
|
+
```bash
|
|
115
|
+
npm run test:coverage
|
|
116
|
+
# Verify 80%+ coverage achieved
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
## Testing Patterns
|
|
120
|
+
|
|
121
|
+
### Unit Test Pattern (Jest/Vitest)
|
|
122
|
+
```typescript
|
|
123
|
+
import { render, screen, fireEvent } from '@testing-library/react'
|
|
124
|
+
import { Button } from './Button'
|
|
125
|
+
|
|
126
|
+
describe('Button Component', () => {
|
|
127
|
+
it('renders with correct text', () => {
|
|
128
|
+
render(<Button>Click me</Button>)
|
|
129
|
+
expect(screen.getByText('Click me')).toBeInTheDocument()
|
|
130
|
+
})
|
|
131
|
+
|
|
132
|
+
it('calls onClick when clicked', () => {
|
|
133
|
+
const handleClick = jest.fn()
|
|
134
|
+
render(<Button onClick={handleClick}>Click</Button>)
|
|
135
|
+
|
|
136
|
+
fireEvent.click(screen.getByRole('button'))
|
|
137
|
+
|
|
138
|
+
expect(handleClick).toHaveBeenCalledTimes(1)
|
|
139
|
+
})
|
|
140
|
+
|
|
141
|
+
it('is disabled when disabled prop is true', () => {
|
|
142
|
+
render(<Button disabled>Click</Button>)
|
|
143
|
+
expect(screen.getByRole('button')).toBeDisabled()
|
|
144
|
+
})
|
|
145
|
+
})
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
### API Integration Test Pattern
|
|
149
|
+
```typescript
|
|
150
|
+
import { NextRequest } from 'next/server'
|
|
151
|
+
import { GET } from './route'
|
|
152
|
+
|
|
153
|
+
describe('GET /api/markets', () => {
|
|
154
|
+
it('returns markets successfully', async () => {
|
|
155
|
+
const request = new NextRequest('http://localhost/api/markets')
|
|
156
|
+
const response = await GET(request)
|
|
157
|
+
const data = await response.json()
|
|
158
|
+
|
|
159
|
+
expect(response.status).toBe(200)
|
|
160
|
+
expect(data.success).toBe(true)
|
|
161
|
+
expect(Array.isArray(data.data)).toBe(true)
|
|
162
|
+
})
|
|
163
|
+
|
|
164
|
+
it('validates query parameters', async () => {
|
|
165
|
+
const request = new NextRequest('http://localhost/api/markets?limit=invalid')
|
|
166
|
+
const response = await GET(request)
|
|
167
|
+
|
|
168
|
+
expect(response.status).toBe(400)
|
|
169
|
+
})
|
|
170
|
+
|
|
171
|
+
it('handles database errors gracefully', async () => {
|
|
172
|
+
// Mock database failure
|
|
173
|
+
const request = new NextRequest('http://localhost/api/markets')
|
|
174
|
+
// Test error handling
|
|
175
|
+
})
|
|
176
|
+
})
|
|
177
|
+
```
|
|
178
|
+
|
|
179
|
+
### E2E Test Pattern (Playwright)
|
|
180
|
+
```typescript
|
|
181
|
+
import { test, expect } from '@playwright/test'
|
|
182
|
+
|
|
183
|
+
test('user can search and filter markets', async ({ page }) => {
|
|
184
|
+
// Navigate to markets page
|
|
185
|
+
await page.goto('/')
|
|
186
|
+
await page.click('a[href="/markets"]')
|
|
187
|
+
|
|
188
|
+
// Verify page loaded
|
|
189
|
+
await expect(page.locator('h1')).toContainText('Markets')
|
|
190
|
+
|
|
191
|
+
// Search for markets
|
|
192
|
+
await page.fill('input[placeholder="Search markets"]', 'election')
|
|
193
|
+
|
|
194
|
+
// Wait for debounce and results
|
|
195
|
+
await page.waitForTimeout(600)
|
|
196
|
+
|
|
197
|
+
// Verify search results displayed
|
|
198
|
+
const results = page.locator('[data-testid="market-card"]')
|
|
199
|
+
await expect(results).toHaveCount(5, { timeout: 5000 })
|
|
200
|
+
|
|
201
|
+
// Verify results contain search term
|
|
202
|
+
const firstResult = results.first()
|
|
203
|
+
await expect(firstResult).toContainText('election', { ignoreCase: true })
|
|
204
|
+
|
|
205
|
+
// Filter by status
|
|
206
|
+
await page.click('button:has-text("Active")')
|
|
207
|
+
|
|
208
|
+
// Verify filtered results
|
|
209
|
+
await expect(results).toHaveCount(3)
|
|
210
|
+
})
|
|
211
|
+
|
|
212
|
+
test('user can create a new market', async ({ page }) => {
|
|
213
|
+
// Login first
|
|
214
|
+
await page.goto('/creator-dashboard')
|
|
215
|
+
|
|
216
|
+
// Fill market creation form
|
|
217
|
+
await page.fill('input[name="name"]', 'Test Market')
|
|
218
|
+
await page.fill('textarea[name="description"]', 'Test description')
|
|
219
|
+
await page.fill('input[name="endDate"]', '2025-12-31')
|
|
220
|
+
|
|
221
|
+
// Submit form
|
|
222
|
+
await page.click('button[type="submit"]')
|
|
223
|
+
|
|
224
|
+
// Verify success message
|
|
225
|
+
await expect(page.locator('text=Market created successfully')).toBeVisible()
|
|
226
|
+
|
|
227
|
+
// Verify redirect to market page
|
|
228
|
+
await expect(page).toHaveURL(/\/markets\/test-market/)
|
|
229
|
+
})
|
|
230
|
+
```
|
|
231
|
+
|
|
232
|
+
## Test File Organization
|
|
233
|
+
|
|
234
|
+
```
|
|
235
|
+
src/
|
|
236
|
+
├── components/
|
|
237
|
+
│ ├── Button/
|
|
238
|
+
│ │ ├── Button.tsx
|
|
239
|
+
│ │ ├── Button.test.tsx # Unit tests
|
|
240
|
+
│ │ └── Button.stories.tsx # Storybook
|
|
241
|
+
│ └── MarketCard/
|
|
242
|
+
│ ├── MarketCard.tsx
|
|
243
|
+
│ └── MarketCard.test.tsx
|
|
244
|
+
├── app/
|
|
245
|
+
│ └── api/
|
|
246
|
+
│ └── markets/
|
|
247
|
+
│ ├── route.ts
|
|
248
|
+
│ └── route.test.ts # Integration tests
|
|
249
|
+
└── e2e/
|
|
250
|
+
├── markets.spec.ts # E2E tests
|
|
251
|
+
├── trading.spec.ts
|
|
252
|
+
└── auth.spec.ts
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
## Mocking External Services
|
|
256
|
+
|
|
257
|
+
### Supabase Mock
|
|
258
|
+
```typescript
|
|
259
|
+
jest.mock('@/lib/supabase', () => ({
|
|
260
|
+
supabase: {
|
|
261
|
+
from: jest.fn(() => ({
|
|
262
|
+
select: jest.fn(() => ({
|
|
263
|
+
eq: jest.fn(() => Promise.resolve({
|
|
264
|
+
data: [{ id: 1, name: 'Test Market' }],
|
|
265
|
+
error: null
|
|
266
|
+
}))
|
|
267
|
+
}))
|
|
268
|
+
}))
|
|
269
|
+
}
|
|
270
|
+
}))
|
|
271
|
+
```
|
|
272
|
+
|
|
273
|
+
### Redis Mock
|
|
274
|
+
```typescript
|
|
275
|
+
jest.mock('@/lib/redis', () => ({
|
|
276
|
+
searchMarketsByVector: jest.fn(() => Promise.resolve([
|
|
277
|
+
{ slug: 'test-market', similarity_score: 0.95 }
|
|
278
|
+
])),
|
|
279
|
+
checkRedisHealth: jest.fn(() => Promise.resolve({ connected: true }))
|
|
280
|
+
}))
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
### OpenAI Mock
|
|
284
|
+
```typescript
|
|
285
|
+
jest.mock('@/lib/openai', () => ({
|
|
286
|
+
generateEmbedding: jest.fn(() => Promise.resolve(
|
|
287
|
+
new Array(1536).fill(0.1) // Mock 1536-dim embedding
|
|
288
|
+
))
|
|
289
|
+
}))
|
|
290
|
+
```
|
|
291
|
+
|
|
292
|
+
## Test Coverage Verification
|
|
293
|
+
|
|
294
|
+
### Run Coverage Report
|
|
295
|
+
```bash
|
|
296
|
+
npm run test:coverage
|
|
297
|
+
```
|
|
298
|
+
|
|
299
|
+
### Coverage Thresholds
|
|
300
|
+
```json
|
|
301
|
+
{
|
|
302
|
+
"jest": {
|
|
303
|
+
"coverageThresholds": {
|
|
304
|
+
"global": {
|
|
305
|
+
"branches": 80,
|
|
306
|
+
"functions": 80,
|
|
307
|
+
"lines": 80,
|
|
308
|
+
"statements": 80
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
```
|
|
314
|
+
|
|
315
|
+
## Common Testing Mistakes to Avoid
|
|
316
|
+
|
|
317
|
+
### ❌ WRONG: Testing Implementation Details
|
|
318
|
+
```typescript
|
|
319
|
+
// Don't test internal state
|
|
320
|
+
expect(component.state.count).toBe(5)
|
|
321
|
+
```
|
|
322
|
+
|
|
323
|
+
### ✅ CORRECT: Test User-Visible Behavior
|
|
324
|
+
```typescript
|
|
325
|
+
// Test what users see
|
|
326
|
+
expect(screen.getByText('Count: 5')).toBeInTheDocument()
|
|
327
|
+
```
|
|
328
|
+
|
|
329
|
+
### ❌ WRONG: Brittle Selectors
|
|
330
|
+
```typescript
|
|
331
|
+
// Breaks easily
|
|
332
|
+
await page.click('.css-class-xyz')
|
|
333
|
+
```
|
|
334
|
+
|
|
335
|
+
### ✅ CORRECT: Semantic Selectors
|
|
336
|
+
```typescript
|
|
337
|
+
// Resilient to changes
|
|
338
|
+
await page.click('button:has-text("Submit")')
|
|
339
|
+
await page.click('[data-testid="submit-button"]')
|
|
340
|
+
```
|
|
341
|
+
|
|
342
|
+
### ❌ WRONG: No Test Isolation
|
|
343
|
+
```typescript
|
|
344
|
+
// Tests depend on each other
|
|
345
|
+
test('creates user', () => { /* ... */ })
|
|
346
|
+
test('updates same user', () => { /* depends on previous test */ })
|
|
347
|
+
```
|
|
348
|
+
|
|
349
|
+
### ✅ CORRECT: Independent Tests
|
|
350
|
+
```typescript
|
|
351
|
+
// Each test sets up its own data
|
|
352
|
+
test('creates user', () => {
|
|
353
|
+
const user = createTestUser()
|
|
354
|
+
// Test logic
|
|
355
|
+
})
|
|
356
|
+
|
|
357
|
+
test('updates user', () => {
|
|
358
|
+
const user = createTestUser()
|
|
359
|
+
// Update logic
|
|
360
|
+
})
|
|
361
|
+
```
|
|
362
|
+
|
|
363
|
+
## Continuous Testing
|
|
364
|
+
|
|
365
|
+
### Watch Mode During Development
|
|
366
|
+
```bash
|
|
367
|
+
npm test -- --watch
|
|
368
|
+
# Tests run automatically on file changes
|
|
369
|
+
```
|
|
370
|
+
|
|
371
|
+
### Pre-Commit Hook
|
|
372
|
+
```bash
|
|
373
|
+
# Runs before every commit
|
|
374
|
+
npm test && npm run lint
|
|
375
|
+
```
|
|
376
|
+
|
|
377
|
+
### CI/CD Integration
|
|
378
|
+
```yaml
|
|
379
|
+
# GitHub Actions
|
|
380
|
+
- name: Run Tests
|
|
381
|
+
run: npm test -- --coverage
|
|
382
|
+
- name: Upload Coverage
|
|
383
|
+
uses: codecov/codecov-action@v3
|
|
384
|
+
```
|
|
385
|
+
|
|
386
|
+
## Best Practices
|
|
387
|
+
|
|
388
|
+
1. **Write Tests First** - Always TDD
|
|
389
|
+
2. **One Assert Per Test** - Focus on single behavior
|
|
390
|
+
3. **Descriptive Test Names** - Explain what's tested
|
|
391
|
+
4. **Arrange-Act-Assert** - Clear test structure
|
|
392
|
+
5. **Mock External Dependencies** - Isolate unit tests
|
|
393
|
+
6. **Test Edge Cases** - Null, undefined, empty, large
|
|
394
|
+
7. **Test Error Paths** - Not just happy paths
|
|
395
|
+
8. **Keep Tests Fast** - Unit tests < 50ms each
|
|
396
|
+
9. **Clean Up After Tests** - No side effects
|
|
397
|
+
10. **Review Coverage Reports** - Identify gaps
|
|
398
|
+
|
|
399
|
+
## Success Metrics
|
|
400
|
+
|
|
401
|
+
- 80%+ code coverage achieved
|
|
402
|
+
- All tests passing (green)
|
|
403
|
+
- No skipped or disabled tests
|
|
404
|
+
- Fast test execution (< 30s for unit tests)
|
|
405
|
+
- E2E tests cover critical user flows
|
|
406
|
+
- Tests catch bugs before production
|
|
407
|
+
|
|
408
|
+
---
|
|
409
|
+
|
|
410
|
+
**Remember**: Tests are not optional. They are the safety net that enables confident refactoring, rapid development, and production reliability.
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: token-budget-advisor
|
|
3
|
+
description: >-
|
|
4
|
+
Offers the user an informed choice about how much response depth to
|
|
5
|
+
consume before answering. Use this skill when the user explicitly
|
|
6
|
+
wants to control response length, depth, or token budget.
|
|
7
|
+
TRIGGER when: "token budget", "token count", "token usage", "token limit",
|
|
8
|
+
"response length", "answer depth", "short version", "brief answer",
|
|
9
|
+
"detailed answer", "exhaustive answer", "respuesta corta vs larga",
|
|
10
|
+
"cuántos tokens", "ahorrar tokens", "responde al 50%", "dame la versión
|
|
11
|
+
corta", "quiero controlar cuánto usas", or clear variants where the
|
|
12
|
+
user is explicitly asking to control answer size or depth.
|
|
13
|
+
DO NOT TRIGGER when: user has already specified a level in the current
|
|
14
|
+
session (maintain it), the request is clearly a one-word answer, or
|
|
15
|
+
"token" refers to auth/session/payment tokens rather than response size.
|
|
16
|
+
origin: community
|
|
17
|
+
---
|
|
18
|
+
|
|
19
|
+
# Token Budget Advisor (TBA)
|
|
20
|
+
|
|
21
|
+
Intercept the response flow to offer the user a choice about response depth **before** Claude answers.
|
|
22
|
+
|
|
23
|
+
## When to Use
|
|
24
|
+
|
|
25
|
+
- User wants to control how long or detailed a response is
|
|
26
|
+
- User mentions tokens, budget, depth, or response length
|
|
27
|
+
- User says "short version", "tldr", "brief", "al 25%", "exhaustive", etc.
|
|
28
|
+
- Any time the user wants to choose depth/detail level upfront
|
|
29
|
+
|
|
30
|
+
**Do not trigger** when: user already set a level this session (maintain it silently), or the answer is trivially one line.
|
|
31
|
+
|
|
32
|
+
## How It Works
|
|
33
|
+
|
|
34
|
+
### Step 1 — Estimate input tokens
|
|
35
|
+
|
|
36
|
+
Use the repository's canonical context-budget heuristics to estimate the prompt's token count mentally.
|
|
37
|
+
|
|
38
|
+
Use the same calibration guidance as [context-budget](../context-budget/SKILL.md):
|
|
39
|
+
|
|
40
|
+
- prose: `words × 1.3`
|
|
41
|
+
- code-heavy or mixed/code blocks: `chars / 4`
|
|
42
|
+
|
|
43
|
+
For mixed content, use the dominant content type and keep the estimate heuristic.
|
|
44
|
+
|
|
45
|
+
### Step 2 — Estimate response size by complexity
|
|
46
|
+
|
|
47
|
+
Classify the prompt, then apply the multiplier range to get the full response window:
|
|
48
|
+
|
|
49
|
+
| Complexity | Multiplier range | Example prompts |
|
|
50
|
+
|--------------|------------------|------------------------------------------------------|
|
|
51
|
+
| Simple | 3× – 8× | "What is X?", yes/no, single fact |
|
|
52
|
+
| Medium | 8× – 20× | "How does X work?" |
|
|
53
|
+
| Medium-High | 10× – 25× | Code request with context |
|
|
54
|
+
| Complex | 15× – 40× | Multi-part analysis, comparisons, architecture |
|
|
55
|
+
| Creative | 10× – 30× | Stories, essays, narrative writing |
|
|
56
|
+
|
|
57
|
+
Response window = `input_tokens × mult_min` to `input_tokens × mult_max` (but don’t exceed your model’s configured output-token limit).
|
|
58
|
+
|
|
59
|
+
### Step 3 — Present depth options
|
|
60
|
+
|
|
61
|
+
Present this block **before** answering, using the actual estimated numbers:
|
|
62
|
+
|
|
63
|
+
```
|
|
64
|
+
Analyzing your prompt...
|
|
65
|
+
|
|
66
|
+
Input: ~[N] tokens | Type: [type] | Complexity: [level] | Language: [lang]
|
|
67
|
+
|
|
68
|
+
Choose your depth level:
|
|
69
|
+
|
|
70
|
+
[1] Essential (25%) -> ~[tokens] Direct answer only, no preamble
|
|
71
|
+
[2] Moderate (50%) -> ~[tokens] Answer + context + 1 example
|
|
72
|
+
[3] Detailed (75%) -> ~[tokens] Full answer with alternatives
|
|
73
|
+
[4] Exhaustive (100%) -> ~[tokens] Everything, no limits
|
|
74
|
+
|
|
75
|
+
Which level? (1-4 or say "25% depth", "50% depth", "75% depth", "100% depth")
|
|
76
|
+
|
|
77
|
+
Precision: heuristic estimate ~85-90% accuracy (±15%).
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
Level token estimates (within the response window):
|
|
81
|
+
- 25% → `min + (max - min) × 0.25`
|
|
82
|
+
- 50% → `min + (max - min) × 0.50`
|
|
83
|
+
- 75% → `min + (max - min) × 0.75`
|
|
84
|
+
- 100% → `max`
|
|
85
|
+
|
|
86
|
+
### Step 4 — Respond at the chosen level
|
|
87
|
+
|
|
88
|
+
| Level | Target length | Include | Omit |
|
|
89
|
+
|------------------|---------------------|-----------------------------------------------------|---------------------------------------------------|
|
|
90
|
+
| 25% Essential | 2-4 sentences max | Direct answer, key conclusion | Context, examples, nuance, alternatives |
|
|
91
|
+
| 50% Moderate | 1-3 paragraphs | Answer + necessary context + 1 example | Deep analysis, edge cases, references |
|
|
92
|
+
| 75% Detailed | Structured response | Multiple examples, pros/cons, alternatives | Extreme edge cases, exhaustive references |
|
|
93
|
+
| 100% Exhaustive | No restriction | Everything — full analysis, all code, all perspectives | Nothing |
|
|
94
|
+
|
|
95
|
+
## Shortcuts — skip the question
|
|
96
|
+
|
|
97
|
+
If the user already signals a level, respond at that level immediately without asking:
|
|
98
|
+
|
|
99
|
+
| What they say | Level |
|
|
100
|
+
|----------------------------------------------------|-------|
|
|
101
|
+
| "1" / "25% depth" / "short version" / "brief answer" / "tldr" | 25% |
|
|
102
|
+
| "2" / "50% depth" / "moderate depth" / "balanced answer" | 50% |
|
|
103
|
+
| "3" / "75% depth" / "detailed answer" / "thorough answer" | 75% |
|
|
104
|
+
| "4" / "100% depth" / "exhaustive answer" / "full deep dive" | 100% |
|
|
105
|
+
|
|
106
|
+
If the user set a level earlier in the session, **maintain it silently** for subsequent responses unless they change it.
|
|
107
|
+
|
|
108
|
+
## Precision note
|
|
109
|
+
|
|
110
|
+
This skill uses heuristic estimation — no real tokenizer. Accuracy ~85-90%, variance ±15%. Always show the disclaimer.
|
|
111
|
+
|
|
112
|
+
## Examples
|
|
113
|
+
|
|
114
|
+
### Triggers
|
|
115
|
+
|
|
116
|
+
- "Give me the short version first."
|
|
117
|
+
- "How many tokens will your answer use?"
|
|
118
|
+
- "Respond at 50% depth."
|
|
119
|
+
- "I want the exhaustive answer, not the summary."
|
|
120
|
+
- "Dame la version corta y luego la detallada."
|
|
121
|
+
|
|
122
|
+
### Does Not Trigger
|
|
123
|
+
|
|
124
|
+
- "What is a JWT token?"
|
|
125
|
+
- "The checkout flow uses a payment token."
|
|
126
|
+
- "Is this normal?"
|
|
127
|
+
- "Complete the refactor."
|
|
128
|
+
- Follow-up questions after the user already chose a depth for the session
|
|
129
|
+
|
|
130
|
+
## Source
|
|
131
|
+
|
|
132
|
+
Standalone skill from [TBA — Token Budget Advisor for Claude Code](https://github.com/Xabilimon1/Token-Budget-Advisor-Claude-Code-).
|
|
133
|
+
Original project also ships a Python estimator script, but this repository keeps the skill self-contained and heuristic-only.
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: workspace-surface-audit
|
|
3
|
+
description: Audit the active repo, MCP servers, plugins, connectors, env surfaces, and harness setup, then recommend the highest-value ECC-native skills, hooks, agents, and operator workflows. Use when the user wants help setting up Claude Code or understanding what capabilities are actually available in their environment.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Workspace Surface Audit
|
|
8
|
+
|
|
9
|
+
Read-only audit skill for answering the question "what can this workspace and machine actually do right now, and what should we add or enable next?"
|
|
10
|
+
|
|
11
|
+
This is the ECC-native answer to setup-audit plugins. It does not modify files unless the user explicitly asks for follow-up implementation.
|
|
12
|
+
|
|
13
|
+
## When to Use
|
|
14
|
+
|
|
15
|
+
- User says "set up Claude Code", "recommend automations", "what plugins or MCPs should I use?", or "what am I missing?"
|
|
16
|
+
- Auditing a machine or repo before installing more skills, hooks, or connectors
|
|
17
|
+
- Comparing official marketplace plugins against ECC-native coverage
|
|
18
|
+
- Reviewing `.env`, `.mcp.json`, plugin settings, or connected-app surfaces to find missing workflow layers
|
|
19
|
+
- Deciding whether a capability should be a skill, hook, agent, MCP, or external connector
|
|
20
|
+
|
|
21
|
+
## Non-Negotiable Rules
|
|
22
|
+
|
|
23
|
+
- Never print secret values. Surface only provider names, capability names, file paths, and whether a key or config exists.
|
|
24
|
+
- Prefer ECC-native workflows over generic "install another plugin" advice when ECC can reasonably own the surface.
|
|
25
|
+
- Treat external plugins as benchmarks and inspiration, not authoritative product boundaries.
|
|
26
|
+
- Separate three things clearly:
|
|
27
|
+
- already available now
|
|
28
|
+
- available but not wrapped well in ECC
|
|
29
|
+
- not available and would require a new integration
|
|
30
|
+
|
|
31
|
+
## Audit Inputs
|
|
32
|
+
|
|
33
|
+
Inspect only the files and settings needed to answer the question well:
|
|
34
|
+
|
|
35
|
+
1. Repo surface
|
|
36
|
+
- `package.json`, lockfiles, language markers, framework config, `README.md`
|
|
37
|
+
- `.mcp.json`, `.lsp.json`, `.claude/settings*.json`, `.codex/*`
|
|
38
|
+
- `AGENTS.md`, `CLAUDE.md`, install manifests, hook configs
|
|
39
|
+
2. Environment surface
|
|
40
|
+
- `.env*` files in the active repo and obvious adjacent ECC workspaces
|
|
41
|
+
- Surface only key names such as `STRIPE_API_KEY`, `TWILIO_AUTH_TOKEN`, `FAL_KEY`
|
|
42
|
+
3. Connected tool surface
|
|
43
|
+
- Installed plugins, enabled connectors, MCP servers, LSPs, and app integrations
|
|
44
|
+
4. ECC surface
|
|
45
|
+
- Existing skills, commands, hooks, agents, and install modules that already cover the need
|
|
46
|
+
|
|
47
|
+
## Audit Process
|
|
48
|
+
|
|
49
|
+
### Phase 1: Inventory What Exists
|
|
50
|
+
|
|
51
|
+
Produce a compact inventory:
|
|
52
|
+
|
|
53
|
+
- active harness targets
|
|
54
|
+
- installed plugins and connected apps
|
|
55
|
+
- configured MCP servers
|
|
56
|
+
- configured LSP servers
|
|
57
|
+
- env-backed services implied by key names
|
|
58
|
+
- existing ECC skills already relevant to the workspace
|
|
59
|
+
|
|
60
|
+
If a surface exists only as a primitive, call that out. Example:
|
|
61
|
+
|
|
62
|
+
- "Stripe is available via connected app, but ECC lacks a billing-operator skill"
|
|
63
|
+
- "Google Drive is connected, but there is no ECC-native Google Workspace operator workflow"
|
|
64
|
+
|
|
65
|
+
### Phase 2: Benchmark Against Official and Installed Surfaces
|
|
66
|
+
|
|
67
|
+
Compare the workspace against:
|
|
68
|
+
|
|
69
|
+
- official Claude plugins that overlap with setup, review, docs, design, or workflow quality
|
|
70
|
+
- locally installed plugins in Claude or Codex
|
|
71
|
+
- the user's currently connected app surfaces
|
|
72
|
+
|
|
73
|
+
Do not just list names. For each comparison, answer:
|
|
74
|
+
|
|
75
|
+
1. what they actually do
|
|
76
|
+
2. whether ECC already has parity
|
|
77
|
+
3. whether ECC only has primitives
|
|
78
|
+
4. whether ECC is missing the workflow entirely
|
|
79
|
+
|
|
80
|
+
### Phase 3: Turn Gaps Into ECC Decisions
|
|
81
|
+
|
|
82
|
+
For every real gap, recommend the correct ECC-native shape:
|
|
83
|
+
|
|
84
|
+
| Gap Type | Preferred ECC Shape |
|
|
85
|
+
|----------|---------------------|
|
|
86
|
+
| Repeatable operator workflow | Skill |
|
|
87
|
+
| Automatic enforcement or side-effect | Hook |
|
|
88
|
+
| Specialized delegated role | Agent |
|
|
89
|
+
| External tool bridge | MCP server or connector |
|
|
90
|
+
| Install/bootstrap guidance | Setup or audit skill |
|
|
91
|
+
|
|
92
|
+
Default to user-facing skills that orchestrate existing tools when the need is operational rather than infrastructural.
|
|
93
|
+
|
|
94
|
+
## Output Format
|
|
95
|
+
|
|
96
|
+
Return five sections in this order:
|
|
97
|
+
|
|
98
|
+
1. **Current surface**
|
|
99
|
+
- what is already usable right now
|
|
100
|
+
2. **Parity**
|
|
101
|
+
- where ECC already matches or exceeds the benchmark
|
|
102
|
+
3. **Primitive-only gaps**
|
|
103
|
+
- tools exist, but ECC lacks a clean operator skill
|
|
104
|
+
4. **Missing integrations**
|
|
105
|
+
- capability not available yet
|
|
106
|
+
5. **Top 3-5 next moves**
|
|
107
|
+
- concrete ECC-native additions, ordered by impact
|
|
108
|
+
|
|
109
|
+
## Recommendation Rules
|
|
110
|
+
|
|
111
|
+
- Recommend at most 1-2 highest-value ideas per category.
|
|
112
|
+
- Favor skills with obvious user intent and business value:
|
|
113
|
+
- setup audit
|
|
114
|
+
- billing/customer ops
|
|
115
|
+
- issue/program ops
|
|
116
|
+
- Google Workspace ops
|
|
117
|
+
- deployment/ops control
|
|
118
|
+
- If a connector is company-specific, recommend it only when it is genuinely available or clearly useful to the user's workflow.
|
|
119
|
+
- If ECC already has a strong primitive, propose a wrapper skill instead of inventing a brand-new subsystem.
|
|
120
|
+
|
|
121
|
+
## Good Outcomes
|
|
122
|
+
|
|
123
|
+
- The user can immediately see what is connected, what is missing, and what ECC should own next.
|
|
124
|
+
- Recommendations are specific enough to implement in the repo without another discovery pass.
|
|
125
|
+
- The final answer is organized around workflows, not API brands.
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
'use strict';
|
|
3
|
-
|
|
4
|
-
const MAX_STDIN = 1024 * 1024;
|
|
5
|
-
let raw = '';
|
|
6
|
-
process.stdin.setEncoding('utf8');
|
|
7
|
-
process.stdin.on('data', chunk => {
|
|
8
|
-
if (raw.length < MAX_STDIN) {
|
|
9
|
-
const remaining = MAX_STDIN - raw.length;
|
|
10
|
-
raw += chunk.substring(0, remaining);
|
|
11
|
-
}
|
|
12
|
-
});
|
|
13
|
-
process.stdin.on('end', () => {
|
|
14
|
-
process.stdout.write(raw);
|
|
15
|
-
});
|