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.
Files changed (514) hide show
  1. package/README.md +76 -97
  2. package/bin/install.js +267 -250
  3. package/manifest.json +5 -18
  4. package/package.json +5 -7
  5. package/src/agents/build-error-resolver.md +114 -0
  6. package/src/agents/ccp-advisor-researcher.md +104 -0
  7. package/src/agents/ccp-assumptions-analyzer.md +105 -0
  8. package/{gsd/agents/gsd-codebase-mapper.md → src/agents/ccp-codebase-mapper.md} +7 -7
  9. package/{gsd/agents/gsd-debugger.md → src/agents/ccp-debugger.md} +125 -8
  10. package/{gsd/agents/gsd-executor.md → src/agents/ccp-executor.md} +31 -20
  11. package/{gsd/agents/gsd-integration-checker.md → src/agents/ccp-integration-checker.md} +2 -2
  12. package/{gsd/agents/gsd-nyquist-auditor.md → src/agents/ccp-nyquist-auditor.md} +3 -3
  13. package/{gsd/agents/gsd-phase-researcher.md → src/agents/ccp-phase-researcher.md} +127 -13
  14. package/{gsd/agents/gsd-plan-checker.md → src/agents/ccp-plan-checker.md} +57 -21
  15. package/{gsd/agents/gsd-planner.md → src/agents/ccp-planner.md} +61 -23
  16. package/{gsd/agents/gsd-project-researcher.md → src/agents/ccp-project-researcher.md} +33 -6
  17. package/{gsd/agents/gsd-research-synthesizer.md → src/agents/ccp-research-synthesizer.md} +11 -11
  18. package/{gsd/agents/gsd-roadmapper.md → src/agents/ccp-roadmapper.md} +39 -10
  19. package/src/agents/ccp-ui-auditor.md +439 -0
  20. package/src/agents/ccp-ui-checker.md +300 -0
  21. package/src/agents/ccp-ui-researcher.md +357 -0
  22. package/{gsd/agents/gsd-verifier.md → src/agents/ccp-verifier.md} +81 -15
  23. package/src/agents/cpp-build-resolver.md +90 -0
  24. package/src/agents/cpp-reviewer.md +72 -0
  25. package/src/agents/database-reviewer.md +91 -0
  26. package/{ecc → src}/agents/doc-updater.md +1 -1
  27. package/src/agents/docs-lookup.md +68 -0
  28. package/src/agents/flutter-reviewer.md +243 -0
  29. package/src/agents/gan-evaluator.md +209 -0
  30. package/src/agents/gan-generator.md +131 -0
  31. package/src/agents/gan-planner.md +99 -0
  32. package/src/agents/go-build-resolver.md +94 -0
  33. package/src/agents/go-reviewer.md +76 -0
  34. package/src/agents/harness-optimizer.md +35 -0
  35. package/src/agents/java-build-resolver.md +153 -0
  36. package/src/agents/java-reviewer.md +92 -0
  37. package/src/agents/kotlin-build-resolver.md +118 -0
  38. package/src/agents/kotlin-reviewer.md +159 -0
  39. package/src/agents/loop-operator.md +36 -0
  40. package/src/agents/opensource-forker.md +198 -0
  41. package/src/agents/opensource-packager.md +249 -0
  42. package/src/agents/opensource-sanitizer.md +188 -0
  43. package/src/agents/performance-optimizer.md +446 -0
  44. package/src/agents/planner.md +212 -0
  45. package/src/agents/python-reviewer.md +98 -0
  46. package/src/agents/pytorch-build-resolver.md +120 -0
  47. package/src/agents/refactor-cleaner.md +85 -0
  48. package/src/agents/rust-build-resolver.md +148 -0
  49. package/src/agents/rust-reviewer.md +94 -0
  50. package/src/agents/typescript-reviewer.md +112 -0
  51. package/src/available-rules/README.md +80 -0
  52. package/src/available-rules/cpp/coding-style.md +44 -0
  53. package/src/available-rules/cpp/hooks.md +39 -0
  54. package/src/available-rules/cpp/patterns.md +51 -0
  55. package/src/available-rules/cpp/security.md +51 -0
  56. package/src/available-rules/cpp/testing.md +44 -0
  57. package/src/available-rules/csharp/coding-style.md +72 -0
  58. package/src/available-rules/csharp/hooks.md +25 -0
  59. package/src/available-rules/csharp/patterns.md +50 -0
  60. package/src/available-rules/csharp/security.md +58 -0
  61. package/src/available-rules/csharp/testing.md +46 -0
  62. package/src/available-rules/java/coding-style.md +114 -0
  63. package/src/available-rules/java/hooks.md +18 -0
  64. package/src/available-rules/java/patterns.md +146 -0
  65. package/src/available-rules/java/security.md +100 -0
  66. package/src/available-rules/java/testing.md +131 -0
  67. package/src/available-rules/kotlin/hooks.md +17 -0
  68. package/src/available-rules/rust/coding-style.md +151 -0
  69. package/src/available-rules/rust/hooks.md +16 -0
  70. package/src/available-rules/rust/patterns.md +168 -0
  71. package/src/available-rules/rust/security.md +141 -0
  72. package/src/available-rules/rust/testing.md +154 -0
  73. package/src/commands/ccp/add-backlog.md +76 -0
  74. package/{gsd/commands-gsd → src/commands/ccp}/add-phase.md +3 -3
  75. package/{gsd/commands-gsd → src/commands/ccp}/add-tests.md +5 -5
  76. package/{gsd/commands-gsd → src/commands/ccp}/add-todo.md +4 -4
  77. package/src/commands/ccp/aside.md +165 -0
  78. package/{gsd/commands-gsd → src/commands/ccp}/audit-milestone.md +3 -3
  79. package/src/commands/ccp/audit-uat.md +24 -0
  80. package/src/commands/ccp/autonomous.md +41 -0
  81. package/src/commands/ccp/build-fix.md +67 -0
  82. package/{gsd/commands-gsd → src/commands/ccp}/check-todos.md +3 -3
  83. package/{ecc/commands → src/commands/ccp}/checkpoint.md +12 -7
  84. package/{gsd/commands-gsd → src/commands/ccp}/cleanup.md +3 -3
  85. package/src/commands/ccp/code-review.md +45 -0
  86. package/{gsd/commands-gsd → src/commands/ccp}/complete-milestone.md +9 -9
  87. package/src/commands/ccp/context-budget.md +30 -0
  88. package/src/commands/ccp/cpp-build.md +174 -0
  89. package/src/commands/ccp/cpp-review.md +133 -0
  90. package/src/commands/ccp/cpp-test.md +252 -0
  91. package/{gsd/commands-gsd → src/commands/ccp}/debug.md +14 -9
  92. package/src/commands/ccp/discuss-phase.md +64 -0
  93. package/src/commands/ccp/do.md +30 -0
  94. package/src/commands/ccp/docs-update.md +48 -0
  95. package/src/commands/ccp/docs.md +32 -0
  96. package/src/commands/ccp/e2e.md +365 -0
  97. package/src/commands/ccp/eval.md +125 -0
  98. package/{ecc/commands → src/commands/ccp}/evolve.md +5 -5
  99. package/src/commands/ccp/execute-phase.md +59 -0
  100. package/src/commands/ccp/fast.md +30 -0
  101. package/src/commands/ccp/forensics.md +56 -0
  102. package/src/commands/ccp/go-build.md +184 -0
  103. package/src/commands/ccp/go-review.md +149 -0
  104. package/src/commands/ccp/go-test.md +269 -0
  105. package/src/commands/ccp/gradle-build.md +71 -0
  106. package/src/commands/ccp/harness-audit.md +76 -0
  107. package/{gsd/commands-gsd → src/commands/ccp}/health.md +3 -3
  108. package/{gsd/commands-gsd → src/commands/ccp}/help.md +5 -5
  109. package/{gsd/commands-gsd → src/commands/ccp}/insert-phase.md +3 -3
  110. package/src/commands/ccp/kotlin-build.md +175 -0
  111. package/src/commands/ccp/kotlin-review.md +141 -0
  112. package/src/commands/ccp/kotlin-test.md +313 -0
  113. package/{ecc/commands → src/commands/ccp}/learn.md +7 -2
  114. package/{gsd/commands-gsd → src/commands/ccp}/list-phase-assumptions.md +2 -2
  115. package/src/commands/ccp/manager.md +39 -0
  116. package/{gsd/commands-gsd → src/commands/ccp}/map-codebase.md +7 -7
  117. package/src/commands/ccp/milestone-summary.md +51 -0
  118. package/{ecc/commands → src/commands/ccp}/model-route.md +6 -1
  119. package/{gsd/commands-gsd → src/commands/ccp}/new-milestone.md +8 -8
  120. package/{gsd/commands-gsd → src/commands/ccp}/new-project.md +8 -8
  121. package/src/commands/ccp/next.md +24 -0
  122. package/src/commands/ccp/note.md +34 -0
  123. package/src/commands/ccp/orchestrate.md +232 -0
  124. package/{gsd/commands-gsd → src/commands/ccp}/pause-work.md +3 -3
  125. package/{gsd/commands-gsd → src/commands/ccp}/plan-milestone-gaps.md +5 -5
  126. package/{gsd/commands-gsd → src/commands/ccp}/plan-phase.md +9 -7
  127. package/src/commands/ccp/plan.md +115 -0
  128. package/src/commands/ccp/plant-seed.md +28 -0
  129. package/src/commands/ccp/pr-branch.md +25 -0
  130. package/src/commands/ccp/profile-user.md +46 -0
  131. package/{gsd/commands-gsd → src/commands/ccp}/progress.md +3 -3
  132. package/src/commands/ccp/prompt-optimize.md +39 -0
  133. package/src/commands/ccp/prune.md +25 -0
  134. package/src/commands/ccp/python-review.md +298 -0
  135. package/{ecc/commands → src/commands/ccp}/quality-gate.md +7 -2
  136. package/{gsd/commands-gsd → src/commands/ccp}/quick.md +10 -8
  137. package/src/commands/ccp/refactor-clean.md +85 -0
  138. package/{gsd/commands-gsd → src/commands/ccp}/remove-phase.md +3 -3
  139. package/{gsd/commands-gsd → src/commands/ccp}/research-phase.md +17 -12
  140. package/{ecc/commands → src/commands/ccp}/resume-session.md +9 -8
  141. package/{gsd/commands-gsd → src/commands/ccp}/resume-work.md +3 -3
  142. package/src/commands/ccp/review-backlog.md +61 -0
  143. package/src/commands/ccp/review.md +37 -0
  144. package/src/commands/ccp/rules-distill.md +12 -0
  145. package/src/commands/ccp/rust-build.md +188 -0
  146. package/src/commands/ccp/rust-review.md +143 -0
  147. package/src/commands/ccp/rust-test.md +309 -0
  148. package/{ecc/commands → src/commands/ccp}/save-session.md +2 -1
  149. package/src/commands/ccp/secure-phase.md +35 -0
  150. package/src/commands/ccp/session-report.md +19 -0
  151. package/{ecc/commands → src/commands/ccp}/sessions.md +39 -34
  152. package/src/commands/ccp/set-profile.md +12 -0
  153. package/{gsd/commands-gsd → src/commands/ccp}/settings.md +5 -5
  154. package/src/commands/ccp/setup-pm.md +81 -0
  155. package/{kit/commands → src/commands/ccp}/setup-refresh.md +4 -3
  156. package/{kit/commands → src/commands/ccp}/setup.md +67 -40
  157. package/src/commands/ccp/ship.md +23 -0
  158. package/src/commands/ccp/skill-create.md +172 -0
  159. package/src/commands/ccp/skill-health.md +51 -0
  160. package/src/commands/ccp/stats.md +18 -0
  161. package/src/commands/ccp/tdd.md +329 -0
  162. package/src/commands/ccp/test-coverage.md +74 -0
  163. package/src/commands/ccp/thread.md +127 -0
  164. package/{kit/commands → src/commands/ccp}/tool-guide.md +2 -1
  165. package/src/commands/ccp/ui-phase.md +34 -0
  166. package/src/commands/ccp/ui-review.md +32 -0
  167. package/src/commands/ccp/update-codemaps.md +77 -0
  168. package/src/commands/ccp/update-docs.md +89 -0
  169. package/{gsd/commands-gsd → src/commands/ccp}/update.md +5 -5
  170. package/{gsd/commands-gsd → src/commands/ccp}/validate-phase.md +3 -3
  171. package/{gsd/commands-gsd → src/commands/ccp}/verify-work.md +5 -5
  172. package/{ecc/commands → src/commands/ccp}/verify.md +5 -0
  173. package/src/commands/ccp/workstreams.md +68 -0
  174. package/{ecc → src}/examples/CLAUDE.md +4 -4
  175. package/{ecc → src}/examples/django-api-CLAUDE.md +5 -5
  176. package/{ecc → src}/examples/go-microservice-CLAUDE.md +6 -6
  177. package/{ecc → src}/examples/rust-api-CLAUDE.md +4 -4
  178. package/{ecc → src}/examples/saas-nextjs-CLAUDE.md +8 -8
  179. package/{gsd/hooks/gsd-context-monitor.js → src/hooks/ccp-context-monitor.js} +3 -3
  180. package/src/hooks/ccp-prompt-guard.js +96 -0
  181. package/{gsd/hooks/gsd-statusline.js → src/hooks/ccp-statusline.js} +7 -7
  182. package/src/hooks/ccp-workflow-guard.js +94 -0
  183. package/src/hooks/config-protection.js +141 -0
  184. package/{kit → src}/hooks/kit-check-update.js +7 -4
  185. package/src/hooks/mcp-health-check.js +620 -0
  186. package/{ecc/scripts → src}/hooks/run-with-flags-shell.sh +1 -1
  187. package/{ecc/scripts → src}/hooks/run-with-flags.js +74 -13
  188. package/src/hooks/session-end-marker.js +29 -0
  189. package/{ecc/scripts → src}/hooks/session-end.js +83 -40
  190. package/{ecc/scripts → src}/hooks/session-start.js +76 -10
  191. package/{ecc/scripts → src}/lib/hook-flags.js +8 -4
  192. package/{ecc/scripts → src}/lib/project-detect.js +2 -1
  193. package/{ecc/scripts → src}/lib/session-manager.d.ts +5 -1
  194. package/{ecc/scripts → src}/lib/session-manager.js +202 -92
  195. package/{ecc/scripts → src}/lib/utils.d.ts +23 -1
  196. package/{ecc/scripts → src}/lib/utils.js +91 -3
  197. package/{gsd/get-shit-done/bin/gsd-tools.cjs → src/pilot/bin/ccp-tools.cjs} +257 -86
  198. package/{gsd/get-shit-done → src/pilot}/bin/lib/commands.cjs +1 -1
  199. package/src/pilot/bin/lib/config.cjs +444 -0
  200. package/src/pilot/bin/lib/core.cjs +1190 -0
  201. package/src/pilot/bin/lib/init.cjs +1281 -0
  202. package/src/pilot/bin/lib/model-profiles.cjs +67 -0
  203. package/{gsd/get-shit-done → src/pilot}/bin/lib/phase.cjs +2 -2
  204. package/src/pilot/bin/lib/security.cjs +382 -0
  205. package/{gsd/get-shit-done → src/pilot}/bin/lib/state.cjs +1 -1
  206. package/src/pilot/bin/lib/uat.cjs +282 -0
  207. package/{gsd/get-shit-done → src/pilot}/bin/lib/verify.cjs +10 -10
  208. package/{gsd/get-shit-done → src/pilot}/references/continuation-format.md +16 -16
  209. package/{gsd/get-shit-done → src/pilot}/references/decimal-phase-calculation.md +5 -5
  210. package/{gsd/get-shit-done → src/pilot}/references/git-integration.md +5 -5
  211. package/{gsd/get-shit-done → src/pilot}/references/git-planning-commit.md +4 -4
  212. package/src/pilot/references/mcp-servers.json +153 -0
  213. package/{gsd/get-shit-done → src/pilot}/references/model-profile-resolution.md +2 -2
  214. package/{gsd/get-shit-done → src/pilot}/references/model-profiles.md +20 -20
  215. package/{gsd/get-shit-done → src/pilot}/references/phase-argument-parsing.md +4 -4
  216. package/{gsd/get-shit-done → src/pilot}/references/planning-config.md +15 -15
  217. package/{gsd/get-shit-done → src/pilot}/references/ui-brand.md +5 -5
  218. package/{gsd/get-shit-done → src/pilot}/references/verification-patterns.md +1 -1
  219. package/{gsd/get-shit-done → src/pilot}/templates/DEBUG.md +1 -1
  220. package/{gsd/get-shit-done → src/pilot}/templates/UAT.md +3 -3
  221. package/src/pilot/templates/UI-SPEC.md +100 -0
  222. package/{gsd/get-shit-done → src/pilot}/templates/VALIDATION.md +1 -1
  223. package/src/pilot/templates/claude-md.md +122 -0
  224. package/{gsd/get-shit-done → src/pilot}/templates/codebase/architecture.md +2 -2
  225. package/{gsd/get-shit-done → src/pilot}/templates/codebase/structure.md +13 -13
  226. package/{gsd/get-shit-done → src/pilot}/templates/context.md +4 -4
  227. package/src/pilot/templates/copilot-instructions.md +7 -0
  228. package/{gsd/get-shit-done → src/pilot}/templates/debug-subagent-prompt.md +4 -4
  229. package/src/pilot/templates/dev-preferences.md +21 -0
  230. package/{gsd/get-shit-done → src/pilot}/templates/discovery.md +2 -2
  231. package/src/pilot/templates/discussion-log.md +63 -0
  232. package/{gsd/get-shit-done → src/pilot}/templates/phase-prompt.md +12 -12
  233. package/{gsd/get-shit-done → src/pilot}/templates/planner-subagent-prompt.md +7 -7
  234. package/{gsd/get-shit-done → src/pilot}/templates/project.md +1 -1
  235. package/{gsd/get-shit-done → src/pilot}/templates/research.md +2 -2
  236. package/{gsd/get-shit-done → src/pilot}/templates/state.md +2 -2
  237. package/{gsd/get-shit-done → src/pilot}/templates/summary-complex.md +1 -1
  238. package/{gsd/get-shit-done → src/pilot}/workflows/add-phase.md +11 -11
  239. package/{gsd/get-shit-done → src/pilot}/workflows/add-tests.md +15 -15
  240. package/{gsd/get-shit-done → src/pilot}/workflows/add-todo.md +7 -7
  241. package/{gsd/get-shit-done → src/pilot}/workflows/audit-milestone.md +24 -16
  242. package/src/pilot/workflows/audit-uat.md +109 -0
  243. package/src/pilot/workflows/autonomous.md +891 -0
  244. package/{gsd/get-shit-done → src/pilot}/workflows/check-todos.md +10 -10
  245. package/{gsd/get-shit-done → src/pilot}/workflows/cleanup.md +3 -3
  246. package/{gsd/get-shit-done → src/pilot}/workflows/complete-milestone.md +19 -16
  247. package/{gsd/get-shit-done → src/pilot}/workflows/diagnose-issues.md +9 -4
  248. package/{gsd/get-shit-done → src/pilot}/workflows/discovery-phase.md +8 -8
  249. package/src/pilot/workflows/discuss-phase-assumptions.md +653 -0
  250. package/{gsd/get-shit-done → src/pilot}/workflows/discuss-phase.md +407 -49
  251. package/src/pilot/workflows/do.md +104 -0
  252. package/src/pilot/workflows/docs-update.md +1165 -0
  253. package/src/pilot/workflows/execute-phase.md +821 -0
  254. package/{gsd/get-shit-done → src/pilot}/workflows/execute-plan.md +79 -28
  255. package/src/pilot/workflows/fast.md +105 -0
  256. package/src/pilot/workflows/forensics.md +265 -0
  257. package/{gsd/get-shit-done → src/pilot}/workflows/health.md +34 -11
  258. package/src/pilot/workflows/help.md +767 -0
  259. package/{gsd/get-shit-done → src/pilot}/workflows/insert-phase.md +10 -10
  260. package/{gsd/get-shit-done → src/pilot}/workflows/list-phase-assumptions.md +4 -4
  261. package/src/pilot/workflows/manager.md +362 -0
  262. package/{gsd/get-shit-done → src/pilot}/workflows/map-codebase.md +27 -17
  263. package/src/pilot/workflows/milestone-summary.md +223 -0
  264. package/{gsd/get-shit-done → src/pilot}/workflows/new-milestone.md +135 -33
  265. package/{gsd/get-shit-done → src/pilot}/workflows/new-project.md +152 -79
  266. package/src/pilot/workflows/next.md +97 -0
  267. package/src/pilot/workflows/node-repair.md +92 -0
  268. package/src/pilot/workflows/note.md +156 -0
  269. package/src/pilot/workflows/pause-work.md +177 -0
  270. package/{gsd/get-shit-done → src/pilot}/workflows/plan-milestone-gaps.md +10 -11
  271. package/src/pilot/workflows/plan-phase.md +859 -0
  272. package/src/pilot/workflows/plant-seed.md +169 -0
  273. package/src/pilot/workflows/pr-branch.md +129 -0
  274. package/src/pilot/workflows/profile-user.md +452 -0
  275. package/{gsd/get-shit-done → src/pilot}/workflows/progress.md +95 -34
  276. package/{gsd/get-shit-done → src/pilot}/workflows/quick.md +33 -21
  277. package/{gsd/get-shit-done → src/pilot}/workflows/remove-phase.md +14 -14
  278. package/{gsd/get-shit-done → src/pilot}/workflows/research-phase.md +18 -10
  279. package/{gsd/get-shit-done → src/pilot}/workflows/resume-project.md +37 -18
  280. package/src/pilot/workflows/review.md +244 -0
  281. package/src/pilot/workflows/secure-phase.md +164 -0
  282. package/src/pilot/workflows/session-report.md +146 -0
  283. package/{gsd/get-shit-done → src/pilot}/workflows/set-profile.md +7 -7
  284. package/{gsd/get-shit-done → src/pilot}/workflows/settings.md +75 -22
  285. package/src/pilot/workflows/ship.md +228 -0
  286. package/src/pilot/workflows/stats.md +60 -0
  287. package/{gsd/get-shit-done → src/pilot}/workflows/transition.md +57 -17
  288. package/src/pilot/workflows/ui-phase.md +302 -0
  289. package/src/pilot/workflows/ui-review.md +165 -0
  290. package/{gsd/get-shit-done → src/pilot}/workflows/update.md +88 -58
  291. package/{gsd/get-shit-done → src/pilot}/workflows/validate-phase.md +24 -17
  292. package/{gsd/get-shit-done → src/pilot}/workflows/verify-phase.md +26 -15
  293. package/{gsd/get-shit-done → src/pilot}/workflows/verify-work.md +89 -37
  294. package/{ecc → src}/rules/common/agents.md +1 -0
  295. package/src/rules/common/code-review.md +124 -0
  296. package/{ecc → src}/rules/common/coding-style.md +21 -0
  297. package/src/rules/zh/README.md +108 -0
  298. package/src/rules/zh/agents.md +50 -0
  299. package/src/rules/zh/code-review.md +124 -0
  300. package/src/rules/zh/coding-style.md +48 -0
  301. package/src/rules/zh/development-workflow.md +44 -0
  302. package/src/rules/zh/git-workflow.md +24 -0
  303. package/src/rules/zh/hooks.md +30 -0
  304. package/src/rules/zh/patterns.md +31 -0
  305. package/src/rules/zh/performance.md +55 -0
  306. package/src/rules/zh/security.md +29 -0
  307. package/src/rules/zh/testing.md +29 -0
  308. package/src/skills/agentic-engineering/SKILL.md +63 -0
  309. package/src/skills/ai-first-engineering/SKILL.md +51 -0
  310. package/src/skills/ai-regression-testing/SKILL.md +385 -0
  311. package/src/skills/api-design/SKILL.md +523 -0
  312. package/src/skills/architecture-decision-records/SKILL.md +179 -0
  313. package/src/skills/autonomous-agent-harness/SKILL.md +267 -0
  314. package/src/skills/autonomous-loops/SKILL.md +610 -0
  315. package/src/skills/backend-patterns/SKILL.md +598 -0
  316. package/src/skills/benchmark/SKILL.md +87 -0
  317. package/src/skills/blueprint/SKILL.md +90 -0
  318. package/src/skills/browser-qa/SKILL.md +81 -0
  319. package/src/skills/bun-runtime/SKILL.md +84 -0
  320. package/src/skills/claude-api/SKILL.md +337 -0
  321. package/src/skills/codebase-onboarding/SKILL.md +233 -0
  322. package/src/skills/coding-standards/SKILL.md +530 -0
  323. package/src/skills/content-hash-cache-pattern/SKILL.md +161 -0
  324. package/src/skills/context-budget/SKILL.md +135 -0
  325. package/{ecc → src}/skills/continuous-learning-v2/SKILL.md +6 -6
  326. package/{ecc → src}/skills/continuous-learning-v2/agents/observer-loop.sh +1 -1
  327. package/{ecc → src}/skills/continuous-learning-v2/agents/observer.md +1 -1
  328. package/src/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  329. package/src/skills/cpp-coding-standards/SKILL.md +723 -0
  330. package/src/skills/cpp-testing/SKILL.md +324 -0
  331. package/src/skills/database-migrations/SKILL.md +429 -0
  332. package/src/skills/deep-research/SKILL.md +155 -0
  333. package/src/skills/deployment-patterns/SKILL.md +427 -0
  334. package/src/skills/design-system/SKILL.md +82 -0
  335. package/src/skills/django-patterns/SKILL.md +734 -0
  336. package/src/skills/django-security/SKILL.md +593 -0
  337. package/src/skills/django-tdd/SKILL.md +729 -0
  338. package/src/skills/django-verification/SKILL.md +469 -0
  339. package/src/skills/docker-patterns/SKILL.md +364 -0
  340. package/src/skills/documentation-lookup/SKILL.md +90 -0
  341. package/src/skills/e2e-testing/SKILL.md +326 -0
  342. package/src/skills/eval-harness/SKILL.md +270 -0
  343. package/src/skills/exa-search/SKILL.md +103 -0
  344. package/src/skills/flutter-dart-code-review/SKILL.md +435 -0
  345. package/src/skills/frontend-patterns/SKILL.md +642 -0
  346. package/src/skills/gan-style-harness/SKILL.md +278 -0
  347. package/src/skills/git-workflow/SKILL.md +715 -0
  348. package/src/skills/golang-patterns/SKILL.md +674 -0
  349. package/src/skills/golang-testing/SKILL.md +720 -0
  350. package/src/skills/hexagonal-architecture/SKILL.md +276 -0
  351. package/src/skills/iterative-retrieval/SKILL.md +211 -0
  352. package/src/skills/java-coding-standards/SKILL.md +147 -0
  353. package/src/skills/jpa-patterns/SKILL.md +151 -0
  354. package/src/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  355. package/src/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  356. package/src/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  357. package/src/skills/kotlin-patterns/SKILL.md +711 -0
  358. package/src/skills/kotlin-testing/SKILL.md +824 -0
  359. package/src/skills/laravel-patterns/SKILL.md +415 -0
  360. package/src/skills/laravel-plugin-discovery/SKILL.md +229 -0
  361. package/src/skills/laravel-security/SKILL.md +285 -0
  362. package/src/skills/laravel-tdd/SKILL.md +283 -0
  363. package/src/skills/laravel-verification/SKILL.md +179 -0
  364. package/src/skills/mcp-server-patterns/SKILL.md +67 -0
  365. package/src/skills/nextjs-turbopack/SKILL.md +44 -0
  366. package/src/skills/nuxt4-patterns/SKILL.md +100 -0
  367. package/src/skills/opensource-pipeline/SKILL.md +255 -0
  368. package/src/skills/perl-patterns/SKILL.md +504 -0
  369. package/src/skills/perl-security/SKILL.md +503 -0
  370. package/src/skills/perl-testing/SKILL.md +475 -0
  371. package/src/skills/postgres-patterns/SKILL.md +147 -0
  372. package/src/skills/project-flow-ops/SKILL.md +111 -0
  373. package/src/skills/project-guidelines-example/SKILL.md +349 -0
  374. package/src/skills/prompt-optimizer/SKILL.md +397 -0
  375. package/src/skills/python-patterns/SKILL.md +750 -0
  376. package/src/skills/python-testing/SKILL.md +816 -0
  377. package/src/skills/pytorch-patterns/SKILL.md +396 -0
  378. package/src/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  379. package/src/skills/repo-scan/SKILL.md +78 -0
  380. package/src/skills/rules-distill/SKILL.md +264 -0
  381. package/src/skills/rules-distill/scripts/scan-rules.sh +58 -0
  382. package/src/skills/rules-distill/scripts/scan-skills.sh +129 -0
  383. package/src/skills/rust-patterns/SKILL.md +499 -0
  384. package/src/skills/rust-testing/SKILL.md +500 -0
  385. package/src/skills/safety-guard/SKILL.md +69 -0
  386. package/src/skills/search-first/SKILL.md +161 -0
  387. package/src/skills/security-review/SKILL.md +495 -0
  388. package/src/skills/security-review/cloud-infrastructure-security.md +361 -0
  389. package/src/skills/security-scan/SKILL.md +165 -0
  390. package/src/skills/springboot-patterns/SKILL.md +314 -0
  391. package/src/skills/springboot-security/SKILL.md +272 -0
  392. package/src/skills/springboot-tdd/SKILL.md +158 -0
  393. package/src/skills/springboot-verification/SKILL.md +231 -0
  394. package/src/skills/swift-concurrency-6-2/SKILL.md +216 -0
  395. package/src/skills/tdd-workflow/SKILL.md +410 -0
  396. package/src/skills/token-budget-advisor/SKILL.md +133 -0
  397. package/{ecc/skills/verification-loop-SKILL.md → src/skills/verification-loop/SKILL.md} +1 -1
  398. package/src/skills/workspace-surface-audit/SKILL.md +125 -0
  399. package/ecc/scripts/hooks/session-end-marker.js +0 -15
  400. package/gsd/LICENSE +0 -21
  401. package/gsd/commands-gsd/discuss-phase.md +0 -90
  402. package/gsd/commands-gsd/execute-phase.md +0 -41
  403. package/gsd/commands-gsd/join-discord.md +0 -18
  404. package/gsd/commands-gsd/reapply-patches.md +0 -123
  405. package/gsd/commands-gsd/set-profile.md +0 -34
  406. package/gsd/get-shit-done/bin/lib/config.cjs +0 -169
  407. package/gsd/get-shit-done/bin/lib/core.cjs +0 -492
  408. package/gsd/get-shit-done/bin/lib/init.cjs +0 -710
  409. package/gsd/get-shit-done/workflows/execute-phase.md +0 -459
  410. package/gsd/get-shit-done/workflows/help.md +0 -489
  411. package/gsd/get-shit-done/workflows/pause-work.md +0 -122
  412. package/gsd/get-shit-done/workflows/plan-phase.md +0 -560
  413. package/gsd/hooks/gsd-check-update.js +0 -81
  414. package/kit/CLAUDE.md +0 -43
  415. package/kit/commands/kit/update.md +0 -46
  416. package/kit/mcp.json +0 -10
  417. package/kit/rules/code-style.md +0 -24
  418. /package/{ecc → src}/agents/architect.md +0 -0
  419. /package/{ecc → src}/agents/code-reviewer.md +0 -0
  420. /package/{ecc → src}/agents/e2e-runner.md +0 -0
  421. /package/{ecc → src}/agents/security-reviewer.md +0 -0
  422. /package/{ecc → src}/agents/tdd-guide.md +0 -0
  423. /package/{ecc/rules → src/available-rules}/golang/coding-style.md +0 -0
  424. /package/{ecc/rules → src/available-rules}/golang/hooks.md +0 -0
  425. /package/{ecc/rules → src/available-rules}/golang/patterns.md +0 -0
  426. /package/{ecc/rules → src/available-rules}/golang/security.md +0 -0
  427. /package/{ecc/rules → src/available-rules}/golang/testing.md +0 -0
  428. /package/{ecc/rules → src/available-rules}/kotlin/coding-style.md +0 -0
  429. /package/{ecc/rules → src/available-rules}/kotlin/patterns.md +0 -0
  430. /package/{ecc/rules → src/available-rules}/kotlin/security.md +0 -0
  431. /package/{ecc/rules → src/available-rules}/kotlin/testing.md +0 -0
  432. /package/{ecc/rules → src/available-rules}/perl/coding-style.md +0 -0
  433. /package/{ecc/rules → src/available-rules}/perl/hooks.md +0 -0
  434. /package/{ecc/rules → src/available-rules}/perl/patterns.md +0 -0
  435. /package/{ecc/rules → src/available-rules}/perl/security.md +0 -0
  436. /package/{ecc/rules → src/available-rules}/perl/testing.md +0 -0
  437. /package/{ecc/rules → src/available-rules}/php/coding-style.md +0 -0
  438. /package/{ecc/rules → src/available-rules}/php/hooks.md +0 -0
  439. /package/{ecc/rules → src/available-rules}/php/patterns.md +0 -0
  440. /package/{ecc/rules → src/available-rules}/php/security.md +0 -0
  441. /package/{ecc/rules → src/available-rules}/php/testing.md +0 -0
  442. /package/{ecc/rules → src/available-rules}/python/coding-style.md +0 -0
  443. /package/{ecc/rules → src/available-rules}/python/hooks.md +0 -0
  444. /package/{ecc/rules → src/available-rules}/python/patterns.md +0 -0
  445. /package/{ecc/rules → src/available-rules}/python/security.md +0 -0
  446. /package/{ecc/rules → src/available-rules}/python/testing.md +0 -0
  447. /package/{ecc/rules → src/available-rules}/swift/coding-style.md +0 -0
  448. /package/{ecc/rules → src/available-rules}/swift/hooks.md +0 -0
  449. /package/{ecc/rules → src/available-rules}/swift/patterns.md +0 -0
  450. /package/{ecc/rules → src/available-rules}/swift/security.md +0 -0
  451. /package/{ecc/rules → src/available-rules}/swift/testing.md +0 -0
  452. /package/{ecc/rules → src/available-rules}/typescript/coding-style.md +0 -0
  453. /package/{ecc/rules → src/available-rules}/typescript/hooks.md +0 -0
  454. /package/{ecc/rules → src/available-rules}/typescript/patterns.md +0 -0
  455. /package/{ecc/rules → src/available-rules}/typescript/security.md +0 -0
  456. /package/{ecc/rules → src/available-rules}/typescript/testing.md +0 -0
  457. /package/{ecc → src}/contexts/dev.md +0 -0
  458. /package/{ecc → src}/contexts/research.md +0 -0
  459. /package/{ecc → src}/contexts/review.md +0 -0
  460. /package/{ecc → src}/examples/user-CLAUDE.md +0 -0
  461. /package/{ecc/scripts → src}/hooks/check-hook-enabled.js +0 -0
  462. /package/{ecc/scripts → src}/hooks/evaluate-session.js +0 -0
  463. /package/{ecc/scripts → src}/hooks/pre-compact.js +0 -0
  464. /package/{ecc/scripts → src}/hooks/suggest-compact.js +0 -0
  465. /package/{ecc/scripts → src}/lib/package-manager.d.ts +0 -0
  466. /package/{ecc/scripts → src}/lib/package-manager.js +0 -0
  467. /package/{ecc/scripts → src}/lib/resolve-formatter.js +0 -0
  468. /package/{ecc/scripts → src}/lib/session-aliases.d.ts +0 -0
  469. /package/{ecc/scripts → src}/lib/session-aliases.js +0 -0
  470. /package/{ecc/scripts → src}/lib/shell-split.js +0 -0
  471. /package/{gsd/get-shit-done → src/pilot}/bin/lib/frontmatter.cjs +0 -0
  472. /package/{gsd/get-shit-done → src/pilot}/bin/lib/milestone.cjs +0 -0
  473. /package/{gsd/get-shit-done → src/pilot}/bin/lib/roadmap.cjs +0 -0
  474. /package/{gsd/get-shit-done → src/pilot}/bin/lib/template.cjs +0 -0
  475. /package/{gsd/get-shit-done → src/pilot}/references/checkpoints.md +0 -0
  476. /package/{gsd/get-shit-done → src/pilot}/references/questioning.md +0 -0
  477. /package/{gsd/get-shit-done → src/pilot}/references/tdd.md +0 -0
  478. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/concerns.md +0 -0
  479. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/conventions.md +0 -0
  480. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/integrations.md +0 -0
  481. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/stack.md +0 -0
  482. /package/{gsd/get-shit-done → src/pilot}/templates/codebase/testing.md +0 -0
  483. /package/{gsd/get-shit-done → src/pilot}/templates/config.json +0 -0
  484. /package/{gsd/get-shit-done → src/pilot}/templates/continue-here.md +0 -0
  485. /package/{gsd/get-shit-done → src/pilot}/templates/milestone-archive.md +0 -0
  486. /package/{gsd/get-shit-done → src/pilot}/templates/milestone.md +0 -0
  487. /package/{gsd/get-shit-done → src/pilot}/templates/requirements.md +0 -0
  488. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/ARCHITECTURE.md +0 -0
  489. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/FEATURES.md +0 -0
  490. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/PITFALLS.md +0 -0
  491. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/STACK.md +0 -0
  492. /package/{gsd/get-shit-done → src/pilot}/templates/research-project/SUMMARY.md +0 -0
  493. /package/{gsd/get-shit-done → src/pilot}/templates/retrospective.md +0 -0
  494. /package/{gsd/get-shit-done → src/pilot}/templates/roadmap.md +0 -0
  495. /package/{gsd/get-shit-done → src/pilot}/templates/summary-minimal.md +0 -0
  496. /package/{gsd/get-shit-done → src/pilot}/templates/summary-standard.md +0 -0
  497. /package/{gsd/get-shit-done → src/pilot}/templates/summary.md +0 -0
  498. /package/{gsd/get-shit-done → src/pilot}/templates/user-setup.md +0 -0
  499. /package/{gsd/get-shit-done → src/pilot}/templates/verification-report.md +0 -0
  500. /package/{ecc → src}/rules/common/development-workflow.md +0 -0
  501. /package/{ecc → src}/rules/common/git-workflow.md +0 -0
  502. /package/{ecc → src}/rules/common/hooks.md +0 -0
  503. /package/{ecc → src}/rules/common/patterns.md +0 -0
  504. /package/{ecc → src}/rules/common/performance.md +0 -0
  505. /package/{ecc → src}/rules/common/security.md +0 -0
  506. /package/{ecc → src}/rules/common/testing.md +0 -0
  507. /package/{ecc → src}/skills/continuous-learning-v2/agents/start-observer.sh +0 -0
  508. /package/{ecc → src}/skills/continuous-learning-v2/config.json +0 -0
  509. /package/{ecc → src}/skills/continuous-learning-v2/hooks/observe.sh +0 -0
  510. /package/{ecc → src}/skills/continuous-learning-v2/scripts/detect-project.sh +0 -0
  511. /package/{ecc → src}/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -0
  512. /package/{ecc → src}/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -0
  513. /package/{ecc → src}/skills/strategic-compact/SKILL.md +0 -0
  514. /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.
@@ -117,7 +117,7 @@ Set a mental checkpoint:
117
117
  - After finishing a component
118
118
  - Before moving to next task
119
119
 
120
- Run: /verify
120
+ Run: /ccp:verify
121
121
  ```
122
122
 
123
123
  ## Integration with Hooks
@@ -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
- });