arboris-cli 1.0.0 → 1.1.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 (451) hide show
  1. package/dist/cli.mjs +420 -0
  2. package/manifest.json +602 -0
  3. package/package.json +22 -10
  4. package/prisma/skills/accessibility/SKILL.md +147 -0
  5. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  6. package/prisma/skills/agent-eval/SKILL.md +146 -0
  7. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  8. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  9. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  10. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  11. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  12. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  13. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  14. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  15. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  16. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  17. package/prisma/skills/agent-sort/SKILL.md +216 -0
  18. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  19. package/prisma/skills/agentic-os/SKILL.md +388 -0
  20. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  21. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  22. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  23. package/prisma/skills/angular-developer/SKILL.md +155 -0
  24. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  25. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  26. package/prisma/skills/angular-developer/references/cli.md +86 -0
  27. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  28. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  29. package/prisma/skills/angular-developer/references/components.md +117 -0
  30. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  31. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  32. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  33. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  34. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  35. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  36. package/prisma/skills/angular-developer/references/effects.md +83 -0
  37. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  38. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  39. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  40. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  41. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  42. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  43. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  44. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  45. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  46. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  47. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  48. package/prisma/skills/angular-developer/references/resource.md +77 -0
  49. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  50. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  51. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  52. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  53. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  54. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  55. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  56. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  57. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  58. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  59. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  60. package/prisma/skills/api-design/SKILL.md +524 -0
  61. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  62. package/prisma/skills/article-writing/SKILL.md +80 -0
  63. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  64. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  65. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  66. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  67. package/prisma/skills/benchmark/SKILL.md +94 -0
  68. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  69. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  70. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  71. package/prisma/skills/blueprint/SKILL.md +106 -0
  72. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  73. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  74. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  75. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  76. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  77. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  78. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  79. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  80. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  81. package/prisma/skills/brand-voice/SKILL.md +98 -0
  82. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  83. package/prisma/skills/browser-qa/SKILL.md +105 -0
  84. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  85. package/prisma/skills/canary-watch/SKILL.md +108 -0
  86. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  87. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  88. package/prisma/skills/ck/SKILL.md +148 -0
  89. package/prisma/skills/ck/commands/forget.mjs +44 -0
  90. package/prisma/skills/ck/commands/info.mjs +24 -0
  91. package/prisma/skills/ck/commands/init.mjs +143 -0
  92. package/prisma/skills/ck/commands/list.mjs +40 -0
  93. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  94. package/prisma/skills/ck/commands/resume.mjs +36 -0
  95. package/prisma/skills/ck/commands/save.mjs +210 -0
  96. package/prisma/skills/ck/commands/shared.mjs +387 -0
  97. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  98. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  99. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  100. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  101. package/prisma/skills/code-tour/SKILL.md +254 -0
  102. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  103. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  104. package/prisma/skills/coding-standards/SKILL.md +551 -0
  105. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  106. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  107. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  108. package/prisma/skills/config-gc/SKILL.md +120 -0
  109. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  110. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  111. package/prisma/skills/content-engine/SKILL.md +132 -0
  112. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  113. package/prisma/skills/context-budget/SKILL.md +136 -0
  114. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  115. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  116. package/prisma/skills/continuous-learning/config.json +18 -0
  117. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  118. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  119. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  121. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  122. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  123. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  124. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  125. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  130. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  131. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  132. package/prisma/skills/council/SKILL.md +204 -0
  133. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  134. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  135. package/prisma/skills/crosspost/SKILL.md +112 -0
  136. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  137. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  138. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  139. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  140. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  141. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  142. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  143. package/prisma/skills/database-migrations/SKILL.md +430 -0
  144. package/prisma/skills/deep-research/SKILL.md +160 -0
  145. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  146. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  147. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  148. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  149. package/prisma/skills/design-system/SKILL.md +83 -0
  150. package/prisma/skills/django-celery/SKILL.md +458 -0
  151. package/prisma/skills/django-patterns/SKILL.md +735 -0
  152. package/prisma/skills/django-security/SKILL.md +644 -0
  153. package/prisma/skills/django-tdd/SKILL.md +730 -0
  154. package/prisma/skills/django-verification/SKILL.md +470 -0
  155. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  156. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  157. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  158. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  159. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  160. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  161. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  162. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  163. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  164. package/prisma/skills/email-ops/SKILL.md +122 -0
  165. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  166. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  167. package/prisma/skills/error-handling/SKILL.md +377 -0
  168. package/prisma/skills/eval-harness/SKILL.md +271 -0
  169. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  170. package/prisma/skills/exa-search/SKILL.md +108 -0
  171. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  172. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  173. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  174. package/prisma/skills/flox-environments/SKILL.md +497 -0
  175. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  176. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  177. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  178. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  179. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  180. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  181. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  182. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  183. package/prisma/skills/frontend-slides/html-template.md +419 -0
  184. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  185. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  186. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  187. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  188. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  189. package/prisma/skills/gateguard/SKILL.md +133 -0
  190. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  191. package/prisma/skills/git-workflow/SKILL.md +716 -0
  192. package/prisma/skills/github-ops/SKILL.md +145 -0
  193. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  194. package/prisma/skills/golang-testing/SKILL.md +721 -0
  195. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  196. package/prisma/skills/growth-log/SKILL.md +128 -0
  197. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  198. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  199. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  200. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  201. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  202. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  203. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  204. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  205. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  206. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  207. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  208. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  209. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  210. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  211. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  212. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  213. package/prisma/skills/investor-materials/SKILL.md +97 -0
  214. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  215. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  216. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  217. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  218. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  219. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  220. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  221. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  222. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  223. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  224. package/prisma/skills/jira-integration/SKILL.md +303 -0
  225. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  226. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  227. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  228. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  229. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  230. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  231. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  232. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  233. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  234. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  235. package/prisma/skills/laravel-security/SKILL.md +948 -0
  236. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  237. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  238. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  239. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  240. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  241. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  242. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  243. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  244. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  245. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  246. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  247. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  248. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  249. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  250. package/prisma/skills/manim-video/SKILL.md +90 -0
  251. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  252. package/prisma/skills/market-research/SKILL.md +76 -0
  253. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  254. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  255. package/prisma/skills/messages-ops/SKILL.md +105 -0
  256. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  257. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  258. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  259. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  260. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  261. package/prisma/skills/motion-ui/SKILL.md +576 -0
  262. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  263. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  264. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  265. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  266. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  267. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  268. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  269. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  270. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  271. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  272. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  273. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  274. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  276. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  277. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  278. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  280. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  281. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  282. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  283. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  284. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  285. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  286. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  287. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  288. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  289. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  290. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  291. package/prisma/skills/perl-security/SKILL.md +504 -0
  292. package/prisma/skills/perl-testing/SKILL.md +476 -0
  293. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  294. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  295. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  296. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  297. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  298. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  299. package/prisma/skills/product-capability/SKILL.md +142 -0
  300. package/prisma/skills/product-lens/SKILL.md +93 -0
  301. package/prisma/skills/production-audit/SKILL.md +207 -0
  302. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  303. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  304. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  305. package/prisma/skills/python-patterns/SKILL.md +751 -0
  306. package/prisma/skills/python-testing/SKILL.md +817 -0
  307. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  308. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  309. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  310. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  311. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  312. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  313. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  314. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  315. package/prisma/skills/react-patterns/SKILL.md +342 -0
  316. package/prisma/skills/react-performance/SKILL.md +575 -0
  317. package/prisma/skills/react-testing/SKILL.md +424 -0
  318. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  319. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  320. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  321. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  322. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  323. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  324. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  325. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  329. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  330. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  331. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  332. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  333. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  334. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  335. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  336. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  337. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  340. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  341. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  342. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  343. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  346. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  347. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  348. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  349. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  350. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  351. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  352. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  353. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  354. package/prisma/skills/repo-scan/SKILL.md +79 -0
  355. package/prisma/skills/research-ops/SKILL.md +113 -0
  356. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  357. package/prisma/skills/rules-distill/SKILL.md +265 -0
  358. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  359. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  360. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  361. package/prisma/skills/rust-testing/SKILL.md +501 -0
  362. package/prisma/skills/safety-guard/SKILL.md +76 -0
  363. package/prisma/skills/santa-method/SKILL.md +307 -0
  364. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  365. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  366. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  367. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  368. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  369. package/prisma/skills/search-first/SKILL.md +183 -0
  370. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  371. package/prisma/skills/security-review/SKILL.md +504 -0
  372. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  373. package/prisma/skills/security-scan/SKILL.md +166 -0
  374. package/prisma/skills/seo/SKILL.md +155 -0
  375. package/prisma/skills/skill-comply/SKILL.md +59 -0
  376. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  377. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  378. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  379. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  380. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  381. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  382. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  383. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  384. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  385. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  386. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  387. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  388. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  389. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  390. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  391. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  392. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  393. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  394. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  395. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  396. package/prisma/skills/skill-scout/SKILL.md +141 -0
  397. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  398. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  399. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  400. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  401. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  402. package/prisma/skills/social-publisher/SKILL.md +130 -0
  403. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  404. package/prisma/skills/springboot-security/SKILL.md +273 -0
  405. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  406. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  407. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  408. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  409. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  410. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  411. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  412. package/prisma/skills/taste/SKILL.md +264 -0
  413. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  414. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  415. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  416. package/prisma/skills/team-builder/SKILL.md +169 -0
  417. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  418. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  419. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  420. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  421. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  422. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  423. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  424. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  425. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  426. package/prisma/skills/ui-demo/SKILL.md +466 -0
  427. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  428. package/prisma/skills/uncloud/SKILL.md +344 -0
  429. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  430. package/prisma/skills/verification-loop/SKILL.md +127 -0
  431. package/prisma/skills/video-editing/SKILL.md +311 -0
  432. package/prisma/skills/videodb/SKILL.md +375 -0
  433. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  434. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  435. package/prisma/skills/videodb/reference/capture.md +101 -0
  436. package/prisma/skills/videodb/reference/editor.md +443 -0
  437. package/prisma/skills/videodb/reference/generative.md +331 -0
  438. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  439. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  440. package/prisma/skills/videodb/reference/search.md +230 -0
  441. package/prisma/skills/videodb/reference/streaming.md +406 -0
  442. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  443. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  444. package/prisma/skills/visa-doc-translate/README.md +86 -0
  445. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  446. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  447. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  448. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  449. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  450. package/prisma/skills/x-api/SKILL.md +235 -0
  451. package/run.mjs +0 -10
@@ -0,0 +1,721 @@
1
+ ---
2
+ name: golang-testing
3
+ description: Go testing patterns including table-driven tests, subtests, benchmarks, fuzzing, and test coverage. Follows TDD methodology with idiomatic Go practices.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Go Testing Patterns
9
+
10
+ Comprehensive Go testing patterns for writing reliable, maintainable tests following TDD methodology.
11
+
12
+ ## When to Activate
13
+
14
+ - Writing new Go functions or methods
15
+ - Adding test coverage to existing code
16
+ - Creating benchmarks for performance-critical code
17
+ - Implementing fuzz tests for input validation
18
+ - Following TDD workflow in Go projects
19
+
20
+ ## TDD Workflow for Go
21
+
22
+ ### The RED-GREEN-REFACTOR Cycle
23
+
24
+ ```
25
+ RED → Write a failing test first
26
+ GREEN → Write minimal code to pass the test
27
+ REFACTOR → Improve code while keeping tests green
28
+ REPEAT → Continue with next requirement
29
+ ```
30
+
31
+ ### Step-by-Step TDD in Go
32
+
33
+ ```go
34
+ // Step 1: Define the interface/signature
35
+ // calculator.go
36
+ package calculator
37
+
38
+ func Add(a, b int) int {
39
+ panic("not implemented") // Placeholder
40
+ }
41
+
42
+ // Step 2: Write failing test (RED)
43
+ // calculator_test.go
44
+ package calculator
45
+
46
+ import "testing"
47
+
48
+ func TestAdd(t *testing.T) {
49
+ got := Add(2, 3)
50
+ want := 5
51
+ if got != want {
52
+ t.Errorf("Add(2, 3) = %d; want %d", got, want)
53
+ }
54
+ }
55
+
56
+ // Step 3: Run test - verify FAIL
57
+ // $ go test
58
+ // --- FAIL: TestAdd (0.00s)
59
+ // panic: not implemented
60
+
61
+ // Step 4: Implement minimal code (GREEN)
62
+ func Add(a, b int) int {
63
+ return a + b
64
+ }
65
+
66
+ // Step 5: Run test - verify PASS
67
+ // $ go test
68
+ // PASS
69
+
70
+ // Step 6: Refactor if needed, verify tests still pass
71
+ ```
72
+
73
+ ## Table-Driven Tests
74
+
75
+ The standard pattern for Go tests. Enables comprehensive coverage with minimal code.
76
+
77
+ ```go
78
+ func TestAdd(t *testing.T) {
79
+ tests := []struct {
80
+ name string
81
+ a, b int
82
+ expected int
83
+ }{
84
+ {"positive numbers", 2, 3, 5},
85
+ {"negative numbers", -1, -2, -3},
86
+ {"zero values", 0, 0, 0},
87
+ {"mixed signs", -1, 1, 0},
88
+ {"large numbers", 1000000, 2000000, 3000000},
89
+ }
90
+
91
+ for _, tt := range tests {
92
+ t.Run(tt.name, func(t *testing.T) {
93
+ got := Add(tt.a, tt.b)
94
+ if got != tt.expected {
95
+ t.Errorf("Add(%d, %d) = %d; want %d",
96
+ tt.a, tt.b, got, tt.expected)
97
+ }
98
+ })
99
+ }
100
+ }
101
+ ```
102
+
103
+ ### Table-Driven Tests with Error Cases
104
+
105
+ ```go
106
+ func TestParseConfig(t *testing.T) {
107
+ tests := []struct {
108
+ name string
109
+ input string
110
+ want *Config
111
+ wantErr bool
112
+ }{
113
+ {
114
+ name: "valid config",
115
+ input: `{"host": "localhost", "port": 8080}`,
116
+ want: &Config{Host: "localhost", Port: 8080},
117
+ },
118
+ {
119
+ name: "invalid JSON",
120
+ input: `{invalid}`,
121
+ wantErr: true,
122
+ },
123
+ {
124
+ name: "empty input",
125
+ input: "",
126
+ wantErr: true,
127
+ },
128
+ {
129
+ name: "minimal config",
130
+ input: `{}`,
131
+ want: &Config{}, // Zero value config
132
+ },
133
+ }
134
+
135
+ for _, tt := range tests {
136
+ t.Run(tt.name, func(t *testing.T) {
137
+ got, err := ParseConfig(tt.input)
138
+
139
+ if tt.wantErr {
140
+ if err == nil {
141
+ t.Error("expected error, got nil")
142
+ }
143
+ return
144
+ }
145
+
146
+ if err != nil {
147
+ t.Fatalf("unexpected error: %v", err)
148
+ }
149
+
150
+ if !reflect.DeepEqual(got, tt.want) {
151
+ t.Errorf("got %+v; want %+v", got, tt.want)
152
+ }
153
+ })
154
+ }
155
+ }
156
+ ```
157
+
158
+ ## Subtests and Sub-benchmarks
159
+
160
+ ### Organizing Related Tests
161
+
162
+ ```go
163
+ func TestUser(t *testing.T) {
164
+ // Setup shared by all subtests
165
+ db := setupTestDB(t)
166
+
167
+ t.Run("Create", func(t *testing.T) {
168
+ user := &User{Name: "Alice"}
169
+ err := db.CreateUser(user)
170
+ if err != nil {
171
+ t.Fatalf("CreateUser failed: %v", err)
172
+ }
173
+ if user.ID == "" {
174
+ t.Error("expected user ID to be set")
175
+ }
176
+ })
177
+
178
+ t.Run("Get", func(t *testing.T) {
179
+ user, err := db.GetUser("alice-id")
180
+ if err != nil {
181
+ t.Fatalf("GetUser failed: %v", err)
182
+ }
183
+ if user.Name != "Alice" {
184
+ t.Errorf("got name %q; want %q", user.Name, "Alice")
185
+ }
186
+ })
187
+
188
+ t.Run("Update", func(t *testing.T) {
189
+ // ...
190
+ })
191
+
192
+ t.Run("Delete", func(t *testing.T) {
193
+ // ...
194
+ })
195
+ }
196
+ ```
197
+
198
+ ### Parallel Subtests
199
+
200
+ ```go
201
+ func TestParallel(t *testing.T) {
202
+ tests := []struct {
203
+ name string
204
+ input string
205
+ }{
206
+ {"case1", "input1"},
207
+ {"case2", "input2"},
208
+ {"case3", "input3"},
209
+ }
210
+
211
+ for _, tt := range tests {
212
+ tt := tt // Capture range variable
213
+ t.Run(tt.name, func(t *testing.T) {
214
+ t.Parallel() // Run subtests in parallel
215
+ result := Process(tt.input)
216
+ // assertions...
217
+ _ = result
218
+ })
219
+ }
220
+ }
221
+ ```
222
+
223
+ ## Test Helpers
224
+
225
+ ### Helper Functions
226
+
227
+ ```go
228
+ func setupTestDB(t *testing.T) *sql.DB {
229
+ t.Helper() // Marks this as a helper function
230
+
231
+ db, err := sql.Open("sqlite3", ":memory:")
232
+ if err != nil {
233
+ t.Fatalf("failed to open database: %v", err)
234
+ }
235
+
236
+ // Cleanup when test finishes
237
+ t.Cleanup(func() {
238
+ db.Close()
239
+ })
240
+
241
+ // Run migrations
242
+ if _, err := db.Exec(schema); err != nil {
243
+ t.Fatalf("failed to create schema: %v", err)
244
+ }
245
+
246
+ return db
247
+ }
248
+
249
+ func assertNoError(t *testing.T, err error) {
250
+ t.Helper()
251
+ if err != nil {
252
+ t.Fatalf("unexpected error: %v", err)
253
+ }
254
+ }
255
+
256
+ func assertEqual[T comparable](t *testing.T, got, want T) {
257
+ t.Helper()
258
+ if got != want {
259
+ t.Errorf("got %v; want %v", got, want)
260
+ }
261
+ }
262
+ ```
263
+
264
+ ### Temporary Files and Directories
265
+
266
+ ```go
267
+ func TestFileProcessing(t *testing.T) {
268
+ // Create temp directory - automatically cleaned up
269
+ tmpDir := t.TempDir()
270
+
271
+ // Create test file
272
+ testFile := filepath.Join(tmpDir, "test.txt")
273
+ err := os.WriteFile(testFile, []byte("test content"), 0644)
274
+ if err != nil {
275
+ t.Fatalf("failed to create test file: %v", err)
276
+ }
277
+
278
+ // Run test
279
+ result, err := ProcessFile(testFile)
280
+ if err != nil {
281
+ t.Fatalf("ProcessFile failed: %v", err)
282
+ }
283
+
284
+ // Assert...
285
+ _ = result
286
+ }
287
+ ```
288
+
289
+ ## Golden Files
290
+
291
+ Testing against expected output files stored in `testdata/`.
292
+
293
+ ```go
294
+ var update = flag.Bool("update", false, "update golden files")
295
+
296
+ func TestRender(t *testing.T) {
297
+ tests := []struct {
298
+ name string
299
+ input Template
300
+ }{
301
+ {"simple", Template{Name: "test"}},
302
+ {"complex", Template{Name: "test", Items: []string{"a", "b"}}},
303
+ }
304
+
305
+ for _, tt := range tests {
306
+ t.Run(tt.name, func(t *testing.T) {
307
+ got := Render(tt.input)
308
+
309
+ golden := filepath.Join("testdata", tt.name+".golden")
310
+
311
+ if *update {
312
+ // Update golden file: go test -update
313
+ err := os.WriteFile(golden, got, 0644)
314
+ if err != nil {
315
+ t.Fatalf("failed to update golden file: %v", err)
316
+ }
317
+ }
318
+
319
+ want, err := os.ReadFile(golden)
320
+ if err != nil {
321
+ t.Fatalf("failed to read golden file: %v", err)
322
+ }
323
+
324
+ if !bytes.Equal(got, want) {
325
+ t.Errorf("output mismatch:\ngot:\n%s\nwant:\n%s", got, want)
326
+ }
327
+ })
328
+ }
329
+ }
330
+ ```
331
+
332
+ ## Mocking with Interfaces
333
+
334
+ ### Interface-Based Mocking
335
+
336
+ ```go
337
+ // Define interface for dependencies
338
+ type UserRepository interface {
339
+ GetUser(id string) (*User, error)
340
+ SaveUser(user *User) error
341
+ }
342
+
343
+ // Production implementation
344
+ type PostgresUserRepository struct {
345
+ db *sql.DB
346
+ }
347
+
348
+ func (r *PostgresUserRepository) GetUser(id string) (*User, error) {
349
+ // Real database query
350
+ }
351
+
352
+ // Mock implementation for tests
353
+ type MockUserRepository struct {
354
+ GetUserFunc func(id string) (*User, error)
355
+ SaveUserFunc func(user *User) error
356
+ }
357
+
358
+ func (m *MockUserRepository) GetUser(id string) (*User, error) {
359
+ return m.GetUserFunc(id)
360
+ }
361
+
362
+ func (m *MockUserRepository) SaveUser(user *User) error {
363
+ return m.SaveUserFunc(user)
364
+ }
365
+
366
+ // Test using mock
367
+ func TestUserService(t *testing.T) {
368
+ mock := &MockUserRepository{
369
+ GetUserFunc: func(id string) (*User, error) {
370
+ if id == "123" {
371
+ return &User{ID: "123", Name: "Alice"}, nil
372
+ }
373
+ return nil, ErrNotFound
374
+ },
375
+ }
376
+
377
+ service := NewUserService(mock)
378
+
379
+ user, err := service.GetUserProfile("123")
380
+ if err != nil {
381
+ t.Fatalf("unexpected error: %v", err)
382
+ }
383
+ if user.Name != "Alice" {
384
+ t.Errorf("got name %q; want %q", user.Name, "Alice")
385
+ }
386
+ }
387
+ ```
388
+
389
+ ## Benchmarks
390
+
391
+ ### Basic Benchmarks
392
+
393
+ ```go
394
+ func BenchmarkProcess(b *testing.B) {
395
+ data := generateTestData(1000)
396
+ b.ResetTimer() // Don't count setup time
397
+
398
+ for i := 0; i < b.N; i++ {
399
+ Process(data)
400
+ }
401
+ }
402
+
403
+ // Run: go test -bench=BenchmarkProcess -benchmem
404
+ // Output: BenchmarkProcess-8 10000 105234 ns/op 4096 B/op 10 allocs/op
405
+ ```
406
+
407
+ ### Benchmark with Different Sizes
408
+
409
+ ```go
410
+ func BenchmarkSort(b *testing.B) {
411
+ sizes := []int{100, 1000, 10000, 100000}
412
+
413
+ for _, size := range sizes {
414
+ b.Run(fmt.Sprintf("size=%d", size), func(b *testing.B) {
415
+ data := generateRandomSlice(size)
416
+ b.ResetTimer()
417
+
418
+ for i := 0; i < b.N; i++ {
419
+ // Make a copy to avoid sorting already sorted data
420
+ tmp := make([]int, len(data))
421
+ copy(tmp, data)
422
+ sort.Ints(tmp)
423
+ }
424
+ })
425
+ }
426
+ }
427
+ ```
428
+
429
+ ### Memory Allocation Benchmarks
430
+
431
+ ```go
432
+ func BenchmarkStringConcat(b *testing.B) {
433
+ parts := []string{"hello", "world", "foo", "bar", "baz"}
434
+
435
+ b.Run("plus", func(b *testing.B) {
436
+ for i := 0; i < b.N; i++ {
437
+ var s string
438
+ for _, p := range parts {
439
+ s += p
440
+ }
441
+ _ = s
442
+ }
443
+ })
444
+
445
+ b.Run("builder", func(b *testing.B) {
446
+ for i := 0; i < b.N; i++ {
447
+ var sb strings.Builder
448
+ for _, p := range parts {
449
+ sb.WriteString(p)
450
+ }
451
+ _ = sb.String()
452
+ }
453
+ })
454
+
455
+ b.Run("join", func(b *testing.B) {
456
+ for i := 0; i < b.N; i++ {
457
+ _ = strings.Join(parts, "")
458
+ }
459
+ })
460
+ }
461
+ ```
462
+
463
+ ## Fuzzing (Go 1.18+)
464
+
465
+ ### Basic Fuzz Test
466
+
467
+ ```go
468
+ func FuzzParseJSON(f *testing.F) {
469
+ // Add seed corpus
470
+ f.Add(`{"name": "test"}`)
471
+ f.Add(`{"count": 123}`)
472
+ f.Add(`[]`)
473
+ f.Add(`""`)
474
+
475
+ f.Fuzz(func(t *testing.T, input string) {
476
+ var result map[string]interface{}
477
+ err := json.Unmarshal([]byte(input), &result)
478
+
479
+ if err != nil {
480
+ // Invalid JSON is expected for random input
481
+ return
482
+ }
483
+
484
+ // If parsing succeeded, re-encoding should work
485
+ _, err = json.Marshal(result)
486
+ if err != nil {
487
+ t.Errorf("Marshal failed after successful Unmarshal: %v", err)
488
+ }
489
+ })
490
+ }
491
+
492
+ // Run: go test -fuzz=FuzzParseJSON -fuzztime=30s
493
+ ```
494
+
495
+ ### Fuzz Test with Multiple Inputs
496
+
497
+ ```go
498
+ func FuzzCompare(f *testing.F) {
499
+ f.Add("hello", "world")
500
+ f.Add("", "")
501
+ f.Add("abc", "abc")
502
+
503
+ f.Fuzz(func(t *testing.T, a, b string) {
504
+ result := Compare(a, b)
505
+
506
+ // Property: Compare(a, a) should always equal 0
507
+ if a == b && result != 0 {
508
+ t.Errorf("Compare(%q, %q) = %d; want 0", a, b, result)
509
+ }
510
+
511
+ // Property: Compare(a, b) and Compare(b, a) should have opposite signs
512
+ reverse := Compare(b, a)
513
+ if (result > 0 && reverse >= 0) || (result < 0 && reverse <= 0) {
514
+ if result != 0 || reverse != 0 {
515
+ t.Errorf("Compare(%q, %q) = %d, Compare(%q, %q) = %d; inconsistent",
516
+ a, b, result, b, a, reverse)
517
+ }
518
+ }
519
+ })
520
+ }
521
+ ```
522
+
523
+ ## Test Coverage
524
+
525
+ ### Running Coverage
526
+
527
+ ```bash
528
+ # Basic coverage
529
+ go test -cover ./...
530
+
531
+ # Generate coverage profile
532
+ go test -coverprofile=coverage.out ./...
533
+
534
+ # View coverage in browser
535
+ go tool cover -html=coverage.out
536
+
537
+ # View coverage by function
538
+ go tool cover -func=coverage.out
539
+
540
+ # Coverage with race detection
541
+ go test -race -coverprofile=coverage.out ./...
542
+ ```
543
+
544
+ ### Coverage Targets
545
+
546
+ | Code Type | Target |
547
+ |-----------|--------|
548
+ | Critical business logic | 100% |
549
+ | Public APIs | 90%+ |
550
+ | General code | 80%+ |
551
+ | Generated code | Exclude |
552
+
553
+ ### Excluding Generated Code from Coverage
554
+
555
+ ```go
556
+ //go:generate mockgen -source=interface.go -destination=mock_interface.go
557
+
558
+ // In coverage profile, exclude with build tags:
559
+ // go test -cover -tags=!generate ./...
560
+ ```
561
+
562
+ ## HTTP Handler Testing
563
+
564
+ ```go
565
+ func TestHealthHandler(t *testing.T) {
566
+ // Create request
567
+ req := httptest.NewRequest(http.MethodGet, "/health", nil)
568
+ w := httptest.NewRecorder()
569
+
570
+ // Call handler
571
+ HealthHandler(w, req)
572
+
573
+ // Check response
574
+ resp := w.Result()
575
+ defer resp.Body.Close()
576
+
577
+ if resp.StatusCode != http.StatusOK {
578
+ t.Errorf("got status %d; want %d", resp.StatusCode, http.StatusOK)
579
+ }
580
+
581
+ body, _ := io.ReadAll(resp.Body)
582
+ if string(body) != "OK" {
583
+ t.Errorf("got body %q; want %q", body, "OK")
584
+ }
585
+ }
586
+
587
+ func TestAPIHandler(t *testing.T) {
588
+ tests := []struct {
589
+ name string
590
+ method string
591
+ path string
592
+ body string
593
+ wantStatus int
594
+ wantBody string
595
+ }{
596
+ {
597
+ name: "get user",
598
+ method: http.MethodGet,
599
+ path: "/users/123",
600
+ wantStatus: http.StatusOK,
601
+ wantBody: `{"id":"123","name":"Alice"}`,
602
+ },
603
+ {
604
+ name: "not found",
605
+ method: http.MethodGet,
606
+ path: "/users/999",
607
+ wantStatus: http.StatusNotFound,
608
+ },
609
+ {
610
+ name: "create user",
611
+ method: http.MethodPost,
612
+ path: "/users",
613
+ body: `{"name":"Bob"}`,
614
+ wantStatus: http.StatusCreated,
615
+ },
616
+ }
617
+
618
+ handler := NewAPIHandler()
619
+
620
+ for _, tt := range tests {
621
+ t.Run(tt.name, func(t *testing.T) {
622
+ var body io.Reader
623
+ if tt.body != "" {
624
+ body = strings.NewReader(tt.body)
625
+ }
626
+
627
+ req := httptest.NewRequest(tt.method, tt.path, body)
628
+ req.Header.Set("Content-Type", "application/json")
629
+ w := httptest.NewRecorder()
630
+
631
+ handler.ServeHTTP(w, req)
632
+
633
+ if w.Code != tt.wantStatus {
634
+ t.Errorf("got status %d; want %d", w.Code, tt.wantStatus)
635
+ }
636
+
637
+ if tt.wantBody != "" && w.Body.String() != tt.wantBody {
638
+ t.Errorf("got body %q; want %q", w.Body.String(), tt.wantBody)
639
+ }
640
+ })
641
+ }
642
+ }
643
+ ```
644
+
645
+ ## Testing Commands
646
+
647
+ ```bash
648
+ # Run all tests
649
+ go test ./...
650
+
651
+ # Run tests with verbose output
652
+ go test -v ./...
653
+
654
+ # Run specific test
655
+ go test -run TestAdd ./...
656
+
657
+ # Run tests matching pattern
658
+ go test -run "TestUser/Create" ./...
659
+
660
+ # Run tests with race detector
661
+ go test -race ./...
662
+
663
+ # Run tests with coverage
664
+ go test -cover -coverprofile=coverage.out ./...
665
+
666
+ # Run short tests only
667
+ go test -short ./...
668
+
669
+ # Run tests with timeout
670
+ go test -timeout 30s ./...
671
+
672
+ # Run benchmarks
673
+ go test -bench=. -benchmem ./...
674
+
675
+ # Run fuzzing
676
+ go test -fuzz=FuzzParse -fuzztime=30s ./...
677
+
678
+ # Count test runs (for flaky test detection)
679
+ go test -count=10 ./...
680
+ ```
681
+
682
+ ## Best Practices
683
+
684
+ **DO:**
685
+ - Write tests FIRST (TDD)
686
+ - Use table-driven tests for comprehensive coverage
687
+ - Test behavior, not implementation
688
+ - Use `t.Helper()` in helper functions
689
+ - Use `t.Parallel()` for independent tests
690
+ - Clean up resources with `t.Cleanup()`
691
+ - Use meaningful test names that describe the scenario
692
+
693
+ **DON'T:**
694
+ - Test private functions directly (test through public API)
695
+ - Use `time.Sleep()` in tests (use channels or conditions)
696
+ - Ignore flaky tests (fix or remove them)
697
+ - Mock everything (prefer integration tests when possible)
698
+ - Skip error path testing
699
+
700
+ ## Integration with CI/CD
701
+
702
+ ```yaml
703
+ # GitHub Actions example
704
+ test:
705
+ runs-on: ubuntu-latest
706
+ steps:
707
+ - uses: actions/checkout@v4
708
+ - uses: actions/setup-go@v5
709
+ with:
710
+ go-version: '1.22'
711
+
712
+ - name: Run tests
713
+ run: go test -race -coverprofile=coverage.out ./...
714
+
715
+ - name: Check coverage
716
+ run: |
717
+ go tool cover -func=coverage.out | grep total | awk '{print $3}' | \
718
+ awk -F'%' '{if ($1 < 80) exit 1}'
719
+ ```
720
+
721
+ **Remember**: Tests are documentation. They show how your code is meant to be used. Write them clearly and keep them up to date.