@macpaw/cctk 1.0.0-beta.1

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 (415) hide show
  1. package/License +21 -0
  2. package/README.md +142 -0
  3. package/bin/index.js +5 -0
  4. package/dist/index.js +1 -0
  5. package/package.json +65 -0
  6. package/templates/claude/agents/brainstormer.md +113 -0
  7. package/templates/claude/agents/code-reviewer.md +157 -0
  8. package/templates/claude/agents/copywriter.md +110 -0
  9. package/templates/claude/agents/database-admin.md +92 -0
  10. package/templates/claude/agents/debugger.md +137 -0
  11. package/templates/claude/agents/docs-manager.md +208 -0
  12. package/templates/claude/agents/fullstack-developer.md +95 -0
  13. package/templates/claude/agents/git-manager.md +394 -0
  14. package/templates/claude/agents/journal-writer.md +113 -0
  15. package/templates/claude/agents/mcp-manager.md +89 -0
  16. package/templates/claude/agents/planner.md +108 -0
  17. package/templates/claude/agents/project-manager.md +125 -0
  18. package/templates/claude/agents/registry.json +304 -0
  19. package/templates/claude/agents/researcher.md +37 -0
  20. package/templates/claude/agents/scout-external.md +140 -0
  21. package/templates/claude/agents/scout.md +106 -0
  22. package/templates/claude/agents/tester.md +105 -0
  23. package/templates/claude/agents/ui-ux-designer.md +208 -0
  24. package/templates/claude/commands/ask.md +56 -0
  25. package/templates/claude/commands/bootstrap/auto/fast.md +106 -0
  26. package/templates/claude/commands/bootstrap/auto/parallel.md +64 -0
  27. package/templates/claude/commands/bootstrap/auto.md +110 -0
  28. package/templates/claude/commands/bootstrap.md +130 -0
  29. package/templates/claude/commands/brainstorm.md +75 -0
  30. package/templates/claude/commands/code/auto.md +198 -0
  31. package/templates/claude/commands/code/no-test.md +172 -0
  32. package/templates/claude/commands/code/parallel.md +100 -0
  33. package/templates/claude/commands/code.md +197 -0
  34. package/templates/claude/commands/coding-level.md +37 -0
  35. package/templates/claude/commands/content/cro.md +41 -0
  36. package/templates/claude/commands/content/enhance.md +12 -0
  37. package/templates/claude/commands/content/fast.md +11 -0
  38. package/templates/claude/commands/content/good.md +14 -0
  39. package/templates/claude/commands/cook/auto/fast.md +26 -0
  40. package/templates/claude/commands/cook/auto/parallel.md +49 -0
  41. package/templates/claude/commands/cook/auto.md +15 -0
  42. package/templates/claude/commands/cook.md +101 -0
  43. package/templates/claude/commands/debug.md +13 -0
  44. package/templates/claude/commands/docs/init.md +37 -0
  45. package/templates/claude/commands/docs/summarize.md +22 -0
  46. package/templates/claude/commands/docs/update.md +78 -0
  47. package/templates/claude/commands/fix/ci.md +17 -0
  48. package/templates/claude/commands/fix/fast.md +18 -0
  49. package/templates/claude/commands/fix/hard.md +35 -0
  50. package/templates/claude/commands/fix/logs.md +26 -0
  51. package/templates/claude/commands/fix/parallel.md +54 -0
  52. package/templates/claude/commands/fix/test.md +20 -0
  53. package/templates/claude/commands/fix/types.md +9 -0
  54. package/templates/claude/commands/fix/ui.md +33 -0
  55. package/templates/claude/commands/fix.md +43 -0
  56. package/templates/claude/commands/git/cm.md +5 -0
  57. package/templates/claude/commands/git/cp.md +4 -0
  58. package/templates/claude/commands/git/merge.md +40 -0
  59. package/templates/claude/commands/git/pr.md +50 -0
  60. package/templates/claude/commands/journal.md +7 -0
  61. package/templates/claude/commands/kanban.md +99 -0
  62. package/templates/claude/commands/plan/archive.md +57 -0
  63. package/templates/claude/commands/plan/ci.md +33 -0
  64. package/templates/claude/commands/plan/cro.md +67 -0
  65. package/templates/claude/commands/plan/fast.md +66 -0
  66. package/templates/claude/commands/plan/hard.md +92 -0
  67. package/templates/claude/commands/plan/parallel.md +129 -0
  68. package/templates/claude/commands/plan/two.md +45 -0
  69. package/templates/claude/commands/plan/validate.md +117 -0
  70. package/templates/claude/commands/plan.md +30 -0
  71. package/templates/claude/commands/preview.md +87 -0
  72. package/templates/claude/commands/registry.json +313 -0
  73. package/templates/claude/commands/review/codebase/parallel.md +122 -0
  74. package/templates/claude/commands/review/codebase.md +47 -0
  75. package/templates/claude/commands/scout/ext.md +35 -0
  76. package/templates/claude/commands/scout.md +28 -0
  77. package/templates/claude/commands/skill/add.md +36 -0
  78. package/templates/claude/commands/skill/create.md +29 -0
  79. package/templates/claude/commands/skill/fix-logs.md +22 -0
  80. package/templates/claude/commands/skill/optimize/auto.md +25 -0
  81. package/templates/claude/commands/skill/optimize.md +34 -0
  82. package/templates/claude/commands/skill/plan.md +45 -0
  83. package/templates/claude/commands/test/ui.md +91 -0
  84. package/templates/claude/commands/test.md +8 -0
  85. package/templates/claude/commands/use-mcp.md +34 -0
  86. package/templates/claude/commands/watzup.md +8 -0
  87. package/templates/claude/commands/worktree.md +126 -0
  88. package/templates/claude/hooks/dev-rules-reminder.cjs +258 -0
  89. package/templates/claude/hooks/docs/README.md +42 -0
  90. package/templates/claude/hooks/lib/cctk-config-utils.cjs +751 -0
  91. package/templates/claude/hooks/lib/cctk-paths.cjs +106 -0
  92. package/templates/claude/hooks/lib/context-tracker.cjs +346 -0
  93. package/templates/claude/hooks/privacy-block.cjs +289 -0
  94. package/templates/claude/hooks/registry.json +77 -0
  95. package/templates/claude/hooks/scout-block/broad-pattern-detector.cjs +293 -0
  96. package/templates/claude/hooks/scout-block/error-formatter.cjs +156 -0
  97. package/templates/claude/hooks/scout-block/path-extractor.cjs +359 -0
  98. package/templates/claude/hooks/scout-block/pattern-matcher.cjs +184 -0
  99. package/templates/claude/hooks/scout-block/vendor/ignore.js +626 -0
  100. package/templates/claude/hooks/scout-block.cjs +167 -0
  101. package/templates/claude/hooks/session-end.cjs +35 -0
  102. package/templates/claude/hooks/session-init.cjs +214 -0
  103. package/templates/claude/hooks/subagent-init.cjs +161 -0
  104. package/templates/claude/hooks/write-compact-marker.cjs +153 -0
  105. package/templates/claude/output-styles/coding-level-1.md +148 -0
  106. package/templates/claude/output-styles/coding-level-2.md +159 -0
  107. package/templates/claude/output-styles/coding-level-3.md +91 -0
  108. package/templates/claude/scripts/README.md +33 -0
  109. package/templates/claude/scripts/generate-catalogs.cjs +318 -0
  110. package/templates/claude/scripts/registry.json +48 -0
  111. package/templates/claude/scripts/set-active-plan.cjs +45 -0
  112. package/templates/claude/scripts/validate-docs.cjs +447 -0
  113. package/templates/claude/scripts/worktree.cjs +658 -0
  114. package/templates/claude/skills/README.md +112 -0
  115. package/templates/claude/skills/ai-artist/SKILL.md +75 -0
  116. package/templates/claude/skills/ai-artist/references/advanced-techniques.md +184 -0
  117. package/templates/claude/skills/ai-artist/references/domain-code.md +66 -0
  118. package/templates/claude/skills/ai-artist/references/domain-data.md +72 -0
  119. package/templates/claude/skills/ai-artist/references/domain-marketing.md +66 -0
  120. package/templates/claude/skills/ai-artist/references/domain-patterns.md +33 -0
  121. package/templates/claude/skills/ai-artist/references/domain-writing.md +68 -0
  122. package/templates/claude/skills/ai-artist/references/image-prompting.md +141 -0
  123. package/templates/claude/skills/ai-artist/references/llm-prompting.md +165 -0
  124. package/templates/claude/skills/ai-artist/references/nano-banana.md +59 -0
  125. package/templates/claude/skills/ai-artist/references/reasoning-techniques.md +201 -0
  126. package/templates/claude/skills/backend-development/SKILL.md +95 -0
  127. package/templates/claude/skills/backend-development/references/backend-api-design.md +495 -0
  128. package/templates/claude/skills/backend-development/references/backend-architecture.md +454 -0
  129. package/templates/claude/skills/backend-development/references/backend-authentication.md +338 -0
  130. package/templates/claude/skills/backend-development/references/backend-code-quality.md +659 -0
  131. package/templates/claude/skills/backend-development/references/backend-debugging.md +904 -0
  132. package/templates/claude/skills/backend-development/references/backend-devops.md +494 -0
  133. package/templates/claude/skills/backend-development/references/backend-mindset.md +387 -0
  134. package/templates/claude/skills/backend-development/references/backend-performance.md +397 -0
  135. package/templates/claude/skills/backend-development/references/backend-security.md +290 -0
  136. package/templates/claude/skills/backend-development/references/backend-technologies.md +256 -0
  137. package/templates/claude/skills/backend-development/references/backend-testing.md +429 -0
  138. package/templates/claude/skills/better-auth/SKILL.md +204 -0
  139. package/templates/claude/skills/better-auth/references/advanced-features.md +553 -0
  140. package/templates/claude/skills/better-auth/references/database-integration.md +577 -0
  141. package/templates/claude/skills/better-auth/references/email-password-auth.md +416 -0
  142. package/templates/claude/skills/better-auth/references/oauth-providers.md +430 -0
  143. package/templates/claude/skills/better-auth/scripts/better_auth_init.py +521 -0
  144. package/templates/claude/skills/chrome-devtools/SKILL.md +473 -0
  145. package/templates/claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
  146. package/templates/claude/skills/chrome-devtools/references/performance-guide.md +940 -0
  147. package/templates/claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
  148. package/templates/claude/skills/chrome-devtools/scripts/README.md +288 -0
  149. package/templates/claude/skills/chrome-devtools/scripts/aria-snapshot.js +368 -0
  150. package/templates/claude/skills/chrome-devtools/scripts/click.js +92 -0
  151. package/templates/claude/skills/chrome-devtools/scripts/console.js +85 -0
  152. package/templates/claude/skills/chrome-devtools/scripts/evaluate.js +59 -0
  153. package/templates/claude/skills/chrome-devtools/scripts/fill.js +84 -0
  154. package/templates/claude/skills/chrome-devtools/scripts/inject-auth.js +247 -0
  155. package/templates/claude/skills/chrome-devtools/scripts/install-deps.sh +11 -0
  156. package/templates/claude/skills/chrome-devtools/scripts/install.sh +36 -0
  157. package/templates/claude/skills/chrome-devtools/scripts/lib/browser.js +335 -0
  158. package/templates/claude/skills/chrome-devtools/scripts/lib/selector.js +183 -0
  159. package/templates/claude/skills/chrome-devtools/scripts/navigate.js +60 -0
  160. package/templates/claude/skills/chrome-devtools/scripts/network.js +113 -0
  161. package/templates/claude/skills/chrome-devtools/scripts/package.json +16 -0
  162. package/templates/claude/skills/chrome-devtools/scripts/performance.js +159 -0
  163. package/templates/claude/skills/chrome-devtools/scripts/screenshot.js +212 -0
  164. package/templates/claude/skills/chrome-devtools/scripts/select-ref.js +151 -0
  165. package/templates/claude/skills/chrome-devtools/scripts/snapshot.js +143 -0
  166. package/templates/claude/skills/chrome-devtools/scripts/ws-debug.js +47 -0
  167. package/templates/claude/skills/chrome-devtools/scripts/ws-full-debug.js +115 -0
  168. package/templates/claude/skills/claude-code/references/advanced-features.md +399 -0
  169. package/templates/claude/skills/claude-code/references/agent-skills.md +399 -0
  170. package/templates/claude/skills/claude-code/references/api-reference.md +498 -0
  171. package/templates/claude/skills/claude-code/references/best-practices.md +447 -0
  172. package/templates/claude/skills/claude-code/references/cicd-integration.md +428 -0
  173. package/templates/claude/skills/claude-code/references/common-workflows.md +107 -0
  174. package/templates/claude/skills/claude-code/references/configuration.md +480 -0
  175. package/templates/claude/skills/claude-code/references/enterprise-features.md +472 -0
  176. package/templates/claude/skills/claude-code/references/getting-started.md +244 -0
  177. package/templates/claude/skills/claude-code/references/hooks-and-plugins.md +444 -0
  178. package/templates/claude/skills/claude-code/references/hooks-comprehensive.md +622 -0
  179. package/templates/claude/skills/claude-code/references/ide-integration.md +316 -0
  180. package/templates/claude/skills/claude-code/references/mcp-integration.md +386 -0
  181. package/templates/claude/skills/claude-code/references/slash-commands.md +460 -0
  182. package/templates/claude/skills/claude-code/references/troubleshooting.md +455 -0
  183. package/templates/claude/skills/claude-code/skill.md +60 -0
  184. package/templates/claude/skills/code-review/SKILL.md +143 -0
  185. package/templates/claude/skills/code-review/references/code-review-reception.md +209 -0
  186. package/templates/claude/skills/code-review/references/requesting-code-review.md +105 -0
  187. package/templates/claude/skills/code-review/references/verification-before-completion.md +139 -0
  188. package/templates/claude/skills/context-engineering/SKILL.md +86 -0
  189. package/templates/claude/skills/context-engineering/references/context-compression.md +84 -0
  190. package/templates/claude/skills/context-engineering/references/context-degradation.md +93 -0
  191. package/templates/claude/skills/context-engineering/references/context-fundamentals.md +75 -0
  192. package/templates/claude/skills/context-engineering/references/context-optimization.md +82 -0
  193. package/templates/claude/skills/context-engineering/references/evaluation.md +89 -0
  194. package/templates/claude/skills/context-engineering/references/memory-systems.md +88 -0
  195. package/templates/claude/skills/context-engineering/references/multi-agent-patterns.md +90 -0
  196. package/templates/claude/skills/context-engineering/references/project-development.md +97 -0
  197. package/templates/claude/skills/context-engineering/references/tool-design.md +86 -0
  198. package/templates/claude/skills/context-engineering/scripts/compression_evaluator.py +329 -0
  199. package/templates/claude/skills/context-engineering/scripts/context_analyzer.py +294 -0
  200. package/templates/claude/skills/databases/SKILL.md +232 -0
  201. package/templates/claude/skills/databases/references/mongodb-aggregation.md +447 -0
  202. package/templates/claude/skills/databases/references/mongodb-atlas.md +465 -0
  203. package/templates/claude/skills/databases/references/mongodb-crud.md +408 -0
  204. package/templates/claude/skills/databases/references/mongodb-indexing.md +442 -0
  205. package/templates/claude/skills/databases/references/postgresql-administration.md +594 -0
  206. package/templates/claude/skills/databases/references/postgresql-performance.md +527 -0
  207. package/templates/claude/skills/databases/references/postgresql-psql-cli.md +467 -0
  208. package/templates/claude/skills/databases/references/postgresql-queries.md +475 -0
  209. package/templates/claude/skills/databases/scripts/db_backup.py +502 -0
  210. package/templates/claude/skills/databases/scripts/db_migrate.py +414 -0
  211. package/templates/claude/skills/databases/scripts/db_performance_check.py +445 -0
  212. package/templates/claude/skills/debugging/SKILL.md +84 -0
  213. package/templates/claude/skills/debugging/references/defense-in-depth.md +124 -0
  214. package/templates/claude/skills/debugging/references/root-cause-tracing.md +122 -0
  215. package/templates/claude/skills/debugging/references/systematic-debugging.md +102 -0
  216. package/templates/claude/skills/debugging/references/verification.md +123 -0
  217. package/templates/claude/skills/debugging/scripts/find-polluter.sh +63 -0
  218. package/templates/claude/skills/debugging/scripts/find-polluter.test.md +102 -0
  219. package/templates/claude/skills/devops/SKILL.md +293 -0
  220. package/templates/claude/skills/devops/references/browser-rendering.md +305 -0
  221. package/templates/claude/skills/devops/references/cloudflare-d1-kv.md +123 -0
  222. package/templates/claude/skills/devops/references/cloudflare-platform.md +271 -0
  223. package/templates/claude/skills/devops/references/cloudflare-r2-storage.md +280 -0
  224. package/templates/claude/skills/devops/references/cloudflare-workers-advanced.md +312 -0
  225. package/templates/claude/skills/devops/references/cloudflare-workers-apis.md +309 -0
  226. package/templates/claude/skills/devops/references/cloudflare-workers-basics.md +418 -0
  227. package/templates/claude/skills/devops/references/docker-basics.md +297 -0
  228. package/templates/claude/skills/devops/references/docker-compose.md +292 -0
  229. package/templates/claude/skills/devops/references/gcloud-platform.md +307 -0
  230. package/templates/claude/skills/devops/references/gcloud-services.md +304 -0
  231. package/templates/claude/skills/devops/scripts/cloudflare_deploy.py +269 -0
  232. package/templates/claude/skills/devops/scripts/docker_optimize.py +320 -0
  233. package/templates/claude/skills/docs-seeker/SKILL.md +95 -0
  234. package/templates/claude/skills/docs-seeker/package.json +24 -0
  235. package/templates/claude/skills/docs-seeker/references/advanced.md +78 -0
  236. package/templates/claude/skills/docs-seeker/references/context7-patterns.md +68 -0
  237. package/templates/claude/skills/docs-seeker/references/errors.md +68 -0
  238. package/templates/claude/skills/docs-seeker/scripts/analyze-llms-txt.js +245 -0
  239. package/templates/claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
  240. package/templates/claude/skills/docs-seeker/scripts/fetch-docs.js +212 -0
  241. package/templates/claude/skills/docs-seeker/workflows/library-search.md +87 -0
  242. package/templates/claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
  243. package/templates/claude/skills/docs-seeker/workflows/topic-search.md +77 -0
  244. package/templates/claude/skills/frontend-design/SKILL.md +85 -0
  245. package/templates/claude/skills/frontend-design/references/analysis-best-practices.md +80 -0
  246. package/templates/claude/skills/frontend-design/references/analysis-prompts.md +141 -0
  247. package/templates/claude/skills/frontend-design/references/analysis-techniques.md +118 -0
  248. package/templates/claude/skills/frontend-design/references/animejs.md +396 -0
  249. package/templates/claude/skills/frontend-design/references/design-extraction-overview.md +71 -0
  250. package/templates/claude/skills/frontend-design/references/extraction-best-practices.md +141 -0
  251. package/templates/claude/skills/frontend-design/references/extraction-output-templates.md +162 -0
  252. package/templates/claude/skills/frontend-design/references/extraction-prompts.md +127 -0
  253. package/templates/claude/skills/frontend-design/references/technical-accessibility.md +119 -0
  254. package/templates/claude/skills/frontend-design/references/technical-best-practices.md +97 -0
  255. package/templates/claude/skills/frontend-design/references/technical-optimization.md +44 -0
  256. package/templates/claude/skills/frontend-design/references/technical-overview.md +90 -0
  257. package/templates/claude/skills/frontend-design/references/technical-workflows.md +150 -0
  258. package/templates/claude/skills/frontend-design/references/visual-analysis-overview.md +95 -0
  259. package/templates/claude/skills/frontend-development/SKILL.md +399 -0
  260. package/templates/claude/skills/frontend-development/resources/common-patterns.md +331 -0
  261. package/templates/claude/skills/frontend-development/resources/complete-examples.md +872 -0
  262. package/templates/claude/skills/frontend-development/resources/component-patterns.md +502 -0
  263. package/templates/claude/skills/frontend-development/resources/data-fetching.md +767 -0
  264. package/templates/claude/skills/frontend-development/resources/file-organization.md +502 -0
  265. package/templates/claude/skills/frontend-development/resources/loading-and-error-states.md +501 -0
  266. package/templates/claude/skills/frontend-development/resources/performance.md +406 -0
  267. package/templates/claude/skills/frontend-development/resources/routing-guide.md +364 -0
  268. package/templates/claude/skills/frontend-development/resources/styling-guide.md +428 -0
  269. package/templates/claude/skills/frontend-development/resources/typescript-standards.md +418 -0
  270. package/templates/claude/skills/markdown-novel-viewer/SKILL.md +272 -0
  271. package/templates/claude/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
  272. package/templates/claude/skills/markdown-novel-viewer/assets/favicon.png +0 -0
  273. package/templates/claude/skills/markdown-novel-viewer/assets/novel-theme.css +872 -0
  274. package/templates/claude/skills/markdown-novel-viewer/assets/reader.js +378 -0
  275. package/templates/claude/skills/markdown-novel-viewer/assets/template.html +85 -0
  276. package/templates/claude/skills/markdown-novel-viewer/package.json +15 -0
  277. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
  278. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
  279. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +509 -0
  280. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +49 -0
  281. package/templates/claude/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
  282. package/templates/claude/skills/markdown-novel-viewer/scripts/server.cjs +398 -0
  283. package/templates/claude/skills/mcp-builder/SKILL.md +328 -0
  284. package/templates/claude/skills/mcp-builder/reference/evaluation.md +602 -0
  285. package/templates/claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
  286. package/templates/claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
  287. package/templates/claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
  288. package/templates/claude/skills/mcp-builder/scripts/connections.py +151 -0
  289. package/templates/claude/skills/mcp-builder/scripts/evaluation.py +381 -0
  290. package/templates/claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  291. package/templates/claude/skills/mcp-builder/scripts/requirements.txt +2 -0
  292. package/templates/claude/skills/mcp-management/README.md +219 -0
  293. package/templates/claude/skills/mcp-management/SKILL.md +209 -0
  294. package/templates/claude/skills/mcp-management/assets/tools.json +3146 -0
  295. package/templates/claude/skills/mcp-management/references/configuration.md +114 -0
  296. package/templates/claude/skills/mcp-management/references/gemini-cli-integration.md +209 -0
  297. package/templates/claude/skills/mcp-management/references/mcp-protocol.md +116 -0
  298. package/templates/claude/skills/mcp-management/scripts/.env.example +10 -0
  299. package/templates/claude/skills/mcp-management/scripts/cli.ts +202 -0
  300. package/templates/claude/skills/mcp-management/scripts/mcp-client.ts +247 -0
  301. package/templates/claude/skills/mcp-management/scripts/package.json +20 -0
  302. package/templates/claude/skills/mcp-management/scripts/tsconfig.json +15 -0
  303. package/templates/claude/skills/media-processing/SKILL.md +91 -0
  304. package/templates/claude/skills/media-processing/references/common-workflows.md +132 -0
  305. package/templates/claude/skills/media-processing/references/ffmpeg-encoding.md +358 -0
  306. package/templates/claude/skills/media-processing/references/ffmpeg-filters.md +503 -0
  307. package/templates/claude/skills/media-processing/references/ffmpeg-streaming.md +395 -0
  308. package/templates/claude/skills/media-processing/references/format-compatibility.md +375 -0
  309. package/templates/claude/skills/media-processing/references/imagemagick-batch.md +612 -0
  310. package/templates/claude/skills/media-processing/references/imagemagick-editing.md +623 -0
  311. package/templates/claude/skills/media-processing/references/rmbg-background-removal.md +66 -0
  312. package/templates/claude/skills/media-processing/references/troubleshooting.md +109 -0
  313. package/templates/claude/skills/media-processing/scripts/README.md +102 -0
  314. package/templates/claude/skills/media-processing/scripts/batch-remove-background.sh +124 -0
  315. package/templates/claude/skills/media-processing/scripts/batch_resize.py +342 -0
  316. package/templates/claude/skills/media-processing/scripts/media_convert.py +311 -0
  317. package/templates/claude/skills/media-processing/scripts/remove-background.sh +96 -0
  318. package/templates/claude/skills/media-processing/scripts/remove-bg-node.js +181 -0
  319. package/templates/claude/skills/mermaidjs-v11/SKILL.md +115 -0
  320. package/templates/claude/skills/mermaidjs-v11/references/cli-usage.md +228 -0
  321. package/templates/claude/skills/mermaidjs-v11/references/configuration.md +232 -0
  322. package/templates/claude/skills/mermaidjs-v11/references/diagram-types.md +315 -0
  323. package/templates/claude/skills/mermaidjs-v11/references/examples.md +344 -0
  324. package/templates/claude/skills/mermaidjs-v11/references/integration.md +310 -0
  325. package/templates/claude/skills/planning/SKILL.md +115 -0
  326. package/templates/claude/skills/planning/references/codebase-understanding.md +62 -0
  327. package/templates/claude/skills/planning/references/output-standards.md +127 -0
  328. package/templates/claude/skills/planning/references/plan-organization.md +150 -0
  329. package/templates/claude/skills/planning/references/research-phase.md +49 -0
  330. package/templates/claude/skills/planning/references/solution-design.md +63 -0
  331. package/templates/claude/skills/plans-kanban/SKILL.md +157 -0
  332. package/templates/claude/skills/plans-kanban/assets/dashboard-template.html +119 -0
  333. package/templates/claude/skills/plans-kanban/assets/dashboard.css +1594 -0
  334. package/templates/claude/skills/plans-kanban/assets/dashboard.js +659 -0
  335. package/templates/claude/skills/plans-kanban/assets/favicon.png +0 -0
  336. package/templates/claude/skills/plans-kanban/package.json +13 -0
  337. package/templates/claude/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +941 -0
  338. package/templates/claude/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
  339. package/templates/claude/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
  340. package/templates/claude/skills/plans-kanban/scripts/lib/plan-parser.cjs +194 -0
  341. package/templates/claude/skills/plans-kanban/scripts/lib/plan-scanner.cjs +277 -0
  342. package/templates/claude/skills/plans-kanban/scripts/lib/port-finder.cjs +49 -0
  343. package/templates/claude/skills/plans-kanban/scripts/lib/process-mgr.cjs +128 -0
  344. package/templates/claude/skills/plans-kanban/scripts/server.cjs +249 -0
  345. package/templates/claude/skills/problem-solving/SKILL.md +96 -0
  346. package/templates/claude/skills/problem-solving/references/attribution.md +69 -0
  347. package/templates/claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
  348. package/templates/claude/skills/problem-solving/references/inversion-exercise.md +91 -0
  349. package/templates/claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
  350. package/templates/claude/skills/problem-solving/references/scale-game.md +95 -0
  351. package/templates/claude/skills/problem-solving/references/simplification-cascades.md +80 -0
  352. package/templates/claude/skills/problem-solving/references/when-stuck.md +72 -0
  353. package/templates/claude/skills/registry.json +258 -0
  354. package/templates/claude/skills/repomix/SKILL.md +247 -0
  355. package/templates/claude/skills/repomix/references/configuration.md +211 -0
  356. package/templates/claude/skills/repomix/references/usage-patterns.md +232 -0
  357. package/templates/claude/skills/repomix/scripts/README.md +179 -0
  358. package/templates/claude/skills/repomix/scripts/repomix_batch.py +455 -0
  359. package/templates/claude/skills/repomix/scripts/repos.example.json +15 -0
  360. package/templates/claude/skills/research/SKILL.md +168 -0
  361. package/templates/claude/skills/sequential-thinking/.env.example +8 -0
  362. package/templates/claude/skills/sequential-thinking/README.md +183 -0
  363. package/templates/claude/skills/sequential-thinking/SKILL.md +94 -0
  364. package/templates/claude/skills/sequential-thinking/package.json +31 -0
  365. package/templates/claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
  366. package/templates/claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
  367. package/templates/claude/skills/sequential-thinking/references/core-patterns.md +95 -0
  368. package/templates/claude/skills/sequential-thinking/references/examples-api.md +88 -0
  369. package/templates/claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
  370. package/templates/claude/skills/sequential-thinking/references/examples-debug.md +90 -0
  371. package/templates/claude/skills/sequential-thinking/scripts/format-thought.js +182 -0
  372. package/templates/claude/skills/sequential-thinking/scripts/process-thought.js +252 -0
  373. package/templates/claude/skills/skill-creator/LICENSE.txt +202 -0
  374. package/templates/claude/skills/skill-creator/SKILL.md +266 -0
  375. package/templates/claude/skills/skill-creator/references/agent-skills-spec.md +51 -0
  376. package/templates/claude/skills/skill-creator/scripts/encoding_utils.py +21 -0
  377. package/templates/claude/skills/skill-creator/scripts/init_skill.py +304 -0
  378. package/templates/claude/skills/skill-creator/scripts/package_skill.py +110 -0
  379. package/templates/claude/skills/skill-creator/scripts/quick_validate.py +66 -0
  380. package/templates/claude/skills/template-skill/SKILL.md +6 -0
  381. package/templates/claude/skills/vitest/SKILL.md +595 -0
  382. package/templates/claude/skills/vitest/references/async-patterns.md +82 -0
  383. package/templates/claude/skills/vitest/references/mock-patterns.md +78 -0
  384. package/templates/claude/skills/vitest/references/monorepo-setup.md +185 -0
  385. package/templates/claude/skills/vitest/references/turborepo-setup.md +332 -0
  386. package/templates/claude/skills/web-frameworks/SKILL.md +324 -0
  387. package/templates/claude/skills/web-frameworks/references/nextjs-app-router.md +465 -0
  388. package/templates/claude/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
  389. package/templates/claude/skills/web-frameworks/references/nextjs-optimization.md +511 -0
  390. package/templates/claude/skills/web-frameworks/references/nextjs-server-components.md +495 -0
  391. package/templates/claude/skills/web-frameworks/references/remix-icon-integration.md +603 -0
  392. package/templates/claude/skills/web-frameworks/references/turborepo-caching.md +551 -0
  393. package/templates/claude/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
  394. package/templates/claude/skills/web-frameworks/references/turborepo-setup.md +542 -0
  395. package/templates/claude/skills/web-frameworks/scripts/nextjs_init.py +547 -0
  396. package/templates/claude/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
  397. package/templates/claude/workflows/development-rules.md +40 -0
  398. package/templates/claude/workflows/documentation-management.md +121 -0
  399. package/templates/claude/workflows/orchestration-protocol.md +16 -0
  400. package/templates/claude/workflows/primary-workflow.md +45 -0
  401. package/templates/claude/workflows/registry.json +37 -0
  402. package/templates/common/.cct.json +41 -0
  403. package/templates/common/.cctkignore +22 -0
  404. package/templates/common/.env.example +39 -0
  405. package/templates/common/.mcp.json.example +16 -0
  406. package/templates/common/metadata.json +15 -0
  407. package/templates/common/settings.json +79 -0
  408. package/templates/common/statusline.cjs +271 -0
  409. package/templates/config/.repomixignore +22 -0
  410. package/templates/config/AGENTS.md +55 -0
  411. package/templates/config/CLAUDE.md +87 -0
  412. package/templates/plans/bug-fix-template.md +69 -0
  413. package/templates/plans/feature-implementation-template.md +84 -0
  414. package/templates/plans/refactor-template.md +82 -0
  415. package/templates/plans/template-usage-guide.md +58 -0
@@ -0,0 +1,78 @@
1
+ # Advanced Mock Patterns
2
+
3
+ ## Timers
4
+
5
+ ```ts
6
+ import { vi, beforeEach, afterEach } from 'vitest'
7
+
8
+ beforeEach(() => vi.useFakeTimers())
9
+ afterEach(() => vi.useRealTimers())
10
+
11
+ it('debounces the search input', async () => {
12
+ const user = userEvent.setup({ advanceTimers: vi.advanceTimersByTime })
13
+ render(<SearchInput />)
14
+ await user.type(screen.getByRole('searchbox'), 'react')
15
+ vi.advanceTimersByTime(300)
16
+ expect(screen.getByText('Searching...')).toBeInTheDocument()
17
+ })
18
+ ```
19
+
20
+ ## Environment Variables
21
+
22
+ ```ts
23
+ it('uses the correct API base URL', () => {
24
+ vi.stubEnv('NEXT_PUBLIC_API_URL', 'https://staging.example.com')
25
+ const url = buildApiUrl('/users')
26
+ expect(url).toBe('https://staging.example.com/users')
27
+ vi.unstubAllEnvs()
28
+ })
29
+ ```
30
+
31
+ ## Global mocks (`window`, `navigator`, etc.)
32
+
33
+ ```ts
34
+ it('reads from the clipboard', async () => {
35
+ Object.assign(navigator, {
36
+ clipboard: { readText: vi.fn().mockResolvedValue('pasted text') },
37
+ })
38
+ render(<ClipboardButton />)
39
+ await userEvent.click(screen.getByRole('button', { name: /paste/i }))
40
+ expect(screen.getByDisplayValue('pasted text')).toBeInTheDocument()
41
+ })
42
+ ```
43
+
44
+ ## localStorage / sessionStorage
45
+
46
+ ```ts
47
+ beforeEach(() => {
48
+ localStorage.clear()
49
+ vi.spyOn(Storage.prototype, 'setItem')
50
+ vi.spyOn(Storage.prototype, 'getItem')
51
+ })
52
+
53
+ it('persists the theme preference', () => {
54
+ render(<ThemeToggle />)
55
+ userEvent.click(screen.getByRole('switch'))
56
+ expect(localStorage.setItem).toHaveBeenCalledWith('theme', 'dark')
57
+ })
58
+ ```
59
+
60
+ ## Mocking `fetch` directly (no MSW)
61
+
62
+ ```ts
63
+ global.fetch = vi.fn().mockResolvedValue({
64
+ ok: true,
65
+ json: async () => ({ id: '1', name: 'Alice' }),
66
+ } as Response)
67
+ ```
68
+
69
+ ## Mocking `console` to suppress noise
70
+
71
+ ```ts
72
+ beforeAll(() => {
73
+ vi.spyOn(console, 'error').mockImplementation(() => {})
74
+ })
75
+ afterAll(() => {
76
+ vi.mocked(console.error).mockRestore()
77
+ })
78
+ ```
@@ -0,0 +1,185 @@
1
+ # Monorepo Vitest Setup
2
+
3
+ ## Typical structure
4
+
5
+ ```
6
+ my-monorepo/
7
+ ├── vitest.workspace.ts # Root workspace config
8
+ ├── packages/
9
+ │ ├── ui/
10
+ │ │ ├── vitest.config.ts
11
+ │ │ └── src/
12
+ │ ├── hooks/
13
+ │ │ ├── vitest.config.ts
14
+ │ │ └── src/
15
+ │ └── utils/
16
+ │ ├── vitest.config.ts
17
+ │ └── src/
18
+ └── apps/
19
+ └── web/ # Next.js app
20
+ ├── vitest.config.ts
21
+ └── src/
22
+ ```
23
+
24
+ ## Root `vitest.workspace.ts`
25
+
26
+ ```ts
27
+ import { defineWorkspace } from 'vitest/config'
28
+
29
+ export default defineWorkspace([
30
+ 'packages/*/vitest.config.ts',
31
+ 'apps/*/vitest.config.ts',
32
+ ])
33
+ ```
34
+
35
+ Run all tests: `vitest --workspace`
36
+
37
+ ## Per-package `vitest.config.ts`
38
+
39
+ ```ts
40
+ import { defineConfig } from 'vitest/config'
41
+ import react from '@vitejs/plugin-react'
42
+ import tsconfigPaths from 'vite-tsconfig-paths'
43
+ import { resolve } from 'path'
44
+
45
+ export default defineConfig({
46
+ plugins: [react(), tsconfigPaths()],
47
+ resolve: {
48
+ alias: {
49
+ '@': resolve(__dirname, './src'),
50
+ },
51
+ },
52
+ test: {
53
+ name: 'ui', // Shows in output, helps identify package
54
+ environment: 'jsdom',
55
+ globals: true,
56
+ setupFiles: ['../../test-utils/src/setup.ts'],
57
+ include: ['src/**/*.test.{ts,tsx}'],
58
+ coverage: {
59
+ provider: 'v8',
60
+ include: ['src/**'],
61
+ exclude: ['src/**/*.stories.tsx', 'src/test/**'],
62
+ },
63
+ },
64
+ })
65
+ ```
66
+
67
+ ## Shared test setup package (`packages/test-utils`)
68
+
69
+ ### `package.json`
70
+
71
+ ```json
72
+ {
73
+ "name": "@acme/test-utils",
74
+ "private": true,
75
+ "exports": {
76
+ ".": "./src/index.ts"
77
+ }
78
+ }
79
+ ```
80
+
81
+ ### `src/index.ts`
82
+
83
+ ```ts
84
+ export { render, renderHook, screen, waitFor } from './render'
85
+ export { server } from './server'
86
+ export * from '@testing-library/jest-dom'
87
+ ```
88
+
89
+ ### `src/render.tsx`
90
+
91
+ ```ts
92
+ import React from 'react'
93
+ import { render as rtlRender, renderHook as rtlRenderHook, RenderOptions } from '@testing-library/react'
94
+ import { QueryClient, QueryClientProvider } from '@tanstack/react-query'
95
+ import { ThemeProvider } from '@acme/ui'
96
+
97
+ function createTestQueryClient() {
98
+ return new QueryClient({
99
+ defaultOptions: {
100
+ queries: { retry: false, gcTime: 0 },
101
+ mutations: { retry: false },
102
+ },
103
+ })
104
+ }
105
+
106
+ function AllProviders({ children }: { children: React.ReactNode }) {
107
+ const queryClient = createTestQueryClient()
108
+ return (
109
+ <QueryClientProvider client={queryClient}>
110
+ <ThemeProvider defaultTheme="light">
111
+ {children}
112
+ </ThemeProvider>
113
+ </QueryClientProvider>
114
+ )
115
+ }
116
+
117
+ export function render(ui: React.ReactElement, options?: RenderOptions) {
118
+ return rtlRender(ui, { wrapper: AllProviders, ...options })
119
+ }
120
+
121
+ export function renderHook<T>(hook: () => T) {
122
+ return rtlRenderHook(hook, { wrapper: AllProviders })
123
+ }
124
+
125
+ export * from '@testing-library/react'
126
+ ```
127
+
128
+ ### `src/server.ts`
129
+
130
+ ```ts
131
+ import { setupServer } from 'msw/node'
132
+ import { handlers } from './handlers'
133
+
134
+ export const server = setupServer(...handlers)
135
+ ```
136
+
137
+ ### `src/setup.ts`
138
+
139
+ ```ts
140
+ import '@testing-library/jest-dom'
141
+ import { afterAll, afterEach, beforeAll } from 'vitest'
142
+ import { cleanup } from '@testing-library/react'
143
+ import { server } from './server'
144
+
145
+ beforeAll(() => server.listen({ onUnhandledRequest: 'warn' }))
146
+ afterEach(() => {
147
+ server.resetHandlers()
148
+ cleanup()
149
+ })
150
+ afterAll(() => server.close())
151
+ ```
152
+
153
+ ## Sharing path aliases
154
+
155
+ Use `vite-tsconfig-paths` in each package. Make sure each `tsconfig.json` has paths configured:
156
+
157
+ ```json
158
+ {
159
+ "compilerOptions": {
160
+ "baseUrl": ".",
161
+ "paths": {
162
+ "@/*": ["./src/*"]
163
+ }
164
+ }
165
+ }
166
+ ```
167
+
168
+ ## Running tests selectively
169
+
170
+ ```bash
171
+ # All packages
172
+ vitest --workspace
173
+
174
+ # Single package
175
+ vitest --project ui
176
+
177
+ # Single file
178
+ vitest src/components/Button.test.tsx
179
+
180
+ # Watch mode
181
+ vitest
182
+
183
+ # Coverage
184
+ vitest run --coverage
185
+ ```
@@ -0,0 +1,332 @@
1
+ # Turborepo + Vitest Setup
2
+
3
+ ## Typical structure
4
+
5
+ ```
6
+ my-turborepo/
7
+ ├── turbo.json # Pipeline config — must declare "test" task
8
+ ├── package.json # Root, workspaces declared here
9
+ ├── pnpm-workspace.yaml # (if using pnpm)
10
+ ├── packages/
11
+ │ ├── test-utils/ # Shared test helpers
12
+ │ │ ├── package.json
13
+ │ │ └── src/
14
+ │ ├── ui/
15
+ │ │ ├── package.json # Must have "test" script
16
+ │ │ ├── vitest.config.ts
17
+ │ │ └── src/
18
+ │ ├── hooks/
19
+ │ │ ├── package.json
20
+ │ │ ├── vitest.config.ts
21
+ │ │ └── src/
22
+ │ └── utils/
23
+ │ ├── package.json
24
+ │ ├── vitest.config.ts
25
+ │ └── src/
26
+ └── apps/
27
+ └── web/ # Next.js app
28
+ ├── package.json
29
+ ├── vitest.config.ts
30
+ └── src/
31
+ ```
32
+
33
+ ---
34
+
35
+ ## `turbo.json` — full test task config
36
+
37
+ ```json
38
+ {
39
+ "$schema": "https://turbo.build/schema.json",
40
+ "tasks": {
41
+ "build": {
42
+ "dependsOn": ["^build"],
43
+ "outputs": ["dist/**", ".next/**"]
44
+ },
45
+ "test": {
46
+ "dependsOn": ["^build"],
47
+ "inputs": [
48
+ "src/**/*.ts",
49
+ "src/**/*.tsx",
50
+ "**/*.test.ts",
51
+ "**/*.test.tsx",
52
+ "vitest.config.ts",
53
+ "tsconfig.json"
54
+ ],
55
+ "outputs": ["coverage/**"],
56
+ "cache": true
57
+ },
58
+ "test:coverage": {
59
+ "dependsOn": ["^build"],
60
+ "inputs": [
61
+ "src/**/*.ts",
62
+ "src/**/*.tsx",
63
+ "**/*.test.ts",
64
+ "**/*.test.tsx"
65
+ ],
66
+ "outputs": ["coverage/**"],
67
+ "cache": true
68
+ },
69
+ "test:watch": {
70
+ "cache": false,
71
+ "persistent": true
72
+ }
73
+ }
74
+ }
75
+ ```
76
+
77
+ **Key points:**
78
+ - `"dependsOn": ["^build"]` — ensures upstream packages (like `test-utils`) are built before tests run
79
+ - `"inputs"` — tells Turbo what files affect the cache key; always include test files and config
80
+ - `"outputs": ["coverage/**"]` — caches coverage reports so CI can read them after `turbo run test`
81
+ - `"cache": false` on `test:watch` — watch mode must never be cached
82
+
83
+ ---
84
+
85
+ ## Per-package `package.json`
86
+
87
+ ```json
88
+ {
89
+ "name": "@acme/ui",
90
+ "scripts": {
91
+ "test": "vitest run",
92
+ "test:watch": "vitest",
93
+ "test:coverage": "vitest run --coverage"
94
+ },
95
+ "devDependencies": {
96
+ "@acme/test-utils": "workspace:*",
97
+ "vitest": "^2.0.0",
98
+ "@vitejs/plugin-react": "^4.0.0",
99
+ "vite-tsconfig-paths": "^5.0.0"
100
+ }
101
+ }
102
+ ```
103
+
104
+ ---
105
+
106
+ ## Per-package `vitest.config.ts`
107
+
108
+ ```ts
109
+ import { defineConfig } from 'vitest/config'
110
+ import react from '@vitejs/plugin-react'
111
+ import tsconfigPaths from 'vite-tsconfig-paths'
112
+ import { resolve } from 'path'
113
+
114
+ export default defineConfig({
115
+ plugins: [react(), tsconfigPaths()],
116
+ resolve: {
117
+ alias: {
118
+ '@': resolve(__dirname, './src'),
119
+ },
120
+ },
121
+ test: {
122
+ name: 'ui', // Used by Turbo output labeling & vitest --project
123
+ environment: 'jsdom',
124
+ globals: true,
125
+ setupFiles: ['../../packages/test-utils/src/setup.ts'],
126
+ include: ['src/**/*.test.{ts,tsx}'],
127
+ coverage: {
128
+ provider: 'v8',
129
+ reportsDirectory: './coverage',
130
+ reporter: ['text', 'lcov', 'json'],
131
+ include: ['src/**'],
132
+ exclude: ['src/**/*.stories.tsx', 'src/test/**'],
133
+ },
134
+ },
135
+ })
136
+ ```
137
+
138
+ ---
139
+
140
+ ## `packages/test-utils` — shared test helpers
141
+
142
+ ### `package.json`
143
+
144
+ ```json
145
+ {
146
+ "name": "@acme/test-utils",
147
+ "private": true,
148
+ "exports": {
149
+ ".": "./src/index.ts"
150
+ },
151
+ "scripts": {
152
+ "build": "tsc --noEmit"
153
+ },
154
+ "dependencies": {
155
+ "@testing-library/react": "^16.0.0",
156
+ "@testing-library/user-event": "^14.0.0",
157
+ "@testing-library/jest-dom": "^6.0.0",
158
+ "msw": "^2.0.0"
159
+ }
160
+ }
161
+ ```
162
+
163
+ ### `src/setup.ts`
164
+
165
+ ```ts
166
+ import '@testing-library/jest-dom'
167
+ import { afterAll, afterEach, beforeAll } from 'vitest'
168
+ import { cleanup } from '@testing-library/react'
169
+ import { server } from './server'
170
+
171
+ beforeAll(() => server.listen({ onUnhandledRequest: 'warn' }))
172
+ afterEach(() => {
173
+ server.resetHandlers()
174
+ cleanup()
175
+ })
176
+ afterAll(() => server.close())
177
+ ```
178
+
179
+ ### `src/render.tsx`
180
+
181
+ ```ts
182
+ import React from 'react'
183
+ import {
184
+ render as rtlRender,
185
+ renderHook as rtlRenderHook,
186
+ type RenderOptions,
187
+ } from '@testing-library/react'
188
+ import { QueryClient, QueryClientProvider } from '@tanstack/react-query'
189
+
190
+ function createTestQueryClient() {
191
+ return new QueryClient({
192
+ defaultOptions: {
193
+ queries: { retry: false, gcTime: 0 },
194
+ mutations: { retry: false },
195
+ },
196
+ })
197
+ }
198
+
199
+ function AllProviders({ children }: { children: React.ReactNode }) {
200
+ const qc = createTestQueryClient()
201
+ return <QueryClientProvider client={qc}>{children}</QueryClientProvider>
202
+ }
203
+
204
+ export function render(ui: React.ReactElement, options?: RenderOptions) {
205
+ return rtlRender(ui, { wrapper: AllProviders, ...options })
206
+ }
207
+
208
+ export function renderHook<T>(hook: () => T) {
209
+ return rtlRenderHook(hook, { wrapper: AllProviders })
210
+ }
211
+
212
+ export * from '@testing-library/react'
213
+ ```
214
+
215
+ ### `src/server.ts`
216
+
217
+ ```ts
218
+ import { setupServer } from 'msw/node'
219
+ import { http, HttpResponse } from 'msw'
220
+
221
+ // Add your baseline handlers here or keep empty and override per-test
222
+ export const handlers = [
223
+ http.get('/api/health', () => HttpResponse.json({ status: 'ok' })),
224
+ ]
225
+
226
+ export const server = setupServer(...handlers)
227
+ export { http, HttpResponse }
228
+ ```
229
+
230
+ ### `src/index.ts`
231
+
232
+ ```ts
233
+ export { render, renderHook } from './render'
234
+ export { server, http, HttpResponse } from './server'
235
+ export * from '@testing-library/react'
236
+ export * from '@testing-library/jest-dom'
237
+ ```
238
+
239
+ ---
240
+
241
+ ## Running tests
242
+
243
+ ```bash
244
+ # All packages — uses cache, only re-runs what changed
245
+ turbo run test
246
+
247
+ # Force re-run all, ignore cache
248
+ turbo run test --force
249
+
250
+ # Only packages affected by changes since last commit
251
+ turbo run test --filter=...[HEAD^1]
252
+
253
+ # Only packages affected by changes on a branch vs main
254
+ turbo run test --filter=...[origin/main]
255
+
256
+ # Single package
257
+ turbo run test --filter=@acme/ui
258
+
259
+ # Single package + all packages that depend on it
260
+ turbo run test --filter=@acme/ui...
261
+
262
+ # All packages that depend on ui (downstream)
263
+ turbo run test --filter=...@acme/ui
264
+
265
+ # Coverage for all
266
+ turbo run test:coverage
267
+
268
+ # Watch mode — run directly in the package (not via turbo)
269
+ cd packages/ui && pnpm test:watch
270
+ ```
271
+
272
+ ---
273
+
274
+ ## CI setup (GitHub Actions example)
275
+
276
+ ```yaml
277
+ name: Test
278
+ on: [push, pull_request]
279
+
280
+ jobs:
281
+ test:
282
+ runs-on: ubuntu-latest
283
+ steps:
284
+ - uses: actions/checkout@v4
285
+ with:
286
+ fetch-depth: 0 # needed for --filter=[...] comparisons
287
+
288
+ - uses: pnpm/action-setup@v3
289
+ with:
290
+ version: 9
291
+
292
+ - uses: actions/setup-node@v4
293
+ with:
294
+ node-version: 20
295
+ cache: 'pnpm'
296
+
297
+ - name: Install dependencies
298
+ run: pnpm install --frozen-lockfile
299
+
300
+ - name: Run tests
301
+ run: turbo run test --filter=...[origin/main]
302
+ # On main branch, run everything:
303
+ # run: turbo run test
304
+ ```
305
+
306
+ ### Turborepo remote caching in CI
307
+
308
+ Add to your CI env to enable remote cache (skips unchanged packages across CI runs):
309
+
310
+ ```yaml
311
+ env:
312
+ TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
313
+ TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
314
+ ```
315
+
316
+ Get these from your Vercel dashboard (Turborepo remote cache is free on Vercel).
317
+
318
+ ---
319
+
320
+ ## Common gotchas
321
+
322
+ **`turbo run test` says "cache hit" but tests didn't run**
323
+ → That's correct behavior — the inputs haven't changed. Use `--force` to bypass.
324
+
325
+ **Tests pass locally but fail in CI**
326
+ → Check that `turbo.json` `inputs` includes all relevant files. If a config file (e.g. `tsconfig.json`, `.env.test`) is missing from `inputs`, Turbo won't invalidate the cache when it changes.
327
+
328
+ **Packages not found by `--filter`**
329
+ → Make sure `name` in each package's `package.json` matches what you pass to `--filter`. Use `turbo ls` to see all recognized packages.
330
+
331
+ **`test-utils` changes don't re-trigger dependent packages**
332
+ → Add `"dependsOn": ["^build"]` to the `test` task, and make sure `test-utils` has a `build` script. Turbo tracks the build output hash of upstream packages as part of the cache key.