@rubix0270/arboris 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/README.md +151 -0
  2. package/cli/manifest.json +323 -0
  3. package/dist/cli.mjs +376 -0
  4. package/package.json +81 -0
  5. package/prisma/skills/accessibility/SKILL.md +147 -0
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  7. package/prisma/skills/agent-eval/SKILL.md +146 -0
  8. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  10. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  18. package/prisma/skills/agent-sort/SKILL.md +216 -0
  19. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  20. package/prisma/skills/agentic-os/SKILL.md +388 -0
  21. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  22. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  23. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  24. package/prisma/skills/angular-developer/SKILL.md +155 -0
  25. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  26. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  27. package/prisma/skills/angular-developer/references/cli.md +86 -0
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  29. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  30. package/prisma/skills/angular-developer/references/components.md +117 -0
  31. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  33. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  34. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  37. package/prisma/skills/angular-developer/references/effects.md +83 -0
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  39. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  40. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  41. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  42. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  44. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  46. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  49. package/prisma/skills/angular-developer/references/resource.md +77 -0
  50. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  51. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  53. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  55. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  56. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  60. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  61. package/prisma/skills/api-design/SKILL.md +524 -0
  62. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  63. package/prisma/skills/article-writing/SKILL.md +80 -0
  64. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  66. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  67. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  68. package/prisma/skills/benchmark/SKILL.md +94 -0
  69. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  72. package/prisma/skills/blueprint/SKILL.md +106 -0
  73. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  82. package/prisma/skills/brand-voice/SKILL.md +98 -0
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  84. package/prisma/skills/browser-qa/SKILL.md +105 -0
  85. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  86. package/prisma/skills/canary-watch/SKILL.md +108 -0
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  89. package/prisma/skills/ck/SKILL.md +148 -0
  90. package/prisma/skills/ck/commands/forget.mjs +44 -0
  91. package/prisma/skills/ck/commands/info.mjs +24 -0
  92. package/prisma/skills/ck/commands/init.mjs +143 -0
  93. package/prisma/skills/ck/commands/list.mjs +40 -0
  94. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  95. package/prisma/skills/ck/commands/resume.mjs +36 -0
  96. package/prisma/skills/ck/commands/save.mjs +210 -0
  97. package/prisma/skills/ck/commands/shared.mjs +387 -0
  98. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  99. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  100. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  101. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  102. package/prisma/skills/code-tour/SKILL.md +254 -0
  103. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  104. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  105. package/prisma/skills/coding-standards/SKILL.md +551 -0
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  107. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  109. package/prisma/skills/config-gc/SKILL.md +120 -0
  110. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  111. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  112. package/prisma/skills/content-engine/SKILL.md +132 -0
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  114. package/prisma/skills/context-budget/SKILL.md +136 -0
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  116. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  117. package/prisma/skills/continuous-learning/config.json +18 -0
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  124. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  132. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  133. package/prisma/skills/council/SKILL.md +204 -0
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  135. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  136. package/prisma/skills/crosspost/SKILL.md +112 -0
  137. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  138. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  141. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  142. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  144. package/prisma/skills/database-migrations/SKILL.md +430 -0
  145. package/prisma/skills/deep-research/SKILL.md +160 -0
  146. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  147. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  149. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  150. package/prisma/skills/design-system/SKILL.md +83 -0
  151. package/prisma/skills/django-celery/SKILL.md +458 -0
  152. package/prisma/skills/django-patterns/SKILL.md +735 -0
  153. package/prisma/skills/django-security/SKILL.md +644 -0
  154. package/prisma/skills/django-tdd/SKILL.md +730 -0
  155. package/prisma/skills/django-verification/SKILL.md +470 -0
  156. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  157. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  158. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  159. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  161. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  162. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  163. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  165. package/prisma/skills/email-ops/SKILL.md +122 -0
  166. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  168. package/prisma/skills/error-handling/SKILL.md +377 -0
  169. package/prisma/skills/eval-harness/SKILL.md +271 -0
  170. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  171. package/prisma/skills/exa-search/SKILL.md +108 -0
  172. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  173. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  174. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  175. package/prisma/skills/flox-environments/SKILL.md +497 -0
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  178. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  179. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  180. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  181. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  183. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  184. package/prisma/skills/frontend-slides/html-template.md +419 -0
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  187. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  188. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  189. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  190. package/prisma/skills/gateguard/SKILL.md +133 -0
  191. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  192. package/prisma/skills/git-workflow/SKILL.md +716 -0
  193. package/prisma/skills/github-ops/SKILL.md +145 -0
  194. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  195. package/prisma/skills/golang-testing/SKILL.md +721 -0
  196. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  197. package/prisma/skills/growth-log/SKILL.md +128 -0
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  202. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  204. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  206. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  210. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  212. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  214. package/prisma/skills/investor-materials/SKILL.md +97 -0
  215. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  216. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  219. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  220. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  223. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  224. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  225. package/prisma/skills/jira-integration/SKILL.md +303 -0
  226. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  227. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  231. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  232. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  234. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  236. package/prisma/skills/laravel-security/SKILL.md +948 -0
  237. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  238. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  239. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  240. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  245. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  247. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  248. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  251. package/prisma/skills/manim-video/SKILL.md +90 -0
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  253. package/prisma/skills/market-research/SKILL.md +76 -0
  254. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  256. package/prisma/skills/messages-ops/SKILL.md +105 -0
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  258. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  259. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  260. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  261. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  262. package/prisma/skills/motion-ui/SKILL.md +576 -0
  263. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  265. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  268. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  269. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  283. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  284. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  285. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  286. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  287. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  288. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  289. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  291. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  292. package/prisma/skills/perl-security/SKILL.md +504 -0
  293. package/prisma/skills/perl-testing/SKILL.md +476 -0
  294. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  295. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  296. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  299. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  300. package/prisma/skills/product-capability/SKILL.md +142 -0
  301. package/prisma/skills/product-lens/SKILL.md +93 -0
  302. package/prisma/skills/production-audit/SKILL.md +207 -0
  303. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  304. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  305. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  306. package/prisma/skills/python-patterns/SKILL.md +751 -0
  307. package/prisma/skills/python-testing/SKILL.md +817 -0
  308. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  309. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  310. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  311. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  312. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  313. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  315. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  316. package/prisma/skills/react-patterns/SKILL.md +342 -0
  317. package/prisma/skills/react-performance/SKILL.md +575 -0
  318. package/prisma/skills/react-testing/SKILL.md +424 -0
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  321. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  323. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  342. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  355. package/prisma/skills/repo-scan/SKILL.md +79 -0
  356. package/prisma/skills/research-ops/SKILL.md +113 -0
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  358. package/prisma/skills/rules-distill/SKILL.md +265 -0
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  361. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  362. package/prisma/skills/rust-testing/SKILL.md +501 -0
  363. package/prisma/skills/safety-guard/SKILL.md +76 -0
  364. package/prisma/skills/santa-method/SKILL.md +307 -0
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  370. package/prisma/skills/search-first/SKILL.md +183 -0
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  372. package/prisma/skills/security-review/SKILL.md +504 -0
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  374. package/prisma/skills/security-scan/SKILL.md +166 -0
  375. package/prisma/skills/seo/SKILL.md +155 -0
  376. package/prisma/skills/skill-comply/SKILL.md +59 -0
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  380. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  383. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  386. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  387. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  388. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  389. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  390. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  393. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  394. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  395. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  396. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  397. package/prisma/skills/skill-scout/SKILL.md +141 -0
  398. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  402. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  403. package/prisma/skills/social-publisher/SKILL.md +130 -0
  404. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  405. package/prisma/skills/springboot-security/SKILL.md +273 -0
  406. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  407. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  408. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  412. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  413. package/prisma/skills/taste/SKILL.md +264 -0
  414. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  415. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  417. package/prisma/skills/team-builder/SKILL.md +169 -0
  418. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  422. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  426. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  427. package/prisma/skills/ui-demo/SKILL.md +466 -0
  428. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  429. package/prisma/skills/uncloud/SKILL.md +344 -0
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  431. package/prisma/skills/verification-loop/SKILL.md +127 -0
  432. package/prisma/skills/video-editing/SKILL.md +311 -0
  433. package/prisma/skills/videodb/SKILL.md +375 -0
  434. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  435. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  436. package/prisma/skills/videodb/reference/capture.md +101 -0
  437. package/prisma/skills/videodb/reference/editor.md +443 -0
  438. package/prisma/skills/videodb/reference/generative.md +331 -0
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  440. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  441. package/prisma/skills/videodb/reference/search.md +230 -0
  442. package/prisma/skills/videodb/reference/streaming.md +406 -0
  443. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  444. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  445. package/prisma/skills/visa-doc-translate/README.md +86 -0
  446. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  447. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  448. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  451. package/prisma/skills/x-api/SKILL.md +235 -0
@@ -0,0 +1,675 @@
1
+ ---
2
+ name: laravel-tdd
3
+ description: Laravel testing strategies with PHPUnit, Pest, model factories, HTTP tests, Sanctum authentication testing, mocking, and coverage.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Laravel Testing with TDD
9
+
10
+ Test-driven development for Laravel applications using PHPUnit, Pest, Laravel factories, and testing helpers.
11
+
12
+ ## When to Activate
13
+
14
+ - Writing new Laravel applications or features
15
+ - Implementing API endpoints with Sanctum or Passport authentication
16
+ - Testing Eloquent models, relationships, scopes, and accessors
17
+ - Setting up testing infrastructure for Laravel projects
18
+ - Writing feature tests for HTTP controllers and form requests
19
+ - Mocking external services (queues, mail, notifications, HTTP)
20
+
21
+ ## TDD Workflow for Laravel
22
+
23
+ ### Red-Green-Refactor Cycle
24
+
25
+ ```php
26
+ // Step 1: RED — Write a failing test
27
+ public function test_a_product_can_be_created(): void
28
+ {
29
+ $product = Product::factory()->create(['name' => 'Test Product']);
30
+ $this->assertDatabaseHas('products', ['name' => 'Test Product']);
31
+ }
32
+
33
+ // Step 2: GREEN — Write the migration, model, and factory
34
+ // Step 3: REFACTOR — Improve while keeping tests green
35
+ ```
36
+
37
+ ## Setup
38
+
39
+ ### PHPUnit Configuration
40
+
41
+ ```xml
42
+ <?xml version="1.0" encoding="UTF-8"?>
43
+ <phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
44
+ xsi:noNamespaceSchemaLocation="vendor/phpunit/phpunit/phpunit.xsd"
45
+ bootstrap="vendor/autoload.php"
46
+ colors="true">
47
+ <testsuites>
48
+ <testsuite name="Unit">
49
+ <directory suffix="Test.php">tests/Unit</directory>
50
+ </testsuite>
51
+ <testsuite name="Feature">
52
+ <directory suffix="Test.php">tests/Feature</directory>
53
+ </testsuite>
54
+ </testsuites>
55
+ <php>
56
+ <env name="APP_ENV" value="testing"/>
57
+ <env name="BCRYPT_ROUNDS" value="4"/>
58
+ <env name="CACHE_STORE" value="array"/>
59
+ <env name="DB_CONNECTION" value="sqlite"/>
60
+ <env name="DB_DATABASE" value=":memory:"/>
61
+ <env name="MAIL_MAILER" value="array"/>
62
+ <env name="QUEUE_CONNECTION" value="sync"/>
63
+ <env name="SESSION_DRIVER" value="array"/>
64
+ </php>
65
+ </phpunit>
66
+ ```
67
+
68
+ ### Base TestCase Setup
69
+
70
+ ```php
71
+ namespace Tests;
72
+
73
+ use Illuminate\Foundation\Testing\TestCase as BaseTestCase;
74
+
75
+ abstract class TestCase extends BaseTestCase
76
+ {
77
+ protected function setUp(): void
78
+ {
79
+ parent::setUp();
80
+ // Call $this->withoutExceptionHandling() only in tests that
81
+ // test non-HTTP exceptions; it suppresses assertStatus() etc.
82
+ }
83
+
84
+ // Helper: Authenticate and return user
85
+ protected function actingAsUser(): mixed
86
+ {
87
+ $user = \App\Models\User::factory()->create();
88
+ $this->actingAs($user);
89
+ return $user;
90
+ }
91
+
92
+ protected function actingAsAdmin(): mixed
93
+ {
94
+ $admin = \App\Models\User::factory()->admin()->create();
95
+ $this->actingAs($admin);
96
+ return $admin;
97
+ }
98
+ }
99
+ ```
100
+
101
+ ## Model Factories
102
+
103
+ ```php
104
+ // database/factories/UserFactory.php
105
+ class UserFactory extends Factory
106
+ {
107
+ protected static ?string $password = null;
108
+
109
+ public function definition(): array
110
+ {
111
+ return [
112
+ 'name' => fake()->name(),
113
+ 'email' => fake()->unique()->safeEmail(),
114
+ 'email_verified_at' => now(),
115
+ 'password' => static::$password ??= Hash::make('password'),
116
+ 'remember_token' => Str::random(10),
117
+ 'role' => 'user',
118
+ ];
119
+ }
120
+
121
+ public function admin(): static
122
+ {
123
+ return $this->state(fn (array $attributes) => ['role' => 'admin']);
124
+ }
125
+
126
+ public function unverified(): static
127
+ {
128
+ return $this->state(fn (array $attributes) => ['email_verified_at' => null]);
129
+ }
130
+ }
131
+
132
+ // database/factories/ProductFactory.php
133
+ class ProductFactory extends Factory
134
+ {
135
+ public function definition(): array
136
+ {
137
+ return [
138
+ 'name' => fake()->unique()->words(3, true),
139
+ 'slug' => fn (array $attrs) => Str::slug($attrs['name']),
140
+ 'description' => fake()->paragraph(),
141
+ 'price' => fake()->numberBetween(100, 100000),
142
+ 'stock' => fake()->numberBetween(0, 100),
143
+ 'is_active' => true,
144
+ 'user_id' => UserFactory::new(),
145
+ ];
146
+ }
147
+
148
+ public function outOfStock(): static
149
+ {
150
+ return $this->state(fn (array $attributes) => ['stock' => 0]);
151
+ }
152
+ }
153
+ ```
154
+
155
+ ### Using Factories
156
+
157
+ ```php
158
+ $user = User::factory()->create();
159
+ $admin = User::factory()->admin()->create();
160
+ $product = Product::factory()->create(['user_id' => $user->id]);
161
+ $products = Product::factory()->count(10)->create();
162
+ $draft = Product::factory()->make(); // Not persisted
163
+
164
+ // With relationships
165
+ $user = User::factory()->has(Product::factory()->count(3))->create();
166
+
167
+ // Sequences
168
+ User::factory()->count(3)->sequence(
169
+ ['role' => 'admin'], ['role' => 'editor'], ['role' => 'user'],
170
+ )->create();
171
+ ```
172
+
173
+ ## Model Testing
174
+
175
+ ```php
176
+ namespace Tests\Unit\Models;
177
+
178
+ use App\Models\User;
179
+ use App\Models\Product;
180
+ use Illuminate\Foundation\Testing\RefreshDatabase;
181
+ use Tests\TestCase;
182
+
183
+ class UserTest extends TestCase
184
+ {
185
+ use RefreshDatabase;
186
+
187
+ public function test_it_hides_sensitive_attributes(): void
188
+ {
189
+ $user = User::factory()->create();
190
+ $this->assertArrayNotHasKey('password', $user->toArray());
191
+ }
192
+
193
+ public function test_admin_scope_returns_only_admins(): void
194
+ {
195
+ User::factory()->admin()->create();
196
+ User::factory()->count(3)->create();
197
+
198
+ $this->assertCount(1, User::admin()->get());
199
+ }
200
+ }
201
+
202
+ class ProductTest extends TestCase
203
+ {
204
+ use RefreshDatabase;
205
+
206
+ public function test_active_scope_filters_correctly(): void
207
+ {
208
+ Product::factory()->count(3)->create(['is_active' => true]);
209
+ Product::factory()->count(2)->create(['is_active' => false]);
210
+
211
+ $this->assertCount(3, Product::active()->get());
212
+ }
213
+
214
+ public function test_it_belongs_to_a_user(): void
215
+ {
216
+ $user = User::factory()->create();
217
+ $product = Product::factory()->create(['user_id' => $user->id]);
218
+
219
+ $this->assertTrue($product->user->is($user));
220
+ }
221
+ }
222
+ ```
223
+
224
+ ## Feature / HTTP Testing
225
+
226
+ ```php
227
+ namespace Tests\Feature\Http\Controllers;
228
+
229
+ use App\Models\Product;
230
+ use App\Models\User;
231
+ use Illuminate\Foundation\Testing\RefreshDatabase;
232
+ use Tests\TestCase;
233
+
234
+ class ProductControllerTest extends TestCase
235
+ {
236
+ use RefreshDatabase;
237
+
238
+ public function test_guests_are_redirected_to_login(): void
239
+ {
240
+ $this->get(route('products.create'))->assertRedirect(route('login'));
241
+ }
242
+
243
+ public function test_it_stores_a_new_product(): void
244
+ {
245
+ $user = User::factory()->create();
246
+ $this->actingAs($user);
247
+
248
+ $response = $this->post(route('products.store'), [
249
+ 'name' => 'New Product',
250
+ 'description' => 'Description',
251
+ 'price' => 2999,
252
+ 'stock' => 10,
253
+ ]);
254
+
255
+ $response->assertRedirect(route('products.index'));
256
+ $this->assertDatabaseHas('products', [
257
+ 'name' => 'New Product',
258
+ 'user_id' => $user->id,
259
+ ]);
260
+ }
261
+
262
+ public function test_it_validates_required_fields(): void
263
+ {
264
+ $this->actingAs(User::factory()->create());
265
+ $this->post(route('products.store'), [])
266
+ ->assertSessionHasErrors(['name', 'price']);
267
+ }
268
+
269
+ public function test_users_cannot_modify_others_products(): void
270
+ {
271
+ $owner = User::factory()->create();
272
+ $attacker = User::factory()->create();
273
+ $product = Product::factory()->create(['user_id' => $owner->id]);
274
+
275
+ $this->actingAs($attacker)
276
+ ->delete(route('products.destroy', $product))
277
+ ->assertForbidden();
278
+ }
279
+ }
280
+ ```
281
+
282
+ ## JSON API Testing
283
+
284
+ ```php
285
+ namespace Tests\Feature\Http\Controllers\Api;
286
+
287
+ use App\Models\Product;
288
+ use App\Models\User;
289
+ use Illuminate\Foundation\Testing\RefreshDatabase;
290
+ use Tests\TestCase;
291
+
292
+ class ProductApiTest extends TestCase
293
+ {
294
+ use RefreshDatabase;
295
+
296
+ public function test_unauthenticated_requests_are_rejected(): void
297
+ {
298
+ $this->getJson('/api/products')->assertUnauthorized();
299
+ }
300
+
301
+ public function test_it_lists_paginated_products(): void
302
+ {
303
+ $user = User::factory()->create();
304
+ Product::factory()->count(5)->create(['user_id' => $user->id]);
305
+
306
+ $response = $this->actingAs($user)->getJson('/api/products');
307
+
308
+ $response->assertOk();
309
+ $response->assertJsonCount(5, 'data');
310
+ $response->assertJsonStructure([
311
+ 'data' => [['id', 'name', 'price']],
312
+ 'meta' => ['current_page', 'last_page', 'total'],
313
+ ]);
314
+ }
315
+
316
+ public function test_it_creates_a_product(): void
317
+ {
318
+ $user = User::factory()->create();
319
+
320
+ $response = $this->actingAs($user)->postJson('/api/products', [
321
+ 'name' => 'API Product',
322
+ 'price' => 4999,
323
+ ]);
324
+
325
+ $response->assertCreated();
326
+ $response->assertJsonPath('data.name', 'API Product');
327
+ }
328
+
329
+ public function test_users_cannot_delete_others_products(): void
330
+ {
331
+ $owner = User::factory()->create();
332
+ $attacker = User::factory()->create();
333
+ $product = Product::factory()->create(['user_id' => $owner->id]);
334
+
335
+ $this->actingAs($attacker)
336
+ ->deleteJson("/api/products/{$product->id}")
337
+ ->assertForbidden();
338
+ }
339
+ }
340
+ ```
341
+
342
+ ## Sanctum API Auth Testing
343
+
344
+ ```php
345
+ namespace Tests\Feature\Http\Controllers\Api;
346
+
347
+ use App\Models\User;
348
+ use Illuminate\Foundation\Testing\RefreshDatabase;
349
+ use Illuminate\Support\Facades\Hash;
350
+ use Tests\TestCase;
351
+
352
+ class AuthControllerTest extends TestCase
353
+ {
354
+ use RefreshDatabase;
355
+
356
+ public function test_users_can_register(): void
357
+ {
358
+ $response = $this->postJson('/api/register', [
359
+ 'name' => 'Test User',
360
+ 'email' => 'test@example.com',
361
+ 'password' => 'Password123!',
362
+ 'password_confirmation' => 'Password123!',
363
+ ]);
364
+
365
+ $response->assertCreated();
366
+ $response->assertJsonStructure(['data' => ['user', 'token']]);
367
+ }
368
+
369
+ public function test_users_can_login(): void
370
+ {
371
+ User::factory()->create([
372
+ 'email' => 'test@example.com',
373
+ 'password' => Hash::make('Password123!'),
374
+ ]);
375
+
376
+ $response = $this->postJson('/api/login', [
377
+ 'email' => 'test@example.com',
378
+ 'password' => 'Password123!',
379
+ ]);
380
+
381
+ $response->assertOk();
382
+ $response->assertJsonStructure(['data' => ['token']]);
383
+ }
384
+
385
+ public function test_users_cannot_login_with_wrong_password(): void
386
+ {
387
+ User::factory()->create(['email' => 'test@example.com']);
388
+
389
+ $this->postJson('/api/login', [
390
+ 'email' => 'test@example.com',
391
+ 'password' => 'wrong',
392
+ ])->assertUnprocessable();
393
+ }
394
+
395
+ public function test_token_bearer_authenticates_requests(): void
396
+ {
397
+ $user = User::factory()->create();
398
+ $token = $user->createToken('test')->plainTextToken;
399
+
400
+ $this->withToken($token)
401
+ ->getJson('/api/user')
402
+ ->assertOk()
403
+ ->assertJsonPath('data.email', $user->email);
404
+ }
405
+ }
406
+ ```
407
+
408
+ ## Mocking and Fakes
409
+
410
+ ### HTTP Fake
411
+
412
+ ```php
413
+ use Illuminate\Support\Facades\Http;
414
+
415
+ public function test_it_handles_successful_payment(): void
416
+ {
417
+ Http::fake([
418
+ 'api.stripe.com/*' => Http::response(['id' => 'pi_123', 'status' => 'succeeded'], 200),
419
+ ]);
420
+
421
+ $result = (new PaymentService())->charge(2999);
422
+ $this->assertTrue($result->success);
423
+ }
424
+
425
+ public function test_it_handles_gateway_failure(): void
426
+ {
427
+ Http::fake([
428
+ 'api.stripe.com/*' => Http::response(['error' => 'card_declined'], 402),
429
+ ]);
430
+
431
+ $this->expectException(PaymentFailedException::class);
432
+ (new PaymentService())->charge(2999);
433
+ }
434
+
435
+ public function test_it_retries_on_timeout(): void
436
+ {
437
+ Http::fake([
438
+ 'api.stripe.com/*' => Http::sequence()
439
+ ->pushStatus(408)
440
+ ->pushStatus(200),
441
+ ]);
442
+
443
+ $this->assertTrue((new PaymentService())->charge(2999)->success);
444
+ }
445
+ ```
446
+
447
+ ### Mail Fake
448
+
449
+ ```php
450
+ Mail::fake();
451
+
452
+ $order->sendConfirmation();
453
+
454
+ Mail::assertSent(OrderConfirmation::class, function ($mail) use ($order) {
455
+ return $mail->hasTo($order->user->email);
456
+ });
457
+ ```
458
+
459
+ ### Notification Fake
460
+
461
+ ```php
462
+ Notification::fake();
463
+
464
+ $user->notify(new WelcomeUser());
465
+
466
+ Notification::assertSentTo($user, WelcomeUser::class);
467
+ ```
468
+
469
+ ### Queue Fake
470
+
471
+ ```php
472
+ Queue::fake();
473
+
474
+ ProcessImage::dispatch($product);
475
+
476
+ Queue::assertPushed(ProcessImage::class, function ($job) use ($product) {
477
+ return $job->product->id === $product->id;
478
+ });
479
+ ```
480
+
481
+ ### Storage Fake
482
+
483
+ ```php
484
+ Storage::fake('public');
485
+
486
+ $file = UploadedFile::fake()->image('photo.jpg', 200, 200);
487
+
488
+ $response = $this->actingAs($user)->post('/avatar', [
489
+ 'avatar' => $file,
490
+ ]);
491
+
492
+ $response->assertSessionHasNoErrors();
493
+ Storage::disk('public')->assertExists('avatars/' . $file->hashName());
494
+ ```
495
+
496
+ ### Event Fake
497
+
498
+ ```php
499
+ Event::fake();
500
+
501
+ $order->markAsShipped();
502
+
503
+ Event::assertDispatched(OrderShipped::class, function ($event) use ($order) {
504
+ return $event->order->id === $order->id;
505
+ });
506
+ ```
507
+
508
+ ## Artisan Command Tests
509
+
510
+ ```php
511
+ public function test_it_sends_newsletters(): void
512
+ {
513
+ Mail::fake();
514
+ User::factory()->count(5)->create(['subscribed' => true]);
515
+
516
+ $this->artisan('newsletter:send')
517
+ ->expectsOutput('Sending newsletter to 5 subscribers...')
518
+ ->assertExitCode(0);
519
+
520
+ Mail::assertSent(NewsletterMail::class, 5);
521
+ }
522
+
523
+ public function test_it_handles_no_subscribers(): void
524
+ {
525
+ $this->artisan('newsletter:send')
526
+ ->expectsOutput('No subscribers found.')
527
+ ->assertExitCode(0);
528
+ }
529
+ ```
530
+
531
+ ## Authorization Tests
532
+
533
+ ```php
534
+ public function test_users_can_update_own_posts(): void
535
+ {
536
+ $user = User::factory()->create();
537
+ $post = Post::factory()->create(['user_id' => $user->id]);
538
+
539
+ $this->actingAs($user)
540
+ ->put(route('posts.update', $post), ['title' => 'Updated'])
541
+ ->assertRedirect();
542
+ }
543
+
544
+ public function test_users_cannot_update_others_posts(): void
545
+ {
546
+ $post = Post::factory()->create();
547
+ $this->actingAs(User::factory()->create())
548
+ ->put(route('posts.update', $post), ['title' => 'Hacked'])
549
+ ->assertForbidden();
550
+ }
551
+
552
+ public function test_gate_before_grants_super_admin_full_access(): void
553
+ {
554
+ $super = User::factory()->create(['role' => 'super-admin']);
555
+ $post = Post::factory()->create();
556
+
557
+ $this->actingAs($super)
558
+ ->delete(route('posts.destroy', $post))
559
+ ->assertRedirect();
560
+
561
+ $this->assertSoftDeleted($post);
562
+ }
563
+ ```
564
+
565
+ ## Pest Feature Tests
566
+
567
+ ```php
568
+ <?php
569
+
570
+ use App\Models\Product;
571
+ use App\Models\User;
572
+
573
+ uses(\Illuminate\Foundation\Testing\RefreshDatabase::class);
574
+
575
+ beforeEach(function () {
576
+ $this->user = User::factory()->create();
577
+ $this->actingAs($this->user);
578
+ });
579
+
580
+ it('lists products', function () {
581
+ Product::factory()->count(3)->create(['user_id' => $this->user->id]);
582
+
583
+ $this->get(route('products.index'))
584
+ ->assertOk()
585
+ ->assertViewHas('products');
586
+ });
587
+
588
+ it('creates a product with valid data', function () {
589
+ $this->post(route('products.store'), [
590
+ 'name' => 'Test Product', 'price' => 1999,
591
+ ])->assertRedirect();
592
+
593
+ $this->assertDatabaseHas('products', ['name' => 'Test Product']);
594
+ });
595
+
596
+ it('fails validation without required fields', function () {
597
+ $this->post(route('products.store'), [])
598
+ ->assertSessionHasErrors(['name', 'price']);
599
+ });
600
+
601
+ it('authorizes updates', function () {
602
+ $other = User::factory()->create();
603
+ $product = Product::factory()->create(['user_id' => $other->id]);
604
+
605
+ $this->put(route('products.update', $product), ['name' => 'Hacked'])
606
+ ->assertForbidden();
607
+ });
608
+ ```
609
+
610
+ ## Coverage
611
+
612
+ ```bash
613
+ # PHPUnit (use clover output for CI threshold checks)
614
+ vendor/bin/phpunit --coverage-html coverage --coverage-clover clover.xml
615
+
616
+ # Pest (built-in threshold support)
617
+ vendor/bin/pest --coverage --min=80
618
+ ```
619
+
620
+ ### Coverage Goals
621
+
622
+ | Component | Target |
623
+ |-----------|--------|
624
+ | Models | 95%+ |
625
+ | Actions/Services | 90%+ |
626
+ | Form Requests | 90%+ |
627
+ | Controllers | 85%+ |
628
+ | Policies | 95%+ |
629
+ | Overall | 80%+ |
630
+
631
+ ## Testing Best Practices
632
+
633
+ ### DO
634
+
635
+ - Use factories over manual `create()` calls
636
+ - One logical assertion per test
637
+ - Descriptive names: `test_guests_cannot_create_products`
638
+ - Test edge cases and authorization boundaries
639
+ - Mock external services with `Http::fake()`, `Mail::fake()`
640
+ - Use `RefreshDatabase` for clean state
641
+
642
+ ### DON'T
643
+
644
+ - Don't test Laravel internals (trust the framework)
645
+ - Don't make tests dependent on each other
646
+ - Don't over-mock — mock only service boundaries
647
+ - Don't test private methods — test through the public interface
648
+ - Don't couple tests to HTML structure
649
+
650
+ ## Quick Reference
651
+
652
+ | Pattern | Usage |
653
+ |---------|-------|
654
+ | `RefreshDatabase` | Reset database between tests |
655
+ | `$this->actingAs($user)` | Authenticate as user |
656
+ | `$this->withToken($token)` | Bearer token auth for APIs |
657
+ | `Model::factory()->create()` | Create model with factory |
658
+ | `Model::factory()->count(5)->create()` | Create multiple records |
659
+ | `Http::fake([...])` | Mock HTTP calls |
660
+ | `Mail::fake()` | Trap sent mail |
661
+ | `Notification::fake()` | Trap sent notifications |
662
+ | `Queue::fake()` | Trap queued jobs |
663
+ | `Event::fake()` | Trap dispatched events |
664
+ | `Storage::fake('public')` | Trap file operations |
665
+ | `assertDatabaseHas` | Assert DB row exists |
666
+ | `assertSoftDeleted` | Assert soft-delete |
667
+ | `assertSessionHasErrors` | Assert validation errors |
668
+ | `assertForbidden` | Assert 403 status |
669
+
670
+ ## Related Skills
671
+
672
+ - `laravel-patterns` — Laravel architecture, Eloquent, routing, and API patterns
673
+ - `laravel-security` — Laravel authentication, authorization, and secure coding
674
+ - `tdd-workflow` — The repo-wide RED -> GREEN -> REFACTOR loop
675
+ - `backend-patterns` — General backend API and database patterns