@ngxtm/devkit 3.0.3 → 3.2.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 (827) hide show
  1. package/package.json +2 -1
  2. package/skills/SPDD/1-research.md +22 -0
  3. package/skills/SPDD/2-spec.md +20 -0
  4. package/skills/SPDD/3-implementation.md +20 -0
  5. package/skills/accessibility-compliance-accessibility-audit/SKILL.md +42 -0
  6. package/skills/accessibility-compliance-accessibility-audit/resources/implementation-playbook.md +502 -0
  7. package/skills/active-directory-attacks/references/advanced-attacks.md +382 -382
  8. package/skills/agent-framework-azure-hosted-agents/SKILL.md +0 -3
  9. package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
  10. package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
  11. package/skills/ai-engineer/SKILL.md +171 -0
  12. package/skills/airflow-dag-patterns/SKILL.md +41 -0
  13. package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
  14. package/skills/angular-migration/SKILL.md +428 -0
  15. package/skills/anti-reversing-techniques/SKILL.md +42 -0
  16. package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
  17. package/skills/api-design-principles/SKILL.md +37 -0
  18. package/skills/api-design-principles/assets/api-design-checklist.md +155 -0
  19. package/skills/api-design-principles/assets/rest-api-template.py +182 -0
  20. package/skills/api-design-principles/references/graphql-schema-design.md +583 -0
  21. package/skills/api-design-principles/references/rest-best-practices.md +408 -0
  22. package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
  23. package/skills/api-documenter/SKILL.md +184 -0
  24. package/skills/api-testing-observability-api-mock/SKILL.md +46 -0
  25. package/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
  26. package/skills/application-performance-performance-optimization/SKILL.md +154 -0
  27. package/skills/architect-review/SKILL.md +174 -0
  28. package/skills/architecture-decision-records/SKILL.md +441 -0
  29. package/skills/architecture-patterns/SKILL.md +37 -0
  30. package/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
  31. package/skills/arm-cortex-expert/SKILL.md +306 -0
  32. package/skills/artifacts-builder/scripts/bundle-artifact.sh +0 -0
  33. package/skills/artifacts-builder/scripts/init-artifact.sh +0 -0
  34. package/skills/async-python-patterns/SKILL.md +39 -0
  35. package/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
  36. package/skills/attack-tree-construction/SKILL.md +38 -0
  37. package/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
  38. package/skills/auth-implementation-patterns/SKILL.md +39 -0
  39. package/skills/auth-implementation-patterns/resources/implementation-playbook.md +633 -0
  40. package/skills/automate-whatsapp/SKILL.md +257 -0
  41. package/skills/aws-agentic-ai/services/gateway/deploy-template.sh +0 -0
  42. package/skills/aws-agentic-ai/services/gateway/validate-deployment.sh +0 -0
  43. package/skills/aws-cdk-development/scripts/validate-stack.sh +0 -0
  44. package/skills/aws-penetration-testing/references/advanced-aws-pentesting.md +469 -469
  45. package/skills/aws-skills/SKILL.md +22 -0
  46. package/skills/azd-deployment/SKILL.md +0 -2
  47. package/skills/backend-architect/SKILL.md +333 -0
  48. package/skills/backend-development-feature-development/SKILL.md +180 -0
  49. package/skills/backend-security-coder/SKILL.md +156 -0
  50. package/skills/backtesting-frameworks/SKILL.md +39 -0
  51. package/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
  52. package/skills/bash-defensive-patterns/SKILL.md +43 -0
  53. package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
  54. package/skills/bash-pro/SKILL.md +310 -0
  55. package/skills/bats-testing-patterns/SKILL.md +34 -0
  56. package/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
  57. package/skills/bazel-build-optimization/SKILL.md +397 -0
  58. package/skills/beautiful-prose/SKILL.md +22 -0
  59. package/skills/billing-automation/SKILL.md +42 -0
  60. package/skills/billing-automation/resources/implementation-playbook.md +544 -0
  61. package/skills/binary-analysis-patterns/SKILL.md +450 -0
  62. package/skills/blockchain-developer/SKILL.md +208 -0
  63. package/skills/business-analyst/SKILL.md +182 -0
  64. package/skills/c-pro/SKILL.md +56 -0
  65. package/skills/c4-architecture-c4-architecture/SKILL.md +389 -0
  66. package/skills/c4-code/SKILL.md +244 -0
  67. package/skills/c4-component/SKILL.md +153 -0
  68. package/skills/c4-container/SKILL.md +171 -0
  69. package/skills/c4-context/SKILL.md +150 -0
  70. package/skills/cc-skill-continuous-learning/evaluate-session.sh +0 -0
  71. package/skills/cc-skill-strategic-compact/suggest-compact.sh +0 -0
  72. package/skills/changelog-automation/SKILL.md +38 -0
  73. package/skills/changelog-automation/resources/implementation-playbook.md +538 -0
  74. package/skills/cicd-automation-workflow-automate/SKILL.md +51 -0
  75. package/skills/cicd-automation-workflow-automate/resources/implementation-playbook.md +1333 -0
  76. package/skills/clarity-gate/SKILL.md +22 -0
  77. package/skills/claude-ally-health/SKILL.md +22 -0
  78. package/skills/claude-scientific-skills/SKILL.md +22 -0
  79. package/skills/claude-speed-reader/SKILL.md +22 -0
  80. package/skills/claude-win11-speckit-update-skill/SKILL.md +22 -0
  81. package/skills/cloud-architect/SKILL.md +131 -102
  82. package/skills/cloud-penetration-testing/references/advanced-cloud-scripts.md +318 -318
  83. package/skills/code-documentation-code-explain/SKILL.md +46 -0
  84. package/skills/code-documentation-code-explain/resources/implementation-playbook.md +802 -0
  85. package/skills/code-documentation-doc-generate/SKILL.md +48 -0
  86. package/skills/code-documentation-doc-generate/resources/implementation-playbook.md +640 -0
  87. package/skills/code-refactoring-context-restore/SKILL.md +179 -0
  88. package/skills/code-refactoring-refactor-clean/SKILL.md +51 -0
  89. package/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
  90. package/skills/code-refactoring-tech-debt/SKILL.md +386 -0
  91. package/skills/code-review-ai-ai-review/SKILL.md +450 -0
  92. package/skills/code-review-excellence/SKILL.md +40 -0
  93. package/skills/code-review-excellence/resources/implementation-playbook.md +515 -0
  94. package/skills/code-reviewer/SKILL.md +174 -205
  95. package/skills/codebase-cleanup-deps-audit/SKILL.md +51 -0
  96. package/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
  97. package/skills/codebase-cleanup-refactor-clean/SKILL.md +51 -0
  98. package/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
  99. package/skills/codebase-cleanup-tech-debt/SKILL.md +386 -0
  100. package/skills/commit/SKILL.md +171 -0
  101. package/skills/competitive-landscape/SKILL.md +34 -0
  102. package/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
  103. package/skills/comprehensive-review-full-review/SKILL.md +146 -0
  104. package/skills/comprehensive-review-pr-enhance/SKILL.md +46 -0
  105. package/skills/comprehensive-review-pr-enhance/resources/implementation-playbook.md +691 -0
  106. package/skills/conductor-implement/SKILL.md +388 -0
  107. package/skills/conductor-manage/SKILL.md +39 -0
  108. package/skills/conductor-manage/resources/implementation-playbook.md +1120 -0
  109. package/skills/conductor-new-track/SKILL.md +433 -0
  110. package/skills/conductor-revert/SKILL.md +372 -0
  111. package/skills/conductor-setup/SKILL.md +426 -0
  112. package/skills/conductor-status/SKILL.md +338 -0
  113. package/skills/conductor-validator/SKILL.md +62 -0
  114. package/skills/content-marketer/SKILL.md +170 -0
  115. package/skills/context-compression/SKILL.md +266 -0
  116. package/skills/context-degradation/SKILL.md +238 -0
  117. package/skills/context-driven-development/SKILL.md +400 -0
  118. package/skills/context-fundamentals/SKILL.md +192 -0
  119. package/skills/context-management-context-restore/SKILL.md +179 -0
  120. package/skills/context-management-context-save/SKILL.md +177 -0
  121. package/skills/context-manager/SKILL.md +185 -0
  122. package/skills/context-optimization/SKILL.md +186 -0
  123. package/skills/cost-optimization/SKILL.md +286 -0
  124. package/skills/cpp-pro/SKILL.md +42 -80
  125. package/skills/cqrs-implementation/SKILL.md +35 -0
  126. package/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
  127. package/skills/create-pr/SKILL.md +192 -0
  128. package/skills/csharp-pro/SKILL.md +59 -0
  129. package/skills/culture-index/SKILL.md +43 -0
  130. package/skills/customer-support/SKILL.md +170 -0
  131. package/skills/daily-news-report/SKILL.md +178 -179
  132. package/skills/data-engineer/SKILL.md +224 -0
  133. package/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
  134. package/skills/data-engineering-data-pipeline/SKILL.md +201 -0
  135. package/skills/data-quality-frameworks/SKILL.md +40 -0
  136. package/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
  137. package/skills/data-scientist/SKILL.md +199 -0
  138. package/skills/data-storytelling/SKILL.md +465 -0
  139. package/skills/database-admin/SKILL.md +165 -0
  140. package/skills/database-architect/SKILL.md +268 -0
  141. package/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
  142. package/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
  143. package/skills/database-migration/SKILL.md +436 -0
  144. package/skills/database-migrations-migration-observability/SKILL.md +420 -0
  145. package/skills/database-migrations-sql-migrations/SKILL.md +53 -0
  146. package/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
  147. package/skills/database-optimizer/SKILL.md +163 -91
  148. package/skills/dbt-transformation-patterns/SKILL.md +34 -0
  149. package/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
  150. package/skills/debugger/SKILL.md +49 -0
  151. package/skills/debugging-strategies/SKILL.md +34 -0
  152. package/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
  153. package/skills/debugging-toolkit-smart-debug/SKILL.md +197 -0
  154. package/skills/deep-research/SKILL.md +114 -0
  155. package/skills/defi-protocol-templates/SKILL.md +466 -0
  156. package/skills/dependency-management-deps-audit/SKILL.md +44 -0
  157. package/skills/dependency-management-deps-audit/resources/implementation-playbook.md +766 -0
  158. package/skills/dependency-upgrade/SKILL.md +421 -0
  159. package/skills/deployment-engineer/SKILL.md +170 -0
  160. package/skills/deployment-pipeline-design/SKILL.md +371 -0
  161. package/skills/deployment-validation-config-validate/SKILL.md +496 -0
  162. package/skills/design-md/SKILL.md +178 -0
  163. package/skills/devops-troubleshooter/SKILL.md +161 -0
  164. package/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
  165. package/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
  166. package/skills/distributed-tracing/SKILL.md +450 -0
  167. package/skills/django-pro/SKILL.md +180 -0
  168. package/skills/docs-architect/SKILL.md +98 -0
  169. package/skills/document-skills/docx/ooxml/scripts/pack.py +0 -0
  170. package/skills/document-skills/docx/ooxml/scripts/unpack.py +0 -0
  171. package/skills/document-skills/docx/ooxml/scripts/validate.py +0 -0
  172. package/skills/document-skills/docx/scripts/__init__.py +0 -0
  173. package/skills/document-skills/docx/scripts/document.py +0 -0
  174. package/skills/document-skills/docx/scripts/utilities.py +0 -0
  175. package/skills/document-skills/pptx/ooxml/scripts/pack.py +0 -0
  176. package/skills/document-skills/pptx/ooxml/scripts/unpack.py +0 -0
  177. package/skills/document-skills/pptx/ooxml/scripts/validate.py +0 -0
  178. package/skills/document-skills/pptx/scripts/html2pptx.js +0 -0
  179. package/skills/document-skills/pptx/scripts/inventory.py +0 -0
  180. package/skills/document-skills/pptx/scripts/rearrange.py +0 -0
  181. package/skills/document-skills/pptx/scripts/replace.py +0 -0
  182. package/skills/document-skills/pptx/scripts/thumbnail.py +0 -0
  183. package/skills/documentation-generation-doc-generate/SKILL.md +48 -0
  184. package/skills/documentation-generation-doc-generate/resources/implementation-playbook.md +640 -0
  185. package/skills/docx/LICENSE.txt +30 -0
  186. package/skills/docx/SKILL.md +172 -69
  187. package/skills/docx/docx-js.md +350 -0
  188. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  189. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  190. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  191. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  192. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  193. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  194. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  195. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  196. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  197. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  198. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  199. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  200. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  201. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  202. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  203. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  204. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  205. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  206. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  207. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  208. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  209. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  210. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  211. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  212. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  213. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  214. package/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  215. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  216. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  217. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  218. package/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  219. package/skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
  220. package/skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  221. package/skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  222. package/skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  223. package/skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  224. package/skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  225. package/skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  226. package/skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  227. package/skills/docx/ooxml/scripts/pack.py +159 -0
  228. package/skills/docx/ooxml/scripts/unpack.py +29 -0
  229. package/skills/docx/ooxml/scripts/validate.py +69 -0
  230. package/skills/docx/ooxml/scripts/validation/__init__.py +15 -0
  231. package/skills/docx/ooxml/scripts/validation/base.py +951 -0
  232. package/skills/docx/ooxml/scripts/validation/docx.py +274 -0
  233. package/skills/docx/ooxml/scripts/validation/pptx.py +315 -0
  234. package/skills/docx/ooxml/scripts/validation/redlining.py +279 -0
  235. package/skills/docx/ooxml.md +610 -0
  236. package/skills/docx/scripts/__init__.py +1 -0
  237. package/skills/docx/scripts/document.py +1276 -0
  238. package/skills/docx/scripts/templates/comments.xml +3 -0
  239. package/skills/docx/scripts/templates/commentsExtended.xml +3 -0
  240. package/skills/docx/scripts/templates/commentsExtensible.xml +3 -0
  241. package/skills/docx/scripts/templates/commentsIds.xml +3 -0
  242. package/skills/docx/scripts/templates/people.xml +3 -0
  243. package/skills/docx/scripts/utilities.py +374 -0
  244. package/skills/docx-official/ooxml/scripts/pack.py +0 -0
  245. package/skills/docx-official/ooxml/scripts/unpack.py +0 -0
  246. package/skills/docx-official/ooxml/scripts/validate.py +0 -0
  247. package/skills/docx-official/scripts/__init__.py +0 -0
  248. package/skills/docx-official/scripts/document.py +0 -0
  249. package/skills/docx-official/scripts/utilities.py +0 -0
  250. package/skills/dotnet-architect/SKILL.md +197 -0
  251. package/skills/dotnet-backend-patterns/SKILL.md +37 -0
  252. package/skills/dotnet-backend-patterns/assets/repository-template.cs +523 -0
  253. package/skills/dotnet-backend-patterns/assets/service-template.cs +336 -0
  254. package/skills/dotnet-backend-patterns/references/dapper-patterns.md +544 -0
  255. package/skills/dotnet-backend-patterns/references/ef-core-best-practices.md +355 -0
  256. package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
  257. package/skills/dx-optimizer/SKILL.md +83 -0
  258. package/skills/e2e-testing-patterns/SKILL.md +41 -0
  259. package/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
  260. package/skills/elixir-pro/SKILL.md +59 -0
  261. package/skills/embedding-strategies/SKILL.md +491 -0
  262. package/skills/employment-contract-templates/SKILL.md +39 -0
  263. package/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
  264. package/skills/error-debugging-error-analysis/SKILL.md +47 -0
  265. package/skills/error-debugging-error-analysis/resources/implementation-playbook.md +1143 -0
  266. package/skills/error-debugging-error-trace/SKILL.md +43 -0
  267. package/skills/error-debugging-error-trace/resources/implementation-playbook.md +1361 -0
  268. package/skills/error-debugging-multi-agent-review/SKILL.md +216 -0
  269. package/skills/error-detective/SKILL.md +53 -0
  270. package/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
  271. package/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
  272. package/skills/error-diagnostics-error-trace/SKILL.md +48 -0
  273. package/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
  274. package/skills/error-diagnostics-smart-debug/SKILL.md +197 -0
  275. package/skills/error-handling-patterns/SKILL.md +35 -0
  276. package/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
  277. package/skills/evaluation/SKILL.md +238 -0
  278. package/skills/event-sourcing-architect/SKILL.md +58 -0
  279. package/skills/event-store-design/SKILL.md +449 -0
  280. package/skills/expo-deployment/SKILL.md +62 -12
  281. package/skills/fal-audio/SKILL.md +22 -0
  282. package/skills/fal-generate/SKILL.md +22 -0
  283. package/skills/fal-image-edit/SKILL.md +22 -0
  284. package/skills/fal-platform/SKILL.md +22 -0
  285. package/skills/fal-upscale/SKILL.md +22 -0
  286. package/skills/fal-workflow/SKILL.md +22 -0
  287. package/skills/fastapi-pro/SKILL.md +192 -0
  288. package/skills/fastapi-templates/SKILL.md +32 -0
  289. package/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
  290. package/skills/ffuf-claude-skill/SKILL.md +22 -0
  291. package/skills/find-bugs/SKILL.md +86 -0
  292. package/skills/firmware-analyst/SKILL.md +320 -0
  293. package/skills/fix-review/SKILL.md +53 -0
  294. package/skills/flutter-expert/SKILL.md +196 -84
  295. package/skills/foundry-iq-agent/SKILL.md +15 -0
  296. package/skills/foundry-iq-python/SKILL.md +0 -3
  297. package/skills/fp-ts-errors/SKILL.md +856 -0
  298. package/skills/fp-ts-pragmatic/SKILL.md +598 -0
  299. package/skills/fp-ts-react/SKILL.md +796 -0
  300. package/skills/framework-migration-code-migrate/SKILL.md +48 -0
  301. package/skills/framework-migration-code-migrate/resources/implementation-playbook.md +1052 -0
  302. package/skills/framework-migration-deps-upgrade/SKILL.md +48 -0
  303. package/skills/framework-migration-deps-upgrade/resources/implementation-playbook.md +755 -0
  304. package/skills/framework-migration-legacy-modernize/SKILL.md +132 -0
  305. package/skills/frontend-developer/SKILL.md +171 -0
  306. package/skills/frontend-mobile-development-component-scaffold/SKILL.md +403 -0
  307. package/skills/frontend-mobile-security-xss-scan/SKILL.md +322 -0
  308. package/skills/frontend-security-coder/SKILL.md +170 -0
  309. package/skills/frontend-slides/SKILL.md +770 -0
  310. package/skills/full-stack-orchestration-full-stack-feature/SKILL.md +135 -0
  311. package/skills/gdpr-data-handling/SKILL.md +33 -0
  312. package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
  313. package/skills/git-advanced-workflows/SKILL.md +412 -0
  314. package/skills/git-pr-workflows-git-workflow/SKILL.md +140 -0
  315. package/skills/git-pr-workflows-onboard/SKILL.md +416 -0
  316. package/skills/git-pr-workflows-pr-enhance/SKILL.md +48 -0
  317. package/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
  318. package/skills/github-actions-templates/SKILL.md +345 -0
  319. package/skills/gitlab-ci-patterns/SKILL.md +283 -0
  320. package/skills/gitops-workflow/SKILL.md +303 -0
  321. package/skills/gitops-workflow/references/argocd-setup.md +134 -0
  322. package/skills/gitops-workflow/references/sync-policies.md +131 -0
  323. package/skills/go-concurrency-patterns/SKILL.md +33 -0
  324. package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
  325. package/skills/godot-gdscript-patterns/SKILL.md +33 -0
  326. package/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
  327. package/skills/golang-pro/SKILL.md +176 -91
  328. package/skills/grafana-dashboards/SKILL.md +381 -0
  329. package/skills/graphql-architect/SKILL.md +168 -83
  330. package/skills/haskell-pro/SKILL.md +56 -0
  331. package/skills/helm-chart-scaffolding/SKILL.md +34 -0
  332. package/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
  333. package/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
  334. package/skills/helm-chart-scaffolding/references/chart-structure.md +500 -0
  335. package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
  336. package/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
  337. package/skills/hr-pro/SKILL.md +126 -0
  338. package/skills/hugging-face-cli/SKILL.md +198 -0
  339. package/skills/hugging-face-jobs/SKILL.md +1038 -0
  340. package/skills/hybrid-cloud-architect/SKILL.md +168 -0
  341. package/skills/hybrid-cloud-networking/SKILL.md +238 -0
  342. package/skills/hybrid-search-implementation/SKILL.md +32 -0
  343. package/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
  344. package/skills/imagen/SKILL.md +77 -0
  345. package/skills/incident-responder/SKILL.md +213 -0
  346. package/skills/incident-response-incident-response/SKILL.md +168 -0
  347. package/skills/incident-response-smart-fix/SKILL.md +29 -0
  348. package/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
  349. package/skills/incident-runbook-templates/SKILL.md +395 -0
  350. package/skills/infinite-gratitude/SKILL.md +26 -0
  351. package/skills/ios-developer/SKILL.md +219 -0
  352. package/skills/istio-traffic-management/SKILL.md +337 -0
  353. package/skills/iterate-pr/SKILL.md +150 -0
  354. package/skills/java-pro/SKILL.md +177 -0
  355. package/skills/javascript-pro/SKILL.md +41 -79
  356. package/skills/javascript-testing-patterns/SKILL.md +35 -0
  357. package/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
  358. package/skills/javascript-typescript-typescript-scaffold/SKILL.md +361 -0
  359. package/skills/julia-pro/SKILL.md +209 -0
  360. package/skills/k8s-manifest-generator/SKILL.md +35 -0
  361. package/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
  362. package/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
  363. package/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
  364. package/skills/k8s-manifest-generator/references/deployment-spec.md +753 -0
  365. package/skills/k8s-manifest-generator/references/service-spec.md +724 -0
  366. package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
  367. package/skills/k8s-security-policies/SKILL.md +346 -0
  368. package/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
  369. package/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
  370. package/skills/kpi-dashboard-design/SKILL.md +440 -0
  371. package/skills/kubernetes-architect/SKILL.md +170 -0
  372. package/skills/langchain-architecture/SKILL.md +350 -0
  373. package/skills/legacy-modernizer/SKILL.md +39 -79
  374. package/skills/legal-advisor/SKILL.md +70 -0
  375. package/skills/linear-claude-skill/SKILL.md +543 -0
  376. package/skills/linkerd-patterns/SKILL.md +321 -0
  377. package/skills/llm-application-dev-ai-assistant/SKILL.md +35 -0
  378. package/skills/llm-application-dev-ai-assistant/resources/implementation-playbook.md +1236 -0
  379. package/skills/llm-application-dev-langchain-agent/SKILL.md +246 -0
  380. package/skills/llm-application-dev-prompt-optimize/SKILL.md +37 -0
  381. package/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
  382. package/skills/llm-evaluation/SKILL.md +483 -0
  383. package/skills/loki-mode/autonomy/run.sh +0 -0
  384. package/skills/loki-mode/benchmarks/prepare-submission.sh +0 -0
  385. package/skills/loki-mode/benchmarks/run-benchmarks.sh +0 -0
  386. package/skills/loki-mode/demo/record-demo.sh +0 -0
  387. package/skills/loki-mode/demo/record-full-demo.sh +0 -0
  388. package/skills/loki-mode/demo/run-demo-auto.sh +0 -0
  389. package/skills/loki-mode/demo/run-demo.sh +0 -0
  390. package/skills/loki-mode/scripts/export-to-vibe-kanban.sh +0 -0
  391. package/skills/loki-mode/scripts/loki-wrapper.sh +0 -0
  392. package/skills/loki-mode/tests/run-all-tests.sh +0 -0
  393. package/skills/loki-mode/tests/test-agent-timeout.sh +0 -0
  394. package/skills/loki-mode/tests/test-bootstrap.sh +0 -0
  395. package/skills/loki-mode/tests/test-circuit-breaker.sh +0 -0
  396. package/skills/loki-mode/tests/test-state-recovery.sh +0 -0
  397. package/skills/loki-mode/tests/test-task-queue.sh +0 -0
  398. package/skills/loki-mode/tests/test-wrapper.sh +0 -0
  399. package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
  400. package/skills/makepad-skills/SKILL.md +22 -0
  401. package/skills/malware-analyst/SKILL.md +247 -0
  402. package/skills/market-sizing-analysis/SKILL.md +425 -0
  403. package/skills/market-sizing-analysis/examples/saas-market-sizing.md +349 -0
  404. package/skills/market-sizing-analysis/references/data-sources.md +360 -0
  405. package/skills/memory-forensics/SKILL.md +491 -0
  406. package/skills/memory-safety-patterns/SKILL.md +33 -0
  407. package/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
  408. package/skills/memory-systems/SKILL.md +228 -0
  409. package/skills/mermaid-expert/SKILL.md +59 -0
  410. package/skills/microservices-patterns/SKILL.md +35 -0
  411. package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
  412. package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
  413. package/skills/ml-engineer/SKILL.md +168 -0
  414. package/skills/ml-pipeline-workflow/SKILL.md +257 -0
  415. package/skills/mlops-engineer/SKILL.md +219 -0
  416. package/skills/mobile-developer/SKILL.md +205 -0
  417. package/skills/mobile-security-coder/SKILL.md +184 -0
  418. package/skills/modern-javascript-patterns/SKILL.md +35 -0
  419. package/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
  420. package/skills/monorepo-architect/SKILL.md +61 -0
  421. package/skills/monorepo-management/SKILL.md +35 -0
  422. package/skills/monorepo-management/resources/implementation-playbook.md +621 -0
  423. package/skills/mtls-configuration/SKILL.md +359 -0
  424. package/skills/multi-agent-patterns/SKILL.md +262 -0
  425. package/skills/multi-cloud-architecture/SKILL.md +189 -0
  426. package/skills/multi-platform-apps-multi-platform/SKILL.md +203 -0
  427. package/skills/n8n-code-python/SKILL.md +750 -0
  428. package/skills/n8n-mcp-tools-expert/SKILL.md +654 -0
  429. package/skills/n8n-node-configuration/SKILL.md +796 -0
  430. package/skills/nanobanana-ppt-skills/SKILL.md +22 -0
  431. package/skills/network-engineer/SKILL.md +169 -0
  432. package/skills/nextjs-app-router-patterns/SKILL.md +33 -0
  433. package/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
  434. package/skills/nft-standards/SKILL.md +395 -0
  435. package/skills/nodejs-backend-patterns/SKILL.md +35 -0
  436. package/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
  437. package/skills/notebooklm/AUTHENTICATION.md +0 -0
  438. package/skills/notebooklm/CHANGELOG.md +0 -0
  439. package/skills/notebooklm/LICENSE +0 -0
  440. package/skills/notebooklm/README.md +0 -0
  441. package/skills/notebooklm/SKILL.md +0 -0
  442. package/skills/notebooklm/images/example_notebookchat.png +0 -0
  443. package/skills/notebooklm/references/api_reference.md +0 -0
  444. package/skills/notebooklm/references/troubleshooting.md +0 -0
  445. package/skills/notebooklm/references/usage_patterns.md +0 -0
  446. package/skills/notebooklm/requirements.txt +0 -0
  447. package/skills/notebooklm/scripts/__init__.py +0 -0
  448. package/skills/notebooklm/scripts/ask_question.py +0 -0
  449. package/skills/notebooklm/scripts/auth_manager.py +0 -0
  450. package/skills/notebooklm/scripts/browser_session.py +0 -0
  451. package/skills/notebooklm/scripts/browser_utils.py +0 -0
  452. package/skills/notebooklm/scripts/cleanup_manager.py +0 -0
  453. package/skills/notebooklm/scripts/config.py +0 -0
  454. package/skills/notebooklm/scripts/notebook_manager.py +0 -0
  455. package/skills/notebooklm/scripts/run.py +0 -0
  456. package/skills/notebooklm/scripts/setup_environment.py +0 -0
  457. package/skills/notebooklm-skill/AUTHENTICATION.md +0 -0
  458. package/skills/notebooklm-skill/SKILL.md +0 -0
  459. package/skills/notebooklm-skill/references/api_reference.md +0 -0
  460. package/skills/notebooklm-skill/references/troubleshooting.md +0 -0
  461. package/skills/notebooklm-skill/references/usage_patterns.md +0 -0
  462. package/skills/notebooklm-skill/scripts/__init__.py +0 -0
  463. package/skills/notebooklm-skill/scripts/ask_question.py +0 -0
  464. package/skills/notebooklm-skill/scripts/auth_manager.py +0 -0
  465. package/skills/notebooklm-skill/scripts/browser_session.py +0 -0
  466. package/skills/notebooklm-skill/scripts/browser_utils.py +0 -0
  467. package/skills/notebooklm-skill/scripts/cleanup_manager.py +0 -0
  468. package/skills/notebooklm-skill/scripts/config.py +0 -0
  469. package/skills/notebooklm-skill/scripts/notebook_manager.py +0 -0
  470. package/skills/notebooklm-skill/scripts/run.py +0 -0
  471. package/skills/notebooklm-skill/scripts/setup_environment.py +0 -0
  472. package/skills/nx-workspace-patterns/SKILL.md +464 -0
  473. package/skills/observability-engineer/SKILL.md +237 -0
  474. package/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
  475. package/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
  476. package/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
  477. package/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
  478. package/skills/observe-whatsapp/SKILL.md +109 -0
  479. package/skills/on-call-handoff-patterns/SKILL.md +453 -0
  480. package/skills/openapi-spec-generation/SKILL.md +33 -0
  481. package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
  482. package/skills/payment-integration/SKILL.md +69 -110
  483. package/skills/paypal-integration/SKILL.md +479 -0
  484. package/skills/pci-compliance/SKILL.md +478 -0
  485. package/skills/pdf/LICENSE.txt +30 -0
  486. package/skills/pdf/SKILL.md +196 -6
  487. package/skills/pdf/forms.md +205 -0
  488. package/skills/pdf/reference.md +612 -0
  489. package/skills/pdf/scripts/check_bounding_boxes.py +70 -0
  490. package/skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
  491. package/skills/pdf/scripts/check_fillable_fields.py +12 -0
  492. package/skills/pdf/scripts/convert_pdf_to_images.py +35 -0
  493. package/skills/pdf/scripts/create_validation_image.py +41 -0
  494. package/skills/pdf/scripts/extract_form_field_info.py +152 -0
  495. package/skills/pdf/scripts/fill_fillable_fields.py +114 -0
  496. package/skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
  497. package/skills/performance-engineer/SKILL.md +180 -0
  498. package/skills/performance-testing-review-ai-review/SKILL.md +450 -0
  499. package/skills/performance-testing-review-multi-agent-review/SKILL.md +216 -0
  500. package/skills/php-pro/SKILL.md +46 -78
  501. package/skills/playwright-skill/run.js +0 -0
  502. package/skills/podcast-generation/SKILL.md +0 -2
  503. package/skills/posix-shell-pro/SKILL.md +304 -0
  504. package/skills/postgresql/SKILL.md +230 -0
  505. package/skills/postmortem-writing/SKILL.md +386 -0
  506. package/skills/pptx/LICENSE.txt +30 -0
  507. package/skills/pptx/SKILL.md +456 -86
  508. package/skills/pptx/html2pptx.md +625 -0
  509. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  510. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  511. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  512. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  513. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  514. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  515. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  516. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  517. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  518. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  519. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  520. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  521. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  522. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  523. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  524. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  525. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  526. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  527. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  528. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  529. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  530. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  531. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  532. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  533. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  534. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  535. package/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  536. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  537. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  538. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  539. package/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  540. package/skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
  541. package/skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  542. package/skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  543. package/skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  544. package/skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  545. package/skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  546. package/skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  547. package/skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  548. package/skills/pptx/ooxml/scripts/pack.py +159 -0
  549. package/skills/pptx/ooxml/scripts/unpack.py +29 -0
  550. package/skills/pptx/ooxml/scripts/validate.py +69 -0
  551. package/skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
  552. package/skills/pptx/ooxml/scripts/validation/base.py +951 -0
  553. package/skills/pptx/ooxml/scripts/validation/docx.py +274 -0
  554. package/skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
  555. package/skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
  556. package/skills/pptx/ooxml.md +427 -0
  557. package/skills/pptx/scripts/html2pptx.js +979 -0
  558. package/skills/pptx/scripts/inventory.py +1020 -0
  559. package/skills/pptx/scripts/rearrange.py +231 -0
  560. package/skills/pptx/scripts/replace.py +385 -0
  561. package/skills/pptx/scripts/thumbnail.py +450 -0
  562. package/skills/pptx-official/ooxml/scripts/pack.py +0 -0
  563. package/skills/pptx-official/ooxml/scripts/unpack.py +0 -0
  564. package/skills/pptx-official/ooxml/scripts/validate.py +0 -0
  565. package/skills/pptx-official/scripts/html2pptx.js +0 -0
  566. package/skills/pptx-official/scripts/inventory.py +0 -0
  567. package/skills/pptx-official/scripts/rearrange.py +0 -0
  568. package/skills/pptx-official/scripts/replace.py +0 -0
  569. package/skills/pptx-official/scripts/thumbnail.py +0 -0
  570. package/skills/projection-patterns/SKILL.md +33 -0
  571. package/skills/projection-patterns/resources/implementation-playbook.md +501 -0
  572. package/skills/prometheus-configuration/SKILL.md +404 -0
  573. package/skills/prompt-engineer/SKILL.md +243 -64
  574. package/skills/prompt-engineering-patterns/SKILL.md +213 -0
  575. package/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
  576. package/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
  577. package/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
  578. package/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
  579. package/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
  580. package/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
  581. package/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
  582. package/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
  583. package/skills/protocol-reverse-engineering/SKILL.md +29 -0
  584. package/skills/protocol-reverse-engineering/resources/implementation-playbook.md +509 -0
  585. package/skills/pypict-skill/SKILL.md +22 -0
  586. package/skills/python-development-python-scaffold/SKILL.md +331 -0
  587. package/skills/python-packaging/SKILL.md +36 -0
  588. package/skills/python-packaging/resources/implementation-playbook.md +869 -0
  589. package/skills/python-performance-optimization/SKILL.md +36 -0
  590. package/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
  591. package/skills/python-pro/SKILL.md +155 -89
  592. package/skills/python-testing-patterns/SKILL.md +37 -0
  593. package/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
  594. package/skills/quant-analyst/SKILL.md +53 -0
  595. package/skills/radix-ui-design-system/SKILL.md +847 -0
  596. package/skills/radix-ui-design-system/examples/README.md +63 -0
  597. package/skills/radix-ui-design-system/examples/dialog-example.tsx +128 -0
  598. package/skills/radix-ui-design-system/examples/dropdown-example.tsx +162 -0
  599. package/skills/radix-ui-design-system/templates/component-template.tsx +148 -0
  600. package/skills/rag-implementation/SKILL.md +395 -37
  601. package/skills/react-modernization/SKILL.md +34 -0
  602. package/skills/react-modernization/resources/implementation-playbook.md +512 -0
  603. package/skills/react-native-architecture/SKILL.md +33 -0
  604. package/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
  605. package/skills/react-state-management/SKILL.md +441 -0
  606. package/skills/readme/SKILL.md +775 -0
  607. package/skills/reference-builder/SKILL.md +188 -0
  608. package/skills/reverse-engineer/SKILL.md +173 -0
  609. package/skills/risk-manager/SKILL.md +61 -0
  610. package/skills/risk-metrics-calculation/SKILL.md +33 -0
  611. package/skills/risk-metrics-calculation/resources/implementation-playbook.md +554 -0
  612. package/skills/ruby-pro/SKILL.md +56 -0
  613. package/skills/rust-async-patterns/SKILL.md +33 -0
  614. package/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
  615. package/skills/rust-pro/SKILL.md +178 -0
  616. package/skills/saga-orchestration/SKILL.md +496 -0
  617. package/skills/sales-automator/SKILL.md +55 -0
  618. package/skills/sast-configuration/SKILL.md +212 -0
  619. package/skills/scala-pro/SKILL.md +82 -0
  620. package/skills/screen-reader-testing/SKILL.md +33 -0
  621. package/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
  622. package/skills/screenshots/SKILL.md +401 -0
  623. package/skills/search-specialist/SKILL.md +80 -0
  624. package/skills/secrets-management/SKILL.md +364 -0
  625. package/skills/security-auditor/SKILL.md +169 -0
  626. package/skills/security-bluebook-builder/SKILL.md +22 -0
  627. package/skills/security-compliance-compliance-check/SKILL.md +55 -0
  628. package/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
  629. package/skills/security-requirement-extraction/SKILL.md +33 -0
  630. package/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
  631. package/skills/security-scanning-security-dependencies/SKILL.md +43 -0
  632. package/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
  633. package/skills/security-scanning-security-hardening/SKILL.md +147 -0
  634. package/skills/security-scanning-security-sast/SKILL.md +495 -0
  635. package/skills/senior-architect/scripts/architecture_diagram_generator.py +0 -0
  636. package/skills/senior-architect/scripts/dependency_analyzer.py +0 -0
  637. package/skills/senior-architect/scripts/project_architect.py +0 -0
  638. package/skills/senior-backend/scripts/api_load_tester.py +0 -0
  639. package/skills/senior-backend/scripts/api_scaffolder.py +0 -0
  640. package/skills/senior-backend/scripts/database_migration_tool.py +0 -0
  641. package/skills/senior-computer-vision/scripts/dataset_pipeline_builder.py +0 -0
  642. package/skills/senior-computer-vision/scripts/inference_optimizer.py +0 -0
  643. package/skills/senior-computer-vision/scripts/vision_model_trainer.py +0 -0
  644. package/skills/senior-data-engineer/scripts/data_quality_validator.py +0 -0
  645. package/skills/senior-data-engineer/scripts/etl_performance_optimizer.py +0 -0
  646. package/skills/senior-data-engineer/scripts/pipeline_orchestrator.py +0 -0
  647. package/skills/senior-data-scientist/scripts/experiment_designer.py +0 -0
  648. package/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +0 -0
  649. package/skills/senior-data-scientist/scripts/model_evaluation_suite.py +0 -0
  650. package/skills/senior-devops/scripts/deployment_manager.py +0 -0
  651. package/skills/senior-devops/scripts/pipeline_generator.py +0 -0
  652. package/skills/senior-devops/scripts/terraform_scaffolder.py +0 -0
  653. package/skills/senior-frontend/scripts/bundle_analyzer.py +0 -0
  654. package/skills/senior-frontend/scripts/component_generator.py +0 -0
  655. package/skills/senior-frontend/scripts/frontend_scaffolder.py +0 -0
  656. package/skills/senior-fullstack/scripts/code_quality_analyzer.py +0 -0
  657. package/skills/senior-fullstack/scripts/fullstack_scaffolder.py +0 -0
  658. package/skills/senior-fullstack/scripts/project_scaffolder.py +0 -0
  659. package/skills/senior-ml-engineer/scripts/ml_monitoring_suite.py +0 -0
  660. package/skills/senior-ml-engineer/scripts/model_deployment_pipeline.py +0 -0
  661. package/skills/senior-ml-engineer/scripts/rag_system_builder.py +0 -0
  662. package/skills/senior-prompt-engineer/scripts/agent_orchestrator.py +0 -0
  663. package/skills/senior-prompt-engineer/scripts/prompt_optimizer.py +0 -0
  664. package/skills/senior-prompt-engineer/scripts/rag_evaluator.py +0 -0
  665. package/skills/senior-qa/scripts/coverage_analyzer.py +0 -0
  666. package/skills/senior-qa/scripts/e2e_test_scaffolder.py +0 -0
  667. package/skills/senior-qa/scripts/test_suite_generator.py +0 -0
  668. package/skills/senior-secops/scripts/compliance_checker.py +0 -0
  669. package/skills/senior-secops/scripts/security_scanner.py +0 -0
  670. package/skills/senior-secops/scripts/vulnerability_assessor.py +0 -0
  671. package/skills/senior-security/scripts/pentest_automator.py +0 -0
  672. package/skills/senior-security/scripts/security_auditor.py +0 -0
  673. package/skills/senior-security/scripts/threat_modeler.py +0 -0
  674. package/skills/seo-authority-builder/SKILL.md +136 -0
  675. package/skills/seo-cannibalization-detector/SKILL.md +123 -0
  676. package/skills/seo-content-auditor/SKILL.md +83 -0
  677. package/skills/seo-content-planner/SKILL.md +108 -0
  678. package/skills/seo-content-refresher/SKILL.md +118 -0
  679. package/skills/seo-content-writer/SKILL.md +96 -0
  680. package/skills/seo-keyword-strategist/SKILL.md +95 -0
  681. package/skills/seo-meta-optimizer/SKILL.md +92 -0
  682. package/skills/seo-snippet-hunter/SKILL.md +114 -0
  683. package/skills/seo-structure-architect/SKILL.md +108 -0
  684. package/skills/service-mesh-expert/SKILL.md +58 -0
  685. package/skills/service-mesh-observability/SKILL.md +395 -0
  686. package/skills/sharp-edges/SKILL.md +70 -0
  687. package/skills/shellcheck-configuration/SKILL.md +466 -0
  688. package/skills/similarity-search-patterns/SKILL.md +33 -0
  689. package/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
  690. package/skills/skill-creator/scripts/init_skill.py +0 -0
  691. package/skills/skill-creator/scripts/package_skill.py +0 -0
  692. package/skills/skill-creator/scripts/quick_validate.py +0 -0
  693. package/skills/skill-rails-upgrade/SKILL.md +408 -0
  694. package/skills/skill-seekers/SKILL.md +22 -0
  695. package/skills/slack-gif-creator/core/easing.py +0 -0
  696. package/skills/slack-gif-creator/core/frame_composer.py +0 -0
  697. package/skills/slack-gif-creator/core/gif_builder.py +0 -0
  698. package/skills/slack-gif-creator/core/validators.py +0 -0
  699. package/skills/slo-implementation/SKILL.md +341 -0
  700. package/skills/solidity-security/SKILL.md +34 -0
  701. package/skills/solidity-security/resources/implementation-playbook.md +524 -0
  702. package/skills/spark-optimization/SKILL.md +427 -0
  703. package/skills/sql-optimization-patterns/SKILL.md +35 -0
  704. package/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
  705. package/skills/sql-pro/SKILL.md +170 -94
  706. package/skills/startup-analyst/SKILL.md +328 -0
  707. package/skills/startup-business-analyst-business-case/SKILL.md +487 -0
  708. package/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
  709. package/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
  710. package/skills/startup-financial-modeling/SKILL.md +467 -0
  711. package/skills/startup-metrics-framework/SKILL.md +34 -0
  712. package/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
  713. package/skills/stitch-ui-design/README.md +165 -0
  714. package/skills/stitch-ui-design/SKILL.md +378 -0
  715. package/skills/stitch-ui-design/references/advanced-techniques.md +541 -0
  716. package/skills/stitch-ui-design/references/prompt-examples.md +601 -0
  717. package/skills/stride-analysis-patterns/SKILL.md +33 -0
  718. package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
  719. package/skills/stripe-integration/SKILL.md +429 -44
  720. package/skills/superpowers-lab/SKILL.md +22 -0
  721. package/skills/swiftui-expert-skill/SKILL.md +275 -0
  722. package/skills/systematic-debugging/find-polluter.sh +0 -0
  723. package/skills/systems-programming-rust-project/SKILL.md +440 -0
  724. package/skills/tailwind-design-system/SKILL.md +33 -0
  725. package/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
  726. package/skills/tdd-orchestrator/SKILL.md +205 -0
  727. package/skills/tdd-workflows-tdd-cycle/SKILL.md +221 -0
  728. package/skills/tdd-workflows-tdd-green/SKILL.md +73 -0
  729. package/skills/tdd-workflows-tdd-green/resources/implementation-playbook.md +870 -0
  730. package/skills/tdd-workflows-tdd-red/SKILL.md +164 -0
  731. package/skills/tdd-workflows-tdd-refactor/SKILL.md +187 -0
  732. package/skills/team-collaboration-issue/SKILL.md +37 -0
  733. package/skills/team-collaboration-issue/resources/implementation-playbook.md +640 -0
  734. package/skills/team-collaboration-standup-notes/SKILL.md +44 -0
  735. package/skills/team-collaboration-standup-notes/resources/implementation-playbook.md +768 -0
  736. package/skills/team-composition-analysis/SKILL.md +413 -0
  737. package/skills/temporal-python-pro/SKILL.md +370 -0
  738. package/skills/temporal-python-testing/SKILL.md +170 -0
  739. package/skills/temporal-python-testing/resources/integration-testing.md +455 -0
  740. package/skills/temporal-python-testing/resources/local-setup.md +553 -0
  741. package/skills/temporal-python-testing/resources/replay-testing.md +462 -0
  742. package/skills/temporal-python-testing/resources/unit-testing.md +328 -0
  743. package/skills/terraform-module-library/SKILL.md +261 -0
  744. package/skills/terraform-module-library/references/aws-modules.md +63 -0
  745. package/skills/terraform-skill/SKILL.md +517 -0
  746. package/skills/terraform-specialist/SKILL.md +166 -0
  747. package/skills/test-automator/SKILL.md +224 -0
  748. package/skills/threat-mitigation-mapping/SKILL.md +33 -0
  749. package/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
  750. package/skills/threat-modeling-expert/SKILL.md +60 -0
  751. package/skills/threejs-skills/SKILL.md +22 -0
  752. package/skills/tool-design/SKILL.md +318 -0
  753. package/skills/track-management/SKILL.md +38 -0
  754. package/skills/track-management/resources/implementation-playbook.md +591 -0
  755. package/skills/turborepo-caching/SKILL.md +419 -0
  756. package/skills/tutorial-engineer/SKILL.md +139 -0
  757. package/skills/typescript-advanced-types/SKILL.md +35 -0
  758. package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
  759. package/skills/typescript-pro/SKILL.md +52 -91
  760. package/skills/ui-skills/SKILL.md +22 -0
  761. package/skills/ui-ux-designer/SKILL.md +209 -0
  762. package/skills/ui-ux-pro-max/SKILL.md +351 -351
  763. package/skills/ui-ux-pro-max/data/charts.csv +25 -25
  764. package/skills/ui-ux-pro-max/data/colors.csv +96 -96
  765. package/skills/ui-ux-pro-max/data/landing.csv +30 -30
  766. package/skills/ui-ux-pro-max/data/products.csv +96 -96
  767. package/skills/ui-ux-pro-max/data/prompts.csv +20 -20
  768. package/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
  769. package/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
  770. package/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
  771. package/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
  772. package/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
  773. package/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
  774. package/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
  775. package/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
  776. package/skills/ui-ux-pro-max/data/styles.csv +58 -58
  777. package/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
  778. package/skills/ui-ux-pro-max/scripts/search.py +76 -76
  779. package/skills/ui-visual-validator/SKILL.md +214 -0
  780. package/skills/unit-testing-test-generate/SKILL.md +319 -0
  781. package/skills/unity-developer/SKILL.md +230 -0
  782. package/skills/unity-ecs-patterns/SKILL.md +33 -0
  783. package/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
  784. package/skills/unreal-engine-cpp-pro/SKILL.md +114 -0
  785. package/skills/unreal-engine-cpp-pro/examples/ExampleActor.cpp +43 -0
  786. package/skills/unreal-engine-cpp-pro/examples/ExampleActor.h +57 -0
  787. package/skills/upgrading-expo/SKILL.md +108 -12
  788. package/skills/using-neon/SKILL.md +84 -0
  789. package/skills/uv-package-manager/SKILL.md +37 -0
  790. package/skills/uv-package-manager/resources/implementation-playbook.md +830 -0
  791. package/skills/varlock-claude-skill/SKILL.md +22 -0
  792. package/skills/vector-database-engineer/SKILL.md +60 -0
  793. package/skills/vector-index-tuning/SKILL.md +42 -0
  794. package/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
  795. package/skills/vercel-deploy-claimable/SKILL.md +120 -0
  796. package/skills/vercel-deployment/SKILL.md +10 -0
  797. package/skills/vexor/SKILL.md +22 -0
  798. package/skills/wcag-audit-patterns/SKILL.md +41 -0
  799. package/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
  800. package/skills/web-artifacts-builder/scripts/bundle-artifact.sh +0 -0
  801. package/skills/web-artifacts-builder/scripts/init-artifact.sh +0 -0
  802. package/skills/web3-testing/SKILL.md +427 -0
  803. package/skills/webapp-testing/scripts/with_server.py +0 -0
  804. package/skills/workflow-orchestration-patterns/SKILL.md +333 -0
  805. package/skills/workflow-patterns/SKILL.md +38 -0
  806. package/skills/workflow-patterns/resources/implementation-playbook.md +621 -0
  807. package/skills/writing-skills/SKILL.md +84 -696
  808. package/skills/writing-skills/examples.md +282 -0
  809. package/skills/writing-skills/gotchas.md +197 -0
  810. package/skills/writing-skills/references/anti-rationalization/README.md +255 -0
  811. package/skills/writing-skills/references/cso/README.md +268 -0
  812. package/skills/writing-skills/references/standards/README.md +152 -0
  813. package/skills/writing-skills/references/standards/metadata-standard.md +65 -0
  814. package/skills/writing-skills/references/templates/discipline.md +54 -0
  815. package/skills/writing-skills/references/templates/pattern.md +48 -0
  816. package/skills/writing-skills/references/templates/reference.md +35 -0
  817. package/skills/writing-skills/references/templates/technique.md +59 -0
  818. package/skills/writing-skills/references/templates/tier-3-platform.md +19 -0
  819. package/skills/writing-skills/references/testing/README.md +204 -0
  820. package/skills/writing-skills/references/tier-1-simple/README.md +75 -0
  821. package/skills/writing-skills/references/tier-2-expanded/README.md +69 -0
  822. package/skills/writing-skills/references/tier-3-platform/README.md +98 -0
  823. package/skills/writing-skills/render-graphs.js +0 -0
  824. package/skills/x-article-publisher-skill/SKILL.md +22 -0
  825. package/skills/xlsx/LICENSE.txt +30 -0
  826. package/skills/xlsx/SKILL.md +217 -28
  827. package/skills/xlsx/recalc.py +178 -0
@@ -0,0 +1,1024 @@
1
+ # JavaScript Testing Patterns Implementation Playbook
2
+
3
+ This file contains detailed patterns, checklists, and code samples referenced by the skill.
4
+
5
+ # JavaScript Testing Patterns
6
+
7
+ Comprehensive guide for implementing robust testing strategies in JavaScript/TypeScript applications using modern testing frameworks and best practices.
8
+
9
+ ## When to Use This Skill
10
+
11
+ - Setting up test infrastructure for new projects
12
+ - Writing unit tests for functions and classes
13
+ - Creating integration tests for APIs and services
14
+ - Implementing end-to-end tests for user flows
15
+ - Mocking external dependencies and APIs
16
+ - Testing React, Vue, or other frontend components
17
+ - Implementing test-driven development (TDD)
18
+ - Setting up continuous testing in CI/CD pipelines
19
+
20
+ ## Testing Frameworks
21
+
22
+ ### Jest - Full-Featured Testing Framework
23
+
24
+ **Setup:**
25
+ ```typescript
26
+ // jest.config.ts
27
+ import type { Config } from 'jest';
28
+
29
+ const config: Config = {
30
+ preset: 'ts-jest',
31
+ testEnvironment: 'node',
32
+ roots: ['<rootDir>/src'],
33
+ testMatch: ['**/__tests__/**/*.ts', '**/?(*.)+(spec|test).ts'],
34
+ collectCoverageFrom: [
35
+ 'src/**/*.ts',
36
+ '!src/**/*.d.ts',
37
+ '!src/**/*.interface.ts',
38
+ ],
39
+ coverageThreshold: {
40
+ global: {
41
+ branches: 80,
42
+ functions: 80,
43
+ lines: 80,
44
+ statements: 80,
45
+ },
46
+ },
47
+ setupFilesAfterEnv: ['<rootDir>/src/test/setup.ts'],
48
+ };
49
+
50
+ export default config;
51
+ ```
52
+
53
+ ### Vitest - Fast, Vite-Native Testing
54
+
55
+ **Setup:**
56
+ ```typescript
57
+ // vitest.config.ts
58
+ import { defineConfig } from 'vitest/config';
59
+
60
+ export default defineConfig({
61
+ test: {
62
+ globals: true,
63
+ environment: 'node',
64
+ coverage: {
65
+ provider: 'v8',
66
+ reporter: ['text', 'json', 'html'],
67
+ exclude: ['**/*.d.ts', '**/*.config.ts', '**/dist/**'],
68
+ },
69
+ setupFiles: ['./src/test/setup.ts'],
70
+ },
71
+ });
72
+ ```
73
+
74
+ ## Unit Testing Patterns
75
+
76
+ ### Pattern 1: Testing Pure Functions
77
+
78
+ ```typescript
79
+ // utils/calculator.ts
80
+ export function add(a: number, b: number): number {
81
+ return a + b;
82
+ }
83
+
84
+ export function divide(a: number, b: number): number {
85
+ if (b === 0) {
86
+ throw new Error('Division by zero');
87
+ }
88
+ return a / b;
89
+ }
90
+
91
+ // utils/calculator.test.ts
92
+ import { describe, it, expect } from 'vitest';
93
+ import { add, divide } from './calculator';
94
+
95
+ describe('Calculator', () => {
96
+ describe('add', () => {
97
+ it('should add two positive numbers', () => {
98
+ expect(add(2, 3)).toBe(5);
99
+ });
100
+
101
+ it('should add negative numbers', () => {
102
+ expect(add(-2, -3)).toBe(-5);
103
+ });
104
+
105
+ it('should handle zero', () => {
106
+ expect(add(0, 5)).toBe(5);
107
+ expect(add(5, 0)).toBe(5);
108
+ });
109
+ });
110
+
111
+ describe('divide', () => {
112
+ it('should divide two numbers', () => {
113
+ expect(divide(10, 2)).toBe(5);
114
+ });
115
+
116
+ it('should handle decimal results', () => {
117
+ expect(divide(5, 2)).toBe(2.5);
118
+ });
119
+
120
+ it('should throw error when dividing by zero', () => {
121
+ expect(() => divide(10, 0)).toThrow('Division by zero');
122
+ });
123
+ });
124
+ });
125
+ ```
126
+
127
+ ### Pattern 2: Testing Classes
128
+
129
+ ```typescript
130
+ // services/user.service.ts
131
+ export class UserService {
132
+ private users: Map<string, User> = new Map();
133
+
134
+ create(user: User): User {
135
+ if (this.users.has(user.id)) {
136
+ throw new Error('User already exists');
137
+ }
138
+ this.users.set(user.id, user);
139
+ return user;
140
+ }
141
+
142
+ findById(id: string): User | undefined {
143
+ return this.users.get(id);
144
+ }
145
+
146
+ update(id: string, updates: Partial<User>): User {
147
+ const user = this.users.get(id);
148
+ if (!user) {
149
+ throw new Error('User not found');
150
+ }
151
+ const updated = { ...user, ...updates };
152
+ this.users.set(id, updated);
153
+ return updated;
154
+ }
155
+
156
+ delete(id: string): boolean {
157
+ return this.users.delete(id);
158
+ }
159
+ }
160
+
161
+ // services/user.service.test.ts
162
+ import { describe, it, expect, beforeEach } from 'vitest';
163
+ import { UserService } from './user.service';
164
+
165
+ describe('UserService', () => {
166
+ let service: UserService;
167
+
168
+ beforeEach(() => {
169
+ service = new UserService();
170
+ });
171
+
172
+ describe('create', () => {
173
+ it('should create a new user', () => {
174
+ const user = { id: '1', name: 'John', email: 'john@example.com' };
175
+ const created = service.create(user);
176
+
177
+ expect(created).toEqual(user);
178
+ expect(service.findById('1')).toEqual(user);
179
+ });
180
+
181
+ it('should throw error if user already exists', () => {
182
+ const user = { id: '1', name: 'John', email: 'john@example.com' };
183
+ service.create(user);
184
+
185
+ expect(() => service.create(user)).toThrow('User already exists');
186
+ });
187
+ });
188
+
189
+ describe('update', () => {
190
+ it('should update existing user', () => {
191
+ const user = { id: '1', name: 'John', email: 'john@example.com' };
192
+ service.create(user);
193
+
194
+ const updated = service.update('1', { name: 'Jane' });
195
+
196
+ expect(updated.name).toBe('Jane');
197
+ expect(updated.email).toBe('john@example.com');
198
+ });
199
+
200
+ it('should throw error if user not found', () => {
201
+ expect(() => service.update('999', { name: 'Jane' }))
202
+ .toThrow('User not found');
203
+ });
204
+ });
205
+ });
206
+ ```
207
+
208
+ ### Pattern 3: Testing Async Functions
209
+
210
+ ```typescript
211
+ // services/api.service.ts
212
+ export class ApiService {
213
+ async fetchUser(id: string): Promise<User> {
214
+ const response = await fetch(`https://api.example.com/users/${id}`);
215
+ if (!response.ok) {
216
+ throw new Error('User not found');
217
+ }
218
+ return response.json();
219
+ }
220
+
221
+ async createUser(user: CreateUserDTO): Promise<User> {
222
+ const response = await fetch('https://api.example.com/users', {
223
+ method: 'POST',
224
+ headers: { 'Content-Type': 'application/json' },
225
+ body: JSON.stringify(user),
226
+ });
227
+ return response.json();
228
+ }
229
+ }
230
+
231
+ // services/api.service.test.ts
232
+ import { describe, it, expect, vi, beforeEach } from 'vitest';
233
+ import { ApiService } from './api.service';
234
+
235
+ // Mock fetch globally
236
+ global.fetch = vi.fn();
237
+
238
+ describe('ApiService', () => {
239
+ let service: ApiService;
240
+
241
+ beforeEach(() => {
242
+ service = new ApiService();
243
+ vi.clearAllMocks();
244
+ });
245
+
246
+ describe('fetchUser', () => {
247
+ it('should fetch user successfully', async () => {
248
+ const mockUser = { id: '1', name: 'John', email: 'john@example.com' };
249
+
250
+ (fetch as any).mockResolvedValueOnce({
251
+ ok: true,
252
+ json: async () => mockUser,
253
+ });
254
+
255
+ const user = await service.fetchUser('1');
256
+
257
+ expect(user).toEqual(mockUser);
258
+ expect(fetch).toHaveBeenCalledWith('https://api.example.com/users/1');
259
+ });
260
+
261
+ it('should throw error if user not found', async () => {
262
+ (fetch as any).mockResolvedValueOnce({
263
+ ok: false,
264
+ });
265
+
266
+ await expect(service.fetchUser('999')).rejects.toThrow('User not found');
267
+ });
268
+ });
269
+
270
+ describe('createUser', () => {
271
+ it('should create user successfully', async () => {
272
+ const newUser = { name: 'John', email: 'john@example.com' };
273
+ const createdUser = { id: '1', ...newUser };
274
+
275
+ (fetch as any).mockResolvedValueOnce({
276
+ ok: true,
277
+ json: async () => createdUser,
278
+ });
279
+
280
+ const user = await service.createUser(newUser);
281
+
282
+ expect(user).toEqual(createdUser);
283
+ expect(fetch).toHaveBeenCalledWith(
284
+ 'https://api.example.com/users',
285
+ expect.objectContaining({
286
+ method: 'POST',
287
+ body: JSON.stringify(newUser),
288
+ })
289
+ );
290
+ });
291
+ });
292
+ });
293
+ ```
294
+
295
+ ## Mocking Patterns
296
+
297
+ ### Pattern 1: Mocking Modules
298
+
299
+ ```typescript
300
+ // services/email.service.ts
301
+ import nodemailer from 'nodemailer';
302
+
303
+ export class EmailService {
304
+ private transporter = nodemailer.createTransport({
305
+ host: process.env.SMTP_HOST,
306
+ port: 587,
307
+ auth: {
308
+ user: process.env.SMTP_USER,
309
+ pass: process.env.SMTP_PASS,
310
+ },
311
+ });
312
+
313
+ async sendEmail(to: string, subject: string, html: string) {
314
+ await this.transporter.sendMail({
315
+ from: process.env.EMAIL_FROM,
316
+ to,
317
+ subject,
318
+ html,
319
+ });
320
+ }
321
+ }
322
+
323
+ // services/email.service.test.ts
324
+ import { describe, it, expect, vi, beforeEach } from 'vitest';
325
+ import { EmailService } from './email.service';
326
+
327
+ vi.mock('nodemailer', () => ({
328
+ default: {
329
+ createTransport: vi.fn(() => ({
330
+ sendMail: vi.fn().mockResolvedValue({ messageId: '123' }),
331
+ })),
332
+ },
333
+ }));
334
+
335
+ describe('EmailService', () => {
336
+ let service: EmailService;
337
+
338
+ beforeEach(() => {
339
+ service = new EmailService();
340
+ });
341
+
342
+ it('should send email successfully', async () => {
343
+ await service.sendEmail(
344
+ 'test@example.com',
345
+ 'Test Subject',
346
+ '<p>Test Body</p>'
347
+ );
348
+
349
+ expect(service['transporter'].sendMail).toHaveBeenCalledWith(
350
+ expect.objectContaining({
351
+ to: 'test@example.com',
352
+ subject: 'Test Subject',
353
+ })
354
+ );
355
+ });
356
+ });
357
+ ```
358
+
359
+ ### Pattern 2: Dependency Injection for Testing
360
+
361
+ ```typescript
362
+ // services/user.service.ts
363
+ export interface IUserRepository {
364
+ findById(id: string): Promise<User | null>;
365
+ create(user: User): Promise<User>;
366
+ }
367
+
368
+ export class UserService {
369
+ constructor(private userRepository: IUserRepository) {}
370
+
371
+ async getUser(id: string): Promise<User> {
372
+ const user = await this.userRepository.findById(id);
373
+ if (!user) {
374
+ throw new Error('User not found');
375
+ }
376
+ return user;
377
+ }
378
+
379
+ async createUser(userData: CreateUserDTO): Promise<User> {
380
+ // Business logic here
381
+ const user = { id: generateId(), ...userData };
382
+ return this.userRepository.create(user);
383
+ }
384
+ }
385
+
386
+ // services/user.service.test.ts
387
+ import { describe, it, expect, vi, beforeEach } from 'vitest';
388
+ import { UserService, IUserRepository } from './user.service';
389
+
390
+ describe('UserService', () => {
391
+ let service: UserService;
392
+ let mockRepository: IUserRepository;
393
+
394
+ beforeEach(() => {
395
+ mockRepository = {
396
+ findById: vi.fn(),
397
+ create: vi.fn(),
398
+ };
399
+ service = new UserService(mockRepository);
400
+ });
401
+
402
+ describe('getUser', () => {
403
+ it('should return user if found', async () => {
404
+ const mockUser = { id: '1', name: 'John', email: 'john@example.com' };
405
+ vi.mocked(mockRepository.findById).mockResolvedValue(mockUser);
406
+
407
+ const user = await service.getUser('1');
408
+
409
+ expect(user).toEqual(mockUser);
410
+ expect(mockRepository.findById).toHaveBeenCalledWith('1');
411
+ });
412
+
413
+ it('should throw error if user not found', async () => {
414
+ vi.mocked(mockRepository.findById).mockResolvedValue(null);
415
+
416
+ await expect(service.getUser('999')).rejects.toThrow('User not found');
417
+ });
418
+ });
419
+
420
+ describe('createUser', () => {
421
+ it('should create user successfully', async () => {
422
+ const userData = { name: 'John', email: 'john@example.com' };
423
+ const createdUser = { id: '1', ...userData };
424
+
425
+ vi.mocked(mockRepository.create).mockResolvedValue(createdUser);
426
+
427
+ const user = await service.createUser(userData);
428
+
429
+ expect(user).toEqual(createdUser);
430
+ expect(mockRepository.create).toHaveBeenCalled();
431
+ });
432
+ });
433
+ });
434
+ ```
435
+
436
+ ### Pattern 3: Spying on Functions
437
+
438
+ ```typescript
439
+ // utils/logger.ts
440
+ export const logger = {
441
+ info: (message: string) => console.log(`INFO: ${message}`),
442
+ error: (message: string) => console.error(`ERROR: ${message}`),
443
+ };
444
+
445
+ // services/order.service.ts
446
+ import { logger } from '../utils/logger';
447
+
448
+ export class OrderService {
449
+ async processOrder(orderId: string): Promise<void> {
450
+ logger.info(`Processing order ${orderId}`);
451
+ // Process order logic
452
+ logger.info(`Order ${orderId} processed successfully`);
453
+ }
454
+ }
455
+
456
+ // services/order.service.test.ts
457
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
458
+ import { OrderService } from './order.service';
459
+ import { logger } from '../utils/logger';
460
+
461
+ describe('OrderService', () => {
462
+ let service: OrderService;
463
+ let loggerSpy: any;
464
+
465
+ beforeEach(() => {
466
+ service = new OrderService();
467
+ loggerSpy = vi.spyOn(logger, 'info');
468
+ });
469
+
470
+ afterEach(() => {
471
+ loggerSpy.mockRestore();
472
+ });
473
+
474
+ it('should log order processing', async () => {
475
+ await service.processOrder('123');
476
+
477
+ expect(loggerSpy).toHaveBeenCalledWith('Processing order 123');
478
+ expect(loggerSpy).toHaveBeenCalledWith('Order 123 processed successfully');
479
+ expect(loggerSpy).toHaveBeenCalledTimes(2);
480
+ });
481
+ });
482
+ ```
483
+
484
+ ## Integration Testing
485
+
486
+ ### Pattern 1: API Integration Tests
487
+
488
+ ```typescript
489
+ // tests/integration/user.api.test.ts
490
+ import request from 'supertest';
491
+ import { app } from '../../src/app';
492
+ import { pool } from '../../src/config/database';
493
+
494
+ describe('User API Integration Tests', () => {
495
+ beforeAll(async () => {
496
+ // Setup test database
497
+ await pool.query('CREATE TABLE IF NOT EXISTS users (...)');
498
+ });
499
+
500
+ afterAll(async () => {
501
+ // Cleanup
502
+ await pool.query('DROP TABLE IF EXISTS users');
503
+ await pool.end();
504
+ });
505
+
506
+ beforeEach(async () => {
507
+ // Clear data before each test
508
+ await pool.query('TRUNCATE TABLE users CASCADE');
509
+ });
510
+
511
+ describe('POST /api/users', () => {
512
+ it('should create a new user', async () => {
513
+ const userData = {
514
+ name: 'John Doe',
515
+ email: 'john@example.com',
516
+ password: 'password123',
517
+ };
518
+
519
+ const response = await request(app)
520
+ .post('/api/users')
521
+ .send(userData)
522
+ .expect(201);
523
+
524
+ expect(response.body).toMatchObject({
525
+ name: userData.name,
526
+ email: userData.email,
527
+ });
528
+ expect(response.body).toHaveProperty('id');
529
+ expect(response.body).not.toHaveProperty('password');
530
+ });
531
+
532
+ it('should return 400 if email is invalid', async () => {
533
+ const userData = {
534
+ name: 'John Doe',
535
+ email: 'invalid-email',
536
+ password: 'password123',
537
+ };
538
+
539
+ const response = await request(app)
540
+ .post('/api/users')
541
+ .send(userData)
542
+ .expect(400);
543
+
544
+ expect(response.body).toHaveProperty('error');
545
+ });
546
+
547
+ it('should return 409 if email already exists', async () => {
548
+ const userData = {
549
+ name: 'John Doe',
550
+ email: 'john@example.com',
551
+ password: 'password123',
552
+ };
553
+
554
+ await request(app).post('/api/users').send(userData);
555
+
556
+ const response = await request(app)
557
+ .post('/api/users')
558
+ .send(userData)
559
+ .expect(409);
560
+
561
+ expect(response.body.error).toContain('already exists');
562
+ });
563
+ });
564
+
565
+ describe('GET /api/users/:id', () => {
566
+ it('should get user by id', async () => {
567
+ const createResponse = await request(app)
568
+ .post('/api/users')
569
+ .send({
570
+ name: 'John Doe',
571
+ email: 'john@example.com',
572
+ password: 'password123',
573
+ });
574
+
575
+ const userId = createResponse.body.id;
576
+
577
+ const response = await request(app)
578
+ .get(`/api/users/${userId}`)
579
+ .expect(200);
580
+
581
+ expect(response.body).toMatchObject({
582
+ id: userId,
583
+ name: 'John Doe',
584
+ email: 'john@example.com',
585
+ });
586
+ });
587
+
588
+ it('should return 404 if user not found', async () => {
589
+ await request(app)
590
+ .get('/api/users/999')
591
+ .expect(404);
592
+ });
593
+ });
594
+
595
+ describe('Authentication', () => {
596
+ it('should require authentication for protected routes', async () => {
597
+ await request(app)
598
+ .get('/api/users/me')
599
+ .expect(401);
600
+ });
601
+
602
+ it('should allow access with valid token', async () => {
603
+ // Create user and login
604
+ await request(app)
605
+ .post('/api/users')
606
+ .send({
607
+ name: 'John Doe',
608
+ email: 'john@example.com',
609
+ password: 'password123',
610
+ });
611
+
612
+ const loginResponse = await request(app)
613
+ .post('/api/auth/login')
614
+ .send({
615
+ email: 'john@example.com',
616
+ password: 'password123',
617
+ });
618
+
619
+ const token = loginResponse.body.token;
620
+
621
+ const response = await request(app)
622
+ .get('/api/users/me')
623
+ .set('Authorization', `Bearer ${token}`)
624
+ .expect(200);
625
+
626
+ expect(response.body.email).toBe('john@example.com');
627
+ });
628
+ });
629
+ });
630
+ ```
631
+
632
+ ### Pattern 2: Database Integration Tests
633
+
634
+ ```typescript
635
+ // tests/integration/user.repository.test.ts
636
+ import { describe, it, expect, beforeAll, afterAll, beforeEach } from 'vitest';
637
+ import { Pool } from 'pg';
638
+ import { UserRepository } from '../../src/repositories/user.repository';
639
+
640
+ describe('UserRepository Integration Tests', () => {
641
+ let pool: Pool;
642
+ let repository: UserRepository;
643
+
644
+ beforeAll(async () => {
645
+ pool = new Pool({
646
+ host: 'localhost',
647
+ port: 5432,
648
+ database: 'test_db',
649
+ user: 'test_user',
650
+ password: 'test_password',
651
+ });
652
+
653
+ repository = new UserRepository(pool);
654
+
655
+ // Create tables
656
+ await pool.query(`
657
+ CREATE TABLE IF NOT EXISTS users (
658
+ id SERIAL PRIMARY KEY,
659
+ name VARCHAR(255) NOT NULL,
660
+ email VARCHAR(255) UNIQUE NOT NULL,
661
+ password VARCHAR(255) NOT NULL,
662
+ created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
663
+ )
664
+ `);
665
+ });
666
+
667
+ afterAll(async () => {
668
+ await pool.query('DROP TABLE IF EXISTS users');
669
+ await pool.end();
670
+ });
671
+
672
+ beforeEach(async () => {
673
+ await pool.query('TRUNCATE TABLE users CASCADE');
674
+ });
675
+
676
+ it('should create a user', async () => {
677
+ const user = await repository.create({
678
+ name: 'John Doe',
679
+ email: 'john@example.com',
680
+ password: 'hashed_password',
681
+ });
682
+
683
+ expect(user).toHaveProperty('id');
684
+ expect(user.name).toBe('John Doe');
685
+ expect(user.email).toBe('john@example.com');
686
+ });
687
+
688
+ it('should find user by email', async () => {
689
+ await repository.create({
690
+ name: 'John Doe',
691
+ email: 'john@example.com',
692
+ password: 'hashed_password',
693
+ });
694
+
695
+ const user = await repository.findByEmail('john@example.com');
696
+
697
+ expect(user).toBeTruthy();
698
+ expect(user?.name).toBe('John Doe');
699
+ });
700
+
701
+ it('should return null if user not found', async () => {
702
+ const user = await repository.findByEmail('nonexistent@example.com');
703
+ expect(user).toBeNull();
704
+ });
705
+ });
706
+ ```
707
+
708
+ ## Frontend Testing with Testing Library
709
+
710
+ ### Pattern 1: React Component Testing
711
+
712
+ ```typescript
713
+ // components/UserForm.tsx
714
+ import { useState } from 'react';
715
+
716
+ interface Props {
717
+ onSubmit: (user: { name: string; email: string }) => void;
718
+ }
719
+
720
+ export function UserForm({ onSubmit }: Props) {
721
+ const [name, setName] = useState('');
722
+ const [email, setEmail] = useState('');
723
+
724
+ const handleSubmit = (e: React.FormEvent) => {
725
+ e.preventDefault();
726
+ onSubmit({ name, email });
727
+ };
728
+
729
+ return (
730
+ <form onSubmit={handleSubmit}>
731
+ <input
732
+ type="text"
733
+ placeholder="Name"
734
+ value={name}
735
+ onChange={(e) => setName(e.target.value)}
736
+ data-testid="name-input"
737
+ />
738
+ <input
739
+ type="email"
740
+ placeholder="Email"
741
+ value={email}
742
+ onChange={(e) => setEmail(e.target.value)}
743
+ data-testid="email-input"
744
+ />
745
+ <button type="submit">Submit</button>
746
+ </form>
747
+ );
748
+ }
749
+
750
+ // components/UserForm.test.tsx
751
+ import { render, screen, fireEvent } from '@testing-library/react';
752
+ import { describe, it, expect, vi } from 'vitest';
753
+ import { UserForm } from './UserForm';
754
+
755
+ describe('UserForm', () => {
756
+ it('should render form inputs', () => {
757
+ render(<UserForm onSubmit={vi.fn()} />);
758
+
759
+ expect(screen.getByPlaceholderText('Name')).toBeInTheDocument();
760
+ expect(screen.getByPlaceholderText('Email')).toBeInTheDocument();
761
+ expect(screen.getByRole('button', { name: 'Submit' })).toBeInTheDocument();
762
+ });
763
+
764
+ it('should update input values', () => {
765
+ render(<UserForm onSubmit={vi.fn()} />);
766
+
767
+ const nameInput = screen.getByTestId('name-input') as HTMLInputElement;
768
+ const emailInput = screen.getByTestId('email-input') as HTMLInputElement;
769
+
770
+ fireEvent.change(nameInput, { target: { value: 'John Doe' } });
771
+ fireEvent.change(emailInput, { target: { value: 'john@example.com' } });
772
+
773
+ expect(nameInput.value).toBe('John Doe');
774
+ expect(emailInput.value).toBe('john@example.com');
775
+ });
776
+
777
+ it('should call onSubmit with form data', () => {
778
+ const onSubmit = vi.fn();
779
+ render(<UserForm onSubmit={onSubmit} />);
780
+
781
+ fireEvent.change(screen.getByTestId('name-input'), {
782
+ target: { value: 'John Doe' },
783
+ });
784
+ fireEvent.change(screen.getByTestId('email-input'), {
785
+ target: { value: 'john@example.com' },
786
+ });
787
+ fireEvent.click(screen.getByRole('button', { name: 'Submit' }));
788
+
789
+ expect(onSubmit).toHaveBeenCalledWith({
790
+ name: 'John Doe',
791
+ email: 'john@example.com',
792
+ });
793
+ });
794
+ });
795
+ ```
796
+
797
+ ### Pattern 2: Testing Hooks
798
+
799
+ ```typescript
800
+ // hooks/useCounter.ts
801
+ import { useState, useCallback } from 'react';
802
+
803
+ export function useCounter(initialValue = 0) {
804
+ const [count, setCount] = useState(initialValue);
805
+
806
+ const increment = useCallback(() => setCount((c) => c + 1), []);
807
+ const decrement = useCallback(() => setCount((c) => c - 1), []);
808
+ const reset = useCallback(() => setCount(initialValue), [initialValue]);
809
+
810
+ return { count, increment, decrement, reset };
811
+ }
812
+
813
+ // hooks/useCounter.test.ts
814
+ import { renderHook, act } from '@testing-library/react';
815
+ import { describe, it, expect } from 'vitest';
816
+ import { useCounter } from './useCounter';
817
+
818
+ describe('useCounter', () => {
819
+ it('should initialize with default value', () => {
820
+ const { result } = renderHook(() => useCounter());
821
+ expect(result.current.count).toBe(0);
822
+ });
823
+
824
+ it('should initialize with custom value', () => {
825
+ const { result } = renderHook(() => useCounter(10));
826
+ expect(result.current.count).toBe(10);
827
+ });
828
+
829
+ it('should increment count', () => {
830
+ const { result } = renderHook(() => useCounter());
831
+
832
+ act(() => {
833
+ result.current.increment();
834
+ });
835
+
836
+ expect(result.current.count).toBe(1);
837
+ });
838
+
839
+ it('should decrement count', () => {
840
+ const { result } = renderHook(() => useCounter(5));
841
+
842
+ act(() => {
843
+ result.current.decrement();
844
+ });
845
+
846
+ expect(result.current.count).toBe(4);
847
+ });
848
+
849
+ it('should reset to initial value', () => {
850
+ const { result } = renderHook(() => useCounter(10));
851
+
852
+ act(() => {
853
+ result.current.increment();
854
+ result.current.increment();
855
+ });
856
+
857
+ expect(result.current.count).toBe(12);
858
+
859
+ act(() => {
860
+ result.current.reset();
861
+ });
862
+
863
+ expect(result.current.count).toBe(10);
864
+ });
865
+ });
866
+ ```
867
+
868
+ ## Test Fixtures and Factories
869
+
870
+ ```typescript
871
+ // tests/fixtures/user.fixture.ts
872
+ import { faker } from '@faker-js/faker';
873
+
874
+ export function createUserFixture(overrides?: Partial<User>): User {
875
+ return {
876
+ id: faker.string.uuid(),
877
+ name: faker.person.fullName(),
878
+ email: faker.internet.email(),
879
+ createdAt: faker.date.past(),
880
+ ...overrides,
881
+ };
882
+ }
883
+
884
+ export function createUsersFixture(count: number): User[] {
885
+ return Array.from({ length: count }, () => createUserFixture());
886
+ }
887
+
888
+ // Usage in tests
889
+ import { createUserFixture, createUsersFixture } from '../fixtures/user.fixture';
890
+
891
+ describe('UserService', () => {
892
+ it('should process user', () => {
893
+ const user = createUserFixture({ name: 'John Doe' });
894
+ // Use user in test
895
+ });
896
+
897
+ it('should handle multiple users', () => {
898
+ const users = createUsersFixture(10);
899
+ // Use users in test
900
+ });
901
+ });
902
+ ```
903
+
904
+ ## Snapshot Testing
905
+
906
+ ```typescript
907
+ // components/UserCard.test.tsx
908
+ import { render } from '@testing-library/react';
909
+ import { describe, it, expect } from 'vitest';
910
+ import { UserCard } from './UserCard';
911
+
912
+ describe('UserCard', () => {
913
+ it('should match snapshot', () => {
914
+ const user = {
915
+ id: '1',
916
+ name: 'John Doe',
917
+ email: 'john@example.com',
918
+ avatar: 'https://example.com/avatar.jpg',
919
+ };
920
+
921
+ const { container } = render(<UserCard user={user} />);
922
+
923
+ expect(container.firstChild).toMatchSnapshot();
924
+ });
925
+
926
+ it('should match snapshot with loading state', () => {
927
+ const { container } = render(<UserCard loading />);
928
+ expect(container.firstChild).toMatchSnapshot();
929
+ });
930
+ });
931
+ ```
932
+
933
+ ## Coverage Reports
934
+
935
+ ```typescript
936
+ // package.json
937
+ {
938
+ "scripts": {
939
+ "test": "vitest",
940
+ "test:coverage": "vitest --coverage",
941
+ "test:ui": "vitest --ui"
942
+ }
943
+ }
944
+ ```
945
+
946
+ ## Best Practices
947
+
948
+ 1. **Follow AAA Pattern**: Arrange, Act, Assert
949
+ 2. **One assertion per test**: Or logically related assertions
950
+ 3. **Descriptive test names**: Should describe what is being tested
951
+ 4. **Use beforeEach/afterEach**: For setup and teardown
952
+ 5. **Mock external dependencies**: Keep tests isolated
953
+ 6. **Test edge cases**: Not just happy paths
954
+ 7. **Avoid implementation details**: Test behavior, not implementation
955
+ 8. **Use test factories**: For consistent test data
956
+ 9. **Keep tests fast**: Mock slow operations
957
+ 10. **Write tests first (TDD)**: When possible
958
+ 11. **Maintain test coverage**: Aim for 80%+ coverage
959
+ 12. **Use TypeScript**: For type-safe tests
960
+ 13. **Test error handling**: Not just success cases
961
+ 14. **Use data-testid sparingly**: Prefer semantic queries
962
+ 15. **Clean up after tests**: Prevent test pollution
963
+
964
+ ## Common Patterns
965
+
966
+ ### Test Organization
967
+
968
+ ```typescript
969
+ describe('UserService', () => {
970
+ describe('createUser', () => {
971
+ it('should create user successfully', () => {});
972
+ it('should throw error if email exists', () => {});
973
+ it('should hash password', () => {});
974
+ });
975
+
976
+ describe('updateUser', () => {
977
+ it('should update user', () => {});
978
+ it('should throw error if not found', () => {});
979
+ });
980
+ });
981
+ ```
982
+
983
+ ### Testing Promises
984
+
985
+ ```typescript
986
+ // Using async/await
987
+ it('should fetch user', async () => {
988
+ const user = await service.fetchUser('1');
989
+ expect(user).toBeDefined();
990
+ });
991
+
992
+ // Testing rejections
993
+ it('should throw error', async () => {
994
+ await expect(service.fetchUser('invalid')).rejects.toThrow('Not found');
995
+ });
996
+ ```
997
+
998
+ ### Testing Timers
999
+
1000
+ ```typescript
1001
+ import { vi } from 'vitest';
1002
+
1003
+ it('should call function after delay', () => {
1004
+ vi.useFakeTimers();
1005
+
1006
+ const callback = vi.fn();
1007
+ setTimeout(callback, 1000);
1008
+
1009
+ expect(callback).not.toHaveBeenCalled();
1010
+
1011
+ vi.advanceTimersByTime(1000);
1012
+
1013
+ expect(callback).toHaveBeenCalled();
1014
+
1015
+ vi.useRealTimers();
1016
+ });
1017
+ ```
1018
+
1019
+ ## Resources
1020
+
1021
+ - **Jest Documentation**: https://jestjs.io/
1022
+ - **Vitest Documentation**: https://vitest.dev/
1023
+ - **Testing Library**: https://testing-library.com/
1024
+ - **Kent C. Dodds Testing Blog**: https://kentcdodds.com/blog/