@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,458 @@
1
+ ---
2
+ name: django-celery
3
+ description: Django + Celery async task patterns — configuration, task design, beat scheduling, retries, canvas workflows, monitoring, and testing. Use when adding background jobs, scheduled tasks, or async processing to a Django app.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Django + Celery Async Task Patterns
9
+
10
+ Production-grade patterns for background task processing in Django using Celery with Redis or RabbitMQ.
11
+
12
+ ## When to Activate
13
+
14
+ - Adding background jobs or async processing to a Django app
15
+ - Implementing periodic/scheduled tasks
16
+ - Offloading slow operations (email, PDF generation, API calls) from request cycle
17
+ - Setting up Celery Beat for cron-like scheduling
18
+ - Debugging task failures, retries, or queue backlogs
19
+ - Writing tests for Celery tasks
20
+
21
+ ## Project Setup
22
+
23
+ ### Installation
24
+
25
+ ```bash
26
+ pip install 'celery[redis]' django-celery-results django-celery-beat
27
+ ```
28
+
29
+ ### `celery.py` — App Entrypoint
30
+
31
+ ```python
32
+ # config/celery.py
33
+ import os
34
+ from celery import Celery
35
+
36
+ os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'config.settings.development')
37
+
38
+ app = Celery('myproject')
39
+ app.config_from_object('django.conf:settings', namespace='CELERY')
40
+ app.autodiscover_tasks() # Discovers tasks.py in each INSTALLED_APP
41
+
42
+ @app.task(bind=True, ignore_result=True)
43
+ def debug_task(self):
44
+ print(f'Request: {self.request!r}')
45
+ ```
46
+
47
+ ```python
48
+ # config/__init__.py
49
+ from .celery import app as celery_app
50
+
51
+ __all__ = ('celery_app',)
52
+ ```
53
+
54
+ ### Django Settings
55
+
56
+ ```python
57
+ # config/settings/base.py
58
+
59
+ # Broker (Redis recommended for production)
60
+ CELERY_BROKER_URL = env('CELERY_BROKER_URL', default='redis://localhost:6379/0')
61
+ CELERY_RESULT_BACKEND = env('CELERY_RESULT_BACKEND', default='django-db')
62
+
63
+ # Serialization
64
+ CELERY_ACCEPT_CONTENT = ['json']
65
+ CELERY_TASK_SERIALIZER = 'json'
66
+ CELERY_RESULT_SERIALIZER = 'json'
67
+
68
+ # Task behavior
69
+ CELERY_TASK_TRACK_STARTED = True
70
+ CELERY_TASK_TIME_LIMIT = 30 * 60 # Hard limit: 30 min
71
+ CELERY_TASK_SOFT_TIME_LIMIT = 25 * 60 # Soft limit: sends SoftTimeLimitExceeded
72
+ CELERY_WORKER_PREFETCH_MULTIPLIER = 1 # Prevent worker hoarding long tasks
73
+ CELERY_TASK_ACKS_LATE = True # Re-queue on worker crash
74
+
75
+ # Result persistence
76
+ CELERY_RESULT_EXPIRES = 60 * 60 * 24 # Keep results 24 hours
77
+
78
+ # Beat scheduler (for periodic tasks)
79
+ CELERY_BEAT_SCHEDULER = 'django_celery_beat.schedulers:DatabaseScheduler'
80
+
81
+ # Installed apps
82
+ INSTALLED_APPS += [
83
+ 'django_celery_results',
84
+ 'django_celery_beat',
85
+ ]
86
+ ```
87
+
88
+ ### Running Workers
89
+
90
+ ```bash
91
+ # Start worker (development)
92
+ celery -A config worker --loglevel=info
93
+
94
+ # Start beat scheduler (periodic tasks)
95
+ celery -A config beat --loglevel=info --scheduler django_celery_beat.schedulers:DatabaseScheduler
96
+
97
+ # Combined worker + beat (dev only, never production)
98
+ celery -A config worker --beat --loglevel=info
99
+
100
+ # Production: multiple workers with concurrency
101
+ celery -A config worker --loglevel=warning --concurrency=4 -Q default,high_priority
102
+ ```
103
+
104
+ ## Task Design Patterns
105
+
106
+ ### Basic Task
107
+
108
+ ```python
109
+ # apps/notifications/tasks.py
110
+ from celery import shared_task
111
+ import logging
112
+
113
+ logger = logging.getLogger(__name__)
114
+
115
+ @shared_task(name='notifications.send_welcome_email')
116
+ def send_welcome_email(user_id: int) -> None:
117
+ """Send welcome email to newly registered user."""
118
+ from apps.users.models import User
119
+ from apps.notifications.services import EmailService
120
+
121
+ try:
122
+ user = User.objects.get(pk=user_id)
123
+ except User.DoesNotExist:
124
+ logger.warning('send_welcome_email: user %s not found', user_id)
125
+ return # Idempotent — do not raise, task already impossible to complete
126
+
127
+ EmailService.send_welcome(user)
128
+ logger.info('Welcome email sent to user %s', user_id)
129
+ ```
130
+
131
+ ### Retryable Task
132
+
133
+ ```python
134
+ @shared_task(
135
+ bind=True,
136
+ name='integrations.sync_to_crm',
137
+ max_retries=5,
138
+ default_retry_delay=60, # seconds before first retry
139
+ autoretry_for=(ConnectionError, TimeoutError),
140
+ retry_backoff=True, # exponential backoff
141
+ retry_backoff_max=600, # cap at 10 minutes
142
+ retry_jitter=True, # randomise to avoid thundering herd
143
+ )
144
+ def sync_contact_to_crm(self, contact_id: int) -> dict:
145
+ """Sync contact to external CRM with retry on transient failures."""
146
+ from apps.crm.services import CRMClient
147
+
148
+ try:
149
+ result = CRMClient().sync(contact_id)
150
+ return result
151
+ except CRMClient.RateLimitError as exc:
152
+ # Specific retry delay from response header
153
+ raise self.retry(exc=exc, countdown=int(exc.retry_after))
154
+ ```
155
+
156
+ ### Idempotent Task Pattern
157
+
158
+ Design tasks so they can safely run multiple times with the same inputs:
159
+
160
+ ```python
161
+ @shared_task(name='orders.mark_shipped')
162
+ def mark_order_shipped(order_id: int, tracking_number: str) -> None:
163
+ """Mark order as shipped — safe to run multiple times."""
164
+ from apps.orders.models import Order
165
+
166
+ updated = Order.objects.filter(
167
+ pk=order_id,
168
+ status=Order.Status.PROCESSING, # Guard: only update if not already shipped
169
+ ).update(
170
+ status=Order.Status.SHIPPED,
171
+ tracking_number=tracking_number,
172
+ )
173
+
174
+ if not updated:
175
+ logger.info('mark_order_shipped: order %s already shipped or not found', order_id)
176
+ ```
177
+
178
+ ### Task with Soft Time Limit
179
+
180
+ ```python
181
+ from celery.exceptions import SoftTimeLimitExceeded
182
+
183
+ @shared_task(
184
+ bind=True,
185
+ name='reports.generate_pdf',
186
+ soft_time_limit=120,
187
+ time_limit=150,
188
+ )
189
+ def generate_pdf_report(self, report_id: int) -> str:
190
+ """Generate PDF report with graceful timeout handling."""
191
+ from apps.reports.services import PDFGenerator
192
+
193
+ try:
194
+ path = PDFGenerator.build(report_id)
195
+ return path
196
+ except SoftTimeLimitExceeded:
197
+ # Clean up partial files before hard kill
198
+ PDFGenerator.cleanup(report_id)
199
+ raise
200
+ ```
201
+
202
+ ## Calling Tasks
203
+
204
+ ```python
205
+ from datetime import timedelta
206
+ from django.utils import timezone
207
+
208
+ # Fire and forget (async)
209
+ send_welcome_email.delay(user.pk)
210
+
211
+ # Schedule in the future
212
+ send_reminder.apply_async(args=[user.pk], countdown=3600) # 1 hour from now
213
+ send_reminder.apply_async(args=[user.pk], eta=timezone.now() + timedelta(days=1))
214
+
215
+ # Apply with queue routing
216
+ sync_contact_to_crm.apply_async(args=[contact.pk], queue='high_priority')
217
+
218
+ # Run synchronously (tests / debugging only)
219
+ result = generate_pdf_report.apply(args=[report.pk])
220
+ ```
221
+
222
+ ## Beat Scheduling (Periodic Tasks)
223
+
224
+ ### Code-Defined Schedule
225
+
226
+ ```python
227
+ # config/settings/base.py
228
+ from celery.schedules import crontab
229
+
230
+ CELERY_BEAT_SCHEDULE = {
231
+ 'cleanup-expired-sessions': {
232
+ 'task': 'users.cleanup_expired_sessions',
233
+ 'schedule': crontab(hour=2, minute=0), # 2am daily
234
+ },
235
+ 'sync-inventory': {
236
+ 'task': 'products.sync_inventory',
237
+ 'schedule': 60.0, # every 60 seconds
238
+ },
239
+ 'weekly-digest': {
240
+ 'task': 'notifications.send_weekly_digest',
241
+ 'schedule': crontab(day_of_week='monday', hour=8, minute=0),
242
+ },
243
+ }
244
+ ```
245
+
246
+ ### Database-Defined Schedule (via django-celery-beat)
247
+
248
+ ```python
249
+ # Manage periodic tasks from Django admin or code
250
+ from django_celery_beat.models import PeriodicTask, CrontabSchedule
251
+ import json
252
+
253
+ schedule, _ = CrontabSchedule.objects.get_or_create(
254
+ hour='*/6', minute='0',
255
+ timezone='UTC',
256
+ )
257
+
258
+ PeriodicTask.objects.update_or_create(
259
+ name='Sync inventory every 6 hours',
260
+ defaults={
261
+ 'crontab': schedule,
262
+ 'task': 'products.sync_inventory',
263
+ 'args': json.dumps([]),
264
+ 'enabled': True,
265
+ }
266
+ )
267
+ ```
268
+
269
+ ## Canvas: Chaining and Grouping Tasks
270
+
271
+ ```python
272
+ from celery import chain, group, chord
273
+
274
+ # Chain: run tasks sequentially, passing results
275
+ pipeline = chain(
276
+ fetch_data.s(source_id),
277
+ transform_data.s(), # receives fetch_data result as first arg
278
+ load_to_warehouse.s(),
279
+ )
280
+ pipeline.delay()
281
+
282
+ # Group: run tasks in parallel
283
+ parallel = group(
284
+ send_welcome_email.s(user_id)
285
+ for user_id in new_user_ids
286
+ )
287
+ parallel.delay()
288
+
289
+ # Chord: parallel tasks + callback when all complete
290
+ result = chord(
291
+ group(process_chunk.s(chunk) for chunk in data_chunks),
292
+ aggregate_results.s(), # called with list of chunk results
293
+ )
294
+ result.delay()
295
+ ```
296
+
297
+ ## Error Handling and Dead Letter Queue
298
+
299
+ ```python
300
+ # apps/core/tasks.py
301
+ from celery.signals import task_failure
302
+
303
+ @task_failure.connect
304
+ def on_task_failure(sender, task_id, exception, args, kwargs, traceback, einfo, **kw):
305
+ """Log all task failures to Sentry / alerting."""
306
+ import sentry_sdk
307
+ with sentry_sdk.new_scope() as scope:
308
+ scope.set_context('celery', {
309
+ 'task': sender.name,
310
+ 'task_id': task_id,
311
+ 'args': args,
312
+ 'kwargs': kwargs,
313
+ })
314
+ sentry_sdk.capture_exception(exception)
315
+ ```
316
+
317
+ ```python
318
+ # Route failed tasks to dead-letter queue after max retries
319
+ @shared_task(
320
+ bind=True,
321
+ max_retries=3,
322
+ name='payments.charge_card',
323
+ )
324
+ def charge_card(self, order_id: int) -> None:
325
+ from apps.payments.models import Order, FailedCharge
326
+
327
+ try:
328
+ _do_charge(order_id)
329
+ except Exception as exc:
330
+ if self.request.retries >= self.max_retries:
331
+ # Persist to dead-letter table for manual review
332
+ FailedCharge.objects.create(
333
+ order_id=order_id,
334
+ error=str(exc),
335
+ task_id=self.request.id,
336
+ )
337
+ return # Don't raise — task is permanently failed
338
+ raise self.retry(exc=exc)
339
+ ```
340
+
341
+ ## Testing Celery Tasks
342
+
343
+ ### Unit Testing (No Broker)
344
+
345
+ ```python
346
+ # tests/test_tasks.py
347
+ import pytest
348
+ from unittest.mock import patch, MagicMock
349
+ from apps.notifications.tasks import send_welcome_email
350
+
351
+ class TestSendWelcomeEmail:
352
+
353
+ @pytest.mark.django_db
354
+ def test_sends_email_to_existing_user(self, user):
355
+ with patch('apps.notifications.services.EmailService') as mock_email:
356
+ send_welcome_email(user.pk)
357
+ mock_email.send_welcome.assert_called_once_with(user)
358
+
359
+ @pytest.mark.django_db
360
+ def test_skips_missing_user_gracefully(self):
361
+ """Should not raise when user is deleted between enqueue and execute."""
362
+ send_welcome_email(99999) # Non-existent user — must not raise
363
+ ```
364
+
365
+ ### Integration Testing with CELERY_TASK_ALWAYS_EAGER
366
+
367
+ ```python
368
+ # config/settings/test.py
369
+ CELERY_TASK_ALWAYS_EAGER = True # Run tasks synchronously in tests
370
+ CELERY_TASK_EAGER_PROPAGATES = True # Re-raise exceptions from tasks
371
+
372
+ # tests/test_integration.py
373
+ @pytest.mark.django_db
374
+ def test_registration_triggers_welcome_email(client):
375
+ with patch('apps.notifications.services.EmailService') as mock_email:
376
+ response = client.post('/api/users/', {
377
+ 'email': 'new@example.com',
378
+ 'password': 'strongpass123',
379
+ })
380
+
381
+ assert response.status_code == 201
382
+ mock_email.send_welcome.assert_called_once()
383
+ ```
384
+
385
+ ### Testing Retries
386
+
387
+ ```python
388
+ @pytest.mark.django_db
389
+ def test_task_retries_on_connection_error():
390
+ with patch('apps.crm.services.CRMClient.sync') as mock_sync:
391
+ mock_sync.side_effect = ConnectionError('timeout')
392
+
393
+ with pytest.raises(ConnectionError):
394
+ sync_contact_to_crm.apply(args=[1], throw=True)
395
+
396
+ assert mock_sync.call_count == 1 # First attempt only when eager
397
+ ```
398
+
399
+ ## Monitoring
400
+
401
+ ```bash
402
+ # Inspect active workers and queues
403
+ celery -A config inspect active
404
+ celery -A config inspect stats
405
+ celery -A config inspect reserved
406
+
407
+ # Check queue lengths (Redis)
408
+ redis-cli llen celery
409
+
410
+ # Flower: web-based real-time monitor
411
+ pip install flower
412
+ celery -A config flower --port=5555
413
+ ```
414
+
415
+ ## Anti-Patterns
416
+
417
+ ```python
418
+ # BAD: Passing model instances — they may be stale by execution time
419
+ send_welcome_email.delay(user) # Never pass ORM objects
420
+ send_welcome_email.delay(user.pk) # Always pass PKs
421
+
422
+ # BAD: Calling tasks synchronously in production views
423
+ result = generate_report.apply() # Blocks the request thread
424
+
425
+ # BAD: Non-idempotent task without guards
426
+ @shared_task
427
+ def charge_and_fulfill(order_id):
428
+ order.charge() # May charge twice if task retries!
429
+ order.fulfill()
430
+
431
+ # GOOD: Idempotent with status guard
432
+ @shared_task
433
+ def charge_and_fulfill(order_id):
434
+ order = Order.objects.select_for_update().get(pk=order_id)
435
+ if order.status != Order.Status.PENDING:
436
+ return # Already processed
437
+ order.charge()
438
+ order.fulfill()
439
+ ```
440
+
441
+ ## Production Checklist
442
+
443
+ | Check | Setting |
444
+ |-------|---------|
445
+ | Worker restarts on crash | `supervisord` or `systemd` unit |
446
+ | `CELERY_TASK_ACKS_LATE = True` | Re-queue tasks on worker crash |
447
+ | `CELERY_WORKER_PREFETCH_MULTIPLIER = 1` | Fair distribution of long tasks |
448
+ | Separate queues per priority | `-Q default,high_priority,low_priority` |
449
+ | `CELERY_TASK_SOFT_TIME_LIMIT` set | Graceful timeout before hard kill |
450
+ | Sentry integration | Capture all `task_failure` signals |
451
+ | Flower or other monitor | Visibility into queue depths |
452
+ | Beat runs on single node only | Prevents duplicate scheduled task execution |
453
+
454
+ ## Related Skills
455
+
456
+ - `django-patterns` — ORM, service layer, and project structure
457
+ - `django-tdd` — Testing Django models, views, and services
458
+ - `python-testing` — pytest configuration and fixtures