@agentskillkit/agent-skills 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (552) hide show
  1. package/.agent/.shared/ui-ux-pro-max/data/charts.csv +26 -0
  2. package/.agent/.shared/ui-ux-pro-max/data/colors.csv +97 -0
  3. package/.agent/.shared/ui-ux-pro-max/data/icons.csv +101 -0
  4. package/.agent/.shared/ui-ux-pro-max/data/landing.csv +31 -0
  5. package/.agent/.shared/ui-ux-pro-max/data/products.csv +97 -0
  6. package/.agent/.shared/ui-ux-pro-max/data/prompts.csv +24 -0
  7. package/.agent/.shared/ui-ux-pro-max/data/react-performance.csv +45 -0
  8. package/.agent/.shared/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  9. package/.agent/.shared/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  10. package/.agent/.shared/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
  11. package/.agent/.shared/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  12. package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
  13. package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
  14. package/.agent/.shared/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  15. package/.agent/.shared/ui-ux-pro-max/data/stacks/react.csv +54 -0
  16. package/.agent/.shared/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
  17. package/.agent/.shared/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  18. package/.agent/.shared/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  19. package/.agent/.shared/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  20. package/.agent/.shared/ui-ux-pro-max/data/styles.csv +59 -0
  21. package/.agent/.shared/ui-ux-pro-max/data/typography.csv +58 -0
  22. package/.agent/.shared/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
  23. package/.agent/.shared/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  24. package/.agent/.shared/ui-ux-pro-max/data/web-interface.csv +31 -0
  25. package/.agent/.shared/ui-ux-pro-max/scripts/__pycache__/core.cpython-313.pyc +0 -0
  26. package/.agent/.shared/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-313.pyc +0 -0
  27. package/.agent/.shared/ui-ux-pro-max/scripts/core.py +258 -0
  28. package/.agent/.shared/ui-ux-pro-max/scripts/design_system.py +1067 -0
  29. package/.agent/.shared/ui-ux-pro-max/scripts/search.py +106 -0
  30. package/.agent/ARCHITECTURE.md +292 -0
  31. package/.agent/GEMINI.md +374 -0
  32. package/.agent/agents/backend-specialist.md +263 -0
  33. package/.agent/agents/code-archaeologist.md +106 -0
  34. package/.agent/agents/database-architect.md +226 -0
  35. package/.agent/agents/debugger.md +225 -0
  36. package/.agent/agents/devops-engineer.md +242 -0
  37. package/.agent/agents/documentation-writer.md +104 -0
  38. package/.agent/agents/explorer-agent.md +73 -0
  39. package/.agent/agents/frontend-specialist.md +556 -0
  40. package/.agent/agents/game-developer.md +162 -0
  41. package/.agent/agents/mobile-developer.md +377 -0
  42. package/.agent/agents/orchestrator.md +416 -0
  43. package/.agent/agents/penetration-tester.md +188 -0
  44. package/.agent/agents/performance-optimizer.md +187 -0
  45. package/.agent/agents/product-manager.md +112 -0
  46. package/.agent/agents/product-owner.md +95 -0
  47. package/.agent/agents/project-planner.md +406 -0
  48. package/.agent/agents/qa-automation-engineer.md +103 -0
  49. package/.agent/agents/security-auditor.md +170 -0
  50. package/.agent/agents/seo-specialist.md +111 -0
  51. package/.agent/agents/test-engineer.md +158 -0
  52. package/.agent/knowledge/lessons-learned.yaml +17 -0
  53. package/.agent/rules/GEMINI.md +253 -0
  54. package/.agent/scripts/auto_preview.py +148 -0
  55. package/.agent/scripts/checklist.py +217 -0
  56. package/.agent/scripts/session_manager.py +120 -0
  57. package/.agent/scripts/verify_all.py +327 -0
  58. package/.agent/skills/aesthetic/SKILL.md +121 -0
  59. package/.agent/skills/aesthetic/assets/design-guideline-template.md +163 -0
  60. package/.agent/skills/aesthetic/assets/design-story-template.md +135 -0
  61. package/.agent/skills/aesthetic/references/design-principles.md +62 -0
  62. package/.agent/skills/aesthetic/references/design-resources.md +75 -0
  63. package/.agent/skills/aesthetic/references/micro-interactions.md +53 -0
  64. package/.agent/skills/aesthetic/references/storytelling-design.md +50 -0
  65. package/.agent/skills/api-patterns/SKILL.md +81 -0
  66. package/.agent/skills/api-patterns/rules/api-style.md +42 -0
  67. package/.agent/skills/api-patterns/rules/auth.md +24 -0
  68. package/.agent/skills/api-patterns/rules/documentation.md +26 -0
  69. package/.agent/skills/api-patterns/rules/graphql.md +41 -0
  70. package/.agent/skills/api-patterns/rules/rate-limiting.md +31 -0
  71. package/.agent/skills/api-patterns/rules/response.md +37 -0
  72. package/.agent/skills/api-patterns/rules/rest.md +40 -0
  73. package/.agent/skills/api-patterns/rules/security-testing.md +122 -0
  74. package/.agent/skills/api-patterns/rules/trpc.md +41 -0
  75. package/.agent/skills/api-patterns/rules/versioning.md +22 -0
  76. package/.agent/skills/api-patterns/scripts/api_validator.py +211 -0
  77. package/.agent/skills/app-builder/SKILL.md +75 -0
  78. package/.agent/skills/app-builder/agent-coordination.md +71 -0
  79. package/.agent/skills/app-builder/feature-building.md +53 -0
  80. package/.agent/skills/app-builder/project-detection.md +34 -0
  81. package/.agent/skills/app-builder/scaffolding.md +118 -0
  82. package/.agent/skills/app-builder/tech-stack.md +40 -0
  83. package/.agent/skills/app-builder/templates/SKILL.md +39 -0
  84. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -0
  85. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -0
  86. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -0
  87. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -0
  88. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +83 -0
  89. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -0
  90. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -0
  91. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +82 -0
  92. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +100 -0
  93. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +106 -0
  94. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +101 -0
  95. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -0
  96. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +93 -0
  97. package/.agent/skills/architecture/SKILL.md +55 -0
  98. package/.agent/skills/architecture/context-discovery.md +43 -0
  99. package/.agent/skills/architecture/examples.md +94 -0
  100. package/.agent/skills/architecture/pattern-selection.md +68 -0
  101. package/.agent/skills/architecture/patterns-reference.md +50 -0
  102. package/.agent/skills/architecture/trade-off-analysis.md +77 -0
  103. package/.agent/skills/bash-linux/SKILL.md +199 -0
  104. package/.agent/skills/behavioral-modes/SKILL.md +242 -0
  105. package/.agent/skills/brainstorming/SKILL.md +163 -0
  106. package/.agent/skills/brainstorming/dynamic-questioning.md +350 -0
  107. package/.agent/skills/clean-code/SKILL.md +201 -0
  108. package/.agent/skills/code-review-checklist/SKILL.md +109 -0
  109. package/.agent/skills/code-reviewer/.skill-source.json +8 -0
  110. package/.agent/skills/code-reviewer/SKILL.md +32 -0
  111. package/.agent/skills/code-reviewer/enforcement/checklists/backend-api-review-checklist.md +5 -0
  112. package/.agent/skills/code-reviewer/examples/approved-pr/review-output.md +76 -0
  113. package/.agent/skills/code-reviewer/examples/rejected-pr/review-output.md +99 -0
  114. package/.agent/skills/code-reviewer/examples/scenarios.md +3 -0
  115. package/.agent/skills/code-reviewer/metadata/doctrine-mapping.yaml +167 -0
  116. package/.agent/skills/code-reviewer/metadata/intent-triggers.yaml +41 -0
  117. package/.agent/skills/code-reviewer/resources/links.md +59 -0
  118. package/.agent/skills/code-reviewer/scripts/audit_pr.js +8 -0
  119. package/.agent/skills/code-reviewer/scripts/audit_pr.v2.js +417 -0
  120. package/.agent/skills/code-reviewer/scripts/validate_doctrine.js +307 -0
  121. package/.agent/skills/context-engineering/SKILL.md +86 -0
  122. package/.agent/skills/context-engineering/references/context-compression.md +84 -0
  123. package/.agent/skills/context-engineering/references/context-degradation.md +93 -0
  124. package/.agent/skills/context-engineering/references/context-fundamentals.md +75 -0
  125. package/.agent/skills/context-engineering/references/context-optimization.md +82 -0
  126. package/.agent/skills/context-engineering/references/evaluation.md +89 -0
  127. package/.agent/skills/context-engineering/references/memory-systems.md +88 -0
  128. package/.agent/skills/context-engineering/references/multi-agent-patterns.md +90 -0
  129. package/.agent/skills/context-engineering/references/project-development.md +97 -0
  130. package/.agent/skills/context-engineering/references/tool-design.md +86 -0
  131. package/.agent/skills/context-engineering/scripts/compression_evaluator.py +329 -0
  132. package/.agent/skills/context-engineering/scripts/context_analyzer.py +294 -0
  133. package/.agent/skills/database-design/SKILL.md +52 -0
  134. package/.agent/skills/database-design/database-selection.md +43 -0
  135. package/.agent/skills/database-design/indexing.md +39 -0
  136. package/.agent/skills/database-design/migrations.md +48 -0
  137. package/.agent/skills/database-design/optimization.md +36 -0
  138. package/.agent/skills/database-design/orm-selection.md +30 -0
  139. package/.agent/skills/database-design/schema-design.md +56 -0
  140. package/.agent/skills/database-design/scripts/schema_validator.py +172 -0
  141. package/.agent/skills/debugging/SKILL.md +42 -0
  142. package/.agent/skills/debugging/defense-in-depth/SKILL.md +130 -0
  143. package/.agent/skills/debugging/root-cause-tracing/SKILL.md +177 -0
  144. package/.agent/skills/debugging/root-cause-tracing/find-polluter.sh +63 -0
  145. package/.agent/skills/debugging/verification-before-completion/SKILL.md +142 -0
  146. package/.agent/skills/deployment-procedures/SKILL.md +241 -0
  147. package/.agent/skills/doc.md +177 -0
  148. package/.agent/skills/document-skills/SKILL.md +49 -0
  149. package/.agent/skills/document-skills/docx/LICENSE.txt +30 -0
  150. package/.agent/skills/document-skills/docx/SKILL.md +197 -0
  151. package/.agent/skills/document-skills/docx/docx-js.md +350 -0
  152. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  153. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  154. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  155. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  156. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  157. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  158. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  159. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  160. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  161. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  162. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  163. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  164. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  165. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  166. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  167. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  168. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  169. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  170. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  171. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  172. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  173. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  174. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  175. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  176. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  177. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  178. package/.agent/skills/document-skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  179. package/.agent/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  180. package/.agent/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  181. package/.agent/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  182. package/.agent/skills/document-skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  183. package/.agent/skills/document-skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
  184. package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  185. package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  186. package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  187. package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  188. package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  189. package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  190. package/.agent/skills/document-skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  191. package/.agent/skills/document-skills/docx/ooxml/scripts/pack.py +159 -0
  192. package/.agent/skills/document-skills/docx/ooxml/scripts/unpack.py +29 -0
  193. package/.agent/skills/document-skills/docx/ooxml/scripts/validate.py +69 -0
  194. package/.agent/skills/document-skills/docx/ooxml/scripts/validation/__init__.py +15 -0
  195. package/.agent/skills/document-skills/docx/ooxml/scripts/validation/base.py +951 -0
  196. package/.agent/skills/document-skills/docx/ooxml/scripts/validation/docx.py +274 -0
  197. package/.agent/skills/document-skills/docx/ooxml/scripts/validation/pptx.py +315 -0
  198. package/.agent/skills/document-skills/docx/ooxml/scripts/validation/redlining.py +279 -0
  199. package/.agent/skills/document-skills/docx/ooxml.md +610 -0
  200. package/.agent/skills/document-skills/docx/scripts/__init__.py +1 -0
  201. package/.agent/skills/document-skills/docx/scripts/document.py +1276 -0
  202. package/.agent/skills/document-skills/docx/scripts/templates/comments.xml +3 -0
  203. package/.agent/skills/document-skills/docx/scripts/templates/commentsExtended.xml +3 -0
  204. package/.agent/skills/document-skills/docx/scripts/templates/commentsExtensible.xml +3 -0
  205. package/.agent/skills/document-skills/docx/scripts/templates/commentsIds.xml +3 -0
  206. package/.agent/skills/document-skills/docx/scripts/templates/people.xml +3 -0
  207. package/.agent/skills/document-skills/docx/scripts/utilities.py +374 -0
  208. package/.agent/skills/document-skills/pdf/LICENSE.txt +30 -0
  209. package/.agent/skills/document-skills/pdf/SKILL.md +294 -0
  210. package/.agent/skills/document-skills/pdf/forms.md +205 -0
  211. package/.agent/skills/document-skills/pdf/reference.md +612 -0
  212. package/.agent/skills/document-skills/pdf/scripts/check_bounding_boxes.py +70 -0
  213. package/.agent/skills/document-skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
  214. package/.agent/skills/document-skills/pdf/scripts/check_fillable_fields.py +12 -0
  215. package/.agent/skills/document-skills/pdf/scripts/convert_pdf_to_images.py +35 -0
  216. package/.agent/skills/document-skills/pdf/scripts/create_validation_image.py +41 -0
  217. package/.agent/skills/document-skills/pdf/scripts/extract_form_field_info.py +152 -0
  218. package/.agent/skills/document-skills/pdf/scripts/fill_fillable_fields.py +114 -0
  219. package/.agent/skills/document-skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
  220. package/.agent/skills/document-skills/pptx/LICENSE.txt +30 -0
  221. package/.agent/skills/document-skills/pptx/SKILL.md +484 -0
  222. package/.agent/skills/document-skills/pptx/html2pptx.md +625 -0
  223. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  224. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  225. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  226. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  227. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  228. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  229. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  230. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  231. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  232. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  233. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  234. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  235. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  236. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  237. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  238. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  239. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  240. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  241. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  242. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  243. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  244. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  245. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  246. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  247. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  248. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  249. package/.agent/skills/document-skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  250. package/.agent/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  251. package/.agent/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  252. package/.agent/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  253. package/.agent/skills/document-skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  254. package/.agent/skills/document-skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
  255. package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  256. package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  257. package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  258. package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  259. package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  260. package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  261. package/.agent/skills/document-skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  262. package/.agent/skills/document-skills/pptx/ooxml/scripts/pack.py +159 -0
  263. package/.agent/skills/document-skills/pptx/ooxml/scripts/unpack.py +29 -0
  264. package/.agent/skills/document-skills/pptx/ooxml/scripts/validate.py +69 -0
  265. package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
  266. package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/base.py +951 -0
  267. package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/docx.py +274 -0
  268. package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
  269. package/.agent/skills/document-skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
  270. package/.agent/skills/document-skills/pptx/ooxml.md +427 -0
  271. package/.agent/skills/document-skills/pptx/scripts/html2pptx.js +979 -0
  272. package/.agent/skills/document-skills/pptx/scripts/inventory.py +1020 -0
  273. package/.agent/skills/document-skills/pptx/scripts/rearrange.py +231 -0
  274. package/.agent/skills/document-skills/pptx/scripts/replace.py +385 -0
  275. package/.agent/skills/document-skills/pptx/scripts/thumbnail.py +450 -0
  276. package/.agent/skills/document-skills/xlsx/LICENSE.txt +30 -0
  277. package/.agent/skills/document-skills/xlsx/SKILL.md +289 -0
  278. package/.agent/skills/document-skills/xlsx/recalc.py +178 -0
  279. package/.agent/skills/documentation-templates/SKILL.md +194 -0
  280. package/.agent/skills/frontend/SKILL.md +38 -0
  281. package/.agent/skills/frontend/rules/_sections.md +46 -0
  282. package/.agent/skills/frontend/rules/_template.md +28 -0
  283. package/.agent/skills/frontend/rules/advanced-event-handler-refs.md +55 -0
  284. package/.agent/skills/frontend/rules/advanced-init-once.md +42 -0
  285. package/.agent/skills/frontend/rules/advanced-use-latest.md +39 -0
  286. package/.agent/skills/frontend/rules/async-api-routes.md +38 -0
  287. package/.agent/skills/frontend/rules/async-defer-await.md +80 -0
  288. package/.agent/skills/frontend/rules/async-dependencies.md +51 -0
  289. package/.agent/skills/frontend/rules/async-parallel.md +28 -0
  290. package/.agent/skills/frontend/rules/async-suspense-boundaries.md +99 -0
  291. package/.agent/skills/frontend/rules/bundle-barrel-imports.md +59 -0
  292. package/.agent/skills/frontend/rules/bundle-conditional.md +31 -0
  293. package/.agent/skills/frontend/rules/bundle-defer-third-party.md +49 -0
  294. package/.agent/skills/frontend/rules/bundle-dynamic-imports.md +35 -0
  295. package/.agent/skills/frontend/rules/bundle-preload.md +50 -0
  296. package/.agent/skills/frontend/rules/client-event-listeners.md +74 -0
  297. package/.agent/skills/frontend/rules/client-localstorage-schema.md +71 -0
  298. package/.agent/skills/frontend/rules/client-passive-event-listeners.md +48 -0
  299. package/.agent/skills/frontend/rules/client-swr-dedup.md +56 -0
  300. package/.agent/skills/frontend/rules/js-batch-dom-css.md +107 -0
  301. package/.agent/skills/frontend/rules/js-cache-function-results.md +80 -0
  302. package/.agent/skills/frontend/rules/js-cache-property-access.md +28 -0
  303. package/.agent/skills/frontend/rules/js-cache-storage.md +70 -0
  304. package/.agent/skills/frontend/rules/js-combine-iterations.md +32 -0
  305. package/.agent/skills/frontend/rules/js-early-exit.md +50 -0
  306. package/.agent/skills/frontend/rules/js-hoist-regexp.md +45 -0
  307. package/.agent/skills/frontend/rules/js-index-maps.md +37 -0
  308. package/.agent/skills/frontend/rules/js-length-check-first.md +49 -0
  309. package/.agent/skills/frontend/rules/js-min-max-loop.md +82 -0
  310. package/.agent/skills/frontend/rules/js-set-map-lookups.md +24 -0
  311. package/.agent/skills/frontend/rules/js-tosorted-immutable.md +57 -0
  312. package/.agent/skills/frontend/rules/rendering-activity.md +26 -0
  313. package/.agent/skills/frontend/rules/rendering-animate-svg-wrapper.md +47 -0
  314. package/.agent/skills/frontend/rules/rendering-conditional-render.md +40 -0
  315. package/.agent/skills/frontend/rules/rendering-content-visibility.md +38 -0
  316. package/.agent/skills/frontend/rules/rendering-hoist-jsx.md +46 -0
  317. package/.agent/skills/frontend/rules/rendering-hydration-no-flicker.md +82 -0
  318. package/.agent/skills/frontend/rules/rendering-hydration-suppress-warning.md +30 -0
  319. package/.agent/skills/frontend/rules/rendering-svg-precision.md +28 -0
  320. package/.agent/skills/frontend/rules/rendering-usetransition-loading.md +75 -0
  321. package/.agent/skills/frontend/rules/rerender-defer-reads.md +39 -0
  322. package/.agent/skills/frontend/rules/rerender-dependencies.md +45 -0
  323. package/.agent/skills/frontend/rules/rerender-derived-state-no-effect.md +40 -0
  324. package/.agent/skills/frontend/rules/rerender-derived-state.md +29 -0
  325. package/.agent/skills/frontend/rules/rerender-functional-setstate.md +74 -0
  326. package/.agent/skills/frontend/rules/rerender-lazy-state-init.md +58 -0
  327. package/.agent/skills/frontend/rules/rerender-memo-with-default-value.md +38 -0
  328. package/.agent/skills/frontend/rules/rerender-memo.md +44 -0
  329. package/.agent/skills/frontend/rules/rerender-move-effect-to-event.md +45 -0
  330. package/.agent/skills/frontend/rules/rerender-simple-expression-in-memo.md +35 -0
  331. package/.agent/skills/frontend/rules/rerender-transitions.md +40 -0
  332. package/.agent/skills/frontend/rules/rerender-use-ref-transient-values.md +73 -0
  333. package/.agent/skills/frontend/rules/schema.json +34 -0
  334. package/.agent/skills/frontend/rules/server-after-nonblocking.md +73 -0
  335. package/.agent/skills/frontend/rules/server-auth-actions.md +96 -0
  336. package/.agent/skills/frontend/rules/server-cache-lru.md +41 -0
  337. package/.agent/skills/frontend/rules/server-cache-react.md +76 -0
  338. package/.agent/skills/frontend/rules/server-dedup-props.md +65 -0
  339. package/.agent/skills/frontend/rules/server-parallel-fetching.md +83 -0
  340. package/.agent/skills/frontend/rules/server-serialization.md +38 -0
  341. package/.agent/skills/frontend-design/SKILL.md +33 -0
  342. package/.agent/skills/frontend-design/rules/animation-guide.md +331 -0
  343. package/.agent/skills/frontend-design/rules/color-system.md +311 -0
  344. package/.agent/skills/frontend-design/rules/decision-trees.md +418 -0
  345. package/.agent/skills/frontend-design/rules/motion-graphics.md +306 -0
  346. package/.agent/skills/frontend-design/rules/typography-system.md +345 -0
  347. package/.agent/skills/frontend-design/rules/ux-psychology.md +541 -0
  348. package/.agent/skills/frontend-design/rules/visual-effects.md +383 -0
  349. package/.agent/skills/frontend-design/scripts/accessibility_checker.py +183 -0
  350. package/.agent/skills/frontend-design/scripts/ux_audit.py +722 -0
  351. package/.agent/skills/game-development/2d-games/SKILL.md +119 -0
  352. package/.agent/skills/game-development/3d-games/SKILL.md +135 -0
  353. package/.agent/skills/game-development/SKILL.md +167 -0
  354. package/.agent/skills/game-development/game-art/SKILL.md +185 -0
  355. package/.agent/skills/game-development/game-audio/SKILL.md +190 -0
  356. package/.agent/skills/game-development/game-design/SKILL.md +129 -0
  357. package/.agent/skills/game-development/mobile-games/SKILL.md +108 -0
  358. package/.agent/skills/game-development/multiplayer/SKILL.md +132 -0
  359. package/.agent/skills/game-development/pc-games/SKILL.md +144 -0
  360. package/.agent/skills/game-development/vr-ar/SKILL.md +123 -0
  361. package/.agent/skills/game-development/web-games/SKILL.md +150 -0
  362. package/.agent/skills/geo-fundamentals/SKILL.md +156 -0
  363. package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +289 -0
  364. package/.agent/skills/git-conventions/.skill-source.json +8 -0
  365. package/.agent/skills/git-conventions/SKILL.md +28 -0
  366. package/.agent/skills/git-conventions/enforcement/commit-validation-rules.md +55 -0
  367. package/.agent/skills/git-conventions/examples/bad-commits.md +201 -0
  368. package/.agent/skills/git-conventions/examples/good-commits.md +135 -0
  369. package/.agent/skills/git-conventions/metadata/commit-config.yaml +79 -0
  370. package/.agent/skills/git-conventions/metadata/intent-triggers.yaml +25 -0
  371. package/.agent/skills/git-conventions/metadata/scope-mapping.yaml +83 -0
  372. package/.agent/skills/git-conventions/resources/BEST_PRACTICES.md +121 -0
  373. package/.agent/skills/git-conventions/resources/references.md +53 -0
  374. package/.agent/skills/git-conventions/scripts/format-commit.js +393 -0
  375. package/.agent/skills/git-conventions/scripts/validate-commit-msg.sh +27 -0
  376. package/.agent/skills/governance/.skill-source.json +8 -0
  377. package/.agent/skills/governance/CHANGELOG.md +222 -0
  378. package/.agent/skills/governance/README.md +250 -0
  379. package/.agent/skills/governance/SKILL.md +199 -0
  380. package/.agent/skills/governance/VERSION +4 -0
  381. package/.agent/skills/governance/examples/violation-backend-mutation/after.tsx +59 -0
  382. package/.agent/skills/governance/examples/violation-backend-mutation/before.tsx +42 -0
  383. package/.agent/skills/governance/examples/violation-backend-mutation/explanation.md +87 -0
  384. package/.agent/skills/governance/examples/violation-chart-injection/after.tsx +99 -0
  385. package/.agent/skills/governance/examples/violation-chart-injection/before.tsx +57 -0
  386. package/.agent/skills/governance/examples/violation-chart-injection/explanation.md +116 -0
  387. package/.agent/skills/governance/knowledge/lessons-learned.yaml +3 -0
  388. package/.agent/skills/governance/metadata/precedence.yaml +117 -0
  389. package/.agent/skills/governance/metadata/scope-map.yaml +156 -0
  390. package/.agent/skills/governance/proposals/v1.1-change-proposal-template.md +197 -0
  391. package/.agent/skills/governance/resources/AUTHORITY_MODEL.md +111 -0
  392. package/.agent/skills/governance/resources/ENFORCEMENT_GUIDE.md +242 -0
  393. package/.agent/skills/governance/resources/LOAD_ORDER.md +82 -0
  394. package/.agent/skills/governance/rules/constitution/coinpika-master-constitution.md +206 -0
  395. package/.agent/skills/governance/rules/doctrines/architecture/coinpika-architecture-doctrine.md +184 -0
  396. package/.agent/skills/governance/rules/doctrines/backend/coinpika-backend-data-engine-doctrine.md +214 -0
  397. package/.agent/skills/governance/rules/doctrines/commercial/coinpika-commercial-guardrails-doctrine.md +192 -0
  398. package/.agent/skills/governance/rules/doctrines/data/coinpika-chart-data-doctrine.md +198 -0
  399. package/.agent/skills/governance/rules/doctrines/frontend/coinpika-frontend-mobile-doctrine.md +165 -0
  400. package/.agent/skills/governance/rules/doctrines/frontend/coinpika-swipe-tabs-doctrine.md +172 -0
  401. package/.agent/skills/governance/rules/doctrines/learning/coinpika-learning-engine-doctrine.md +188 -0
  402. package/.agent/skills/governance/rules/doctrines/performance/coinpika-performance-doctrine.md +176 -0
  403. package/.agent/skills/governance/rules/doctrines/review/coinpika-code-review-doctrine.md +170 -0
  404. package/.agent/skills/governance/rules/enforcement/agents/coinpika-agent-enforcement-protocol.md +214 -0
  405. package/.agent/skills/governance/rules/enforcement/agents/coinpika-agent-system-prompt.md +192 -0
  406. package/.agent/skills/governance/rules/enforcement/checklists/backend-api-review-checklist.md +127 -0
  407. package/.agent/skills/governance/rules/enforcement/checklists/chart-component-review-checklist.md +143 -0
  408. package/.agent/skills/governance/rules/enforcement/checklists/coinpika-frontend-gesture-review-checklist.md +190 -0
  409. package/.agent/skills/governance/rules/enforcement/playbooks/doctrine-violation-playbook.md +232 -0
  410. package/.agent/skills/governance/scripts/audit_pr.js +218 -0
  411. package/.agent/skills/governance/scripts/learn.js +161 -0
  412. package/.agent/skills/governance/scripts/validate_doctrine.js +286 -0
  413. package/.agent/skills/i18n-localization/SKILL.md +154 -0
  414. package/.agent/skills/i18n-localization/scripts/i18n_checker.py +241 -0
  415. package/.agent/skills/intelligent-routing/SKILL.md +335 -0
  416. package/.agent/skills/lint-and-validate/SKILL.md +45 -0
  417. package/.agent/skills/lint-and-validate/scripts/lint_runner.py +172 -0
  418. package/.agent/skills/lint-and-validate/scripts/type_coverage.py +173 -0
  419. package/.agent/skills/mcp-builder/SKILL.md +176 -0
  420. package/.agent/skills/mermaidjs-v11/SKILL.md +115 -0
  421. package/.agent/skills/mermaidjs-v11/references/cli-usage.md +228 -0
  422. package/.agent/skills/mermaidjs-v11/references/configuration.md +232 -0
  423. package/.agent/skills/mermaidjs-v11/references/diagram-types.md +315 -0
  424. package/.agent/skills/mermaidjs-v11/references/examples.md +344 -0
  425. package/.agent/skills/mermaidjs-v11/references/integration.md +310 -0
  426. package/.agent/skills/mobile-design/SKILL.md +76 -0
  427. package/.agent/skills/mobile-design/references/anti-patterns.md +46 -0
  428. package/.agent/skills/mobile-design/references/decision-trees.md +516 -0
  429. package/.agent/skills/mobile-design/references/mobile-backend.md +491 -0
  430. package/.agent/skills/mobile-design/references/mobile-color-system.md +420 -0
  431. package/.agent/skills/mobile-design/references/mobile-debugging.md +122 -0
  432. package/.agent/skills/mobile-design/references/mobile-design-thinking.md +357 -0
  433. package/.agent/skills/mobile-design/references/mobile-navigation.md +458 -0
  434. package/.agent/skills/mobile-design/references/mobile-performance.md +767 -0
  435. package/.agent/skills/mobile-design/references/mobile-testing.md +356 -0
  436. package/.agent/skills/mobile-design/references/mobile-typography.md +433 -0
  437. package/.agent/skills/mobile-design/references/platform-android.md +666 -0
  438. package/.agent/skills/mobile-design/references/platform-ios.md +561 -0
  439. package/.agent/skills/mobile-design/references/touch-psychology.md +537 -0
  440. package/.agent/skills/mobile-design/scripts/mobile_audit.py +670 -0
  441. package/.agent/skills/nextjs-best-practices/SKILL.md +203 -0
  442. package/.agent/skills/nodejs-best-practices/SKILL.md +76 -0
  443. package/.agent/skills/nodejs-best-practices/references/architecture-patterns.md +34 -0
  444. package/.agent/skills/nodejs-best-practices/references/async-patterns.md +32 -0
  445. package/.agent/skills/nodejs-best-practices/references/error-handling.md +39 -0
  446. package/.agent/skills/nodejs-best-practices/references/framework-selection.md +39 -0
  447. package/.agent/skills/nodejs-best-practices/references/runtime-modules.md +33 -0
  448. package/.agent/skills/nodejs-best-practices/references/testing-strategy.md +25 -0
  449. package/.agent/skills/nodejs-best-practices/references/validation-security.md +45 -0
  450. package/.agent/skills/parallel-agents/SKILL.md +175 -0
  451. package/.agent/skills/performance-profiling/SKILL.md +143 -0
  452. package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +76 -0
  453. package/.agent/skills/plan-writing/SKILL.md +152 -0
  454. package/.agent/skills/powershell-windows/SKILL.md +167 -0
  455. package/.agent/skills/problem-solving/ABOUT.md +40 -0
  456. package/.agent/skills/problem-solving/SKILL.md +69 -0
  457. package/.agent/skills/problem-solving/collision-zone-thinking/SKILL.md +62 -0
  458. package/.agent/skills/problem-solving/inversion-exercise/SKILL.md +58 -0
  459. package/.agent/skills/problem-solving/meta-pattern-recognition/SKILL.md +54 -0
  460. package/.agent/skills/problem-solving/scale-game/SKILL.md +63 -0
  461. package/.agent/skills/problem-solving/simplification-cascades/SKILL.md +76 -0
  462. package/.agent/skills/problem-solving/when-stuck/SKILL.md +88 -0
  463. package/.agent/skills/python-patterns/SKILL.md +80 -0
  464. package/.agent/skills/python-patterns/references/async-patterns.md +57 -0
  465. package/.agent/skills/python-patterns/references/django-patterns.md +41 -0
  466. package/.agent/skills/python-patterns/references/fastapi-patterns.md +54 -0
  467. package/.agent/skills/python-patterns/references/framework-selection.md +39 -0
  468. package/.agent/skills/python-patterns/references/project-structure.md +80 -0
  469. package/.agent/skills/python-patterns/references/testing-patterns.md +34 -0
  470. package/.agent/skills/python-patterns/references/type-hints.md +51 -0
  471. package/.agent/skills/react-patterns/SKILL.md +198 -0
  472. package/.agent/skills/red-team-tactics/SKILL.md +199 -0
  473. package/.agent/skills/registry.json +367 -0
  474. package/.agent/skills/seo-fundamentals/SKILL.md +129 -0
  475. package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +219 -0
  476. package/.agent/skills/sequential-thinking/README.md +118 -0
  477. package/.agent/skills/sequential-thinking/SKILL.md +93 -0
  478. package/.agent/skills/sequential-thinking/references/advanced.md +122 -0
  479. package/.agent/skills/sequential-thinking/references/examples.md +274 -0
  480. package/.agent/skills/server-management/SKILL.md +161 -0
  481. package/.agent/skills/skill-creator/LICENSE.txt +202 -0
  482. package/.agent/skills/skill-creator/SKILL.md +237 -0
  483. package/.agent/skills/skill-creator/scripts/init_skill.py +303 -0
  484. package/.agent/skills/skill-creator/scripts/package_skill.py +110 -0
  485. package/.agent/skills/skill-creator/scripts/quick_validate.py +65 -0
  486. package/.agent/skills/systematic-debugging/SKILL.md +109 -0
  487. package/.agent/skills/tailwind-patterns/SKILL.md +269 -0
  488. package/.agent/skills/tdd-workflow/SKILL.md +149 -0
  489. package/.agent/skills/testing-patterns/SKILL.md +178 -0
  490. package/.agent/skills/testing-patterns/scripts/test_runner.py +219 -0
  491. package/.agent/skills/vulnerability-scanner/SKILL.md +276 -0
  492. package/.agent/skills/vulnerability-scanner/checklists.md +121 -0
  493. package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +458 -0
  494. package/.agent/skills/webapp-testing/SKILL.md +187 -0
  495. package/.agent/skills/webapp-testing/scripts/playwright_runner.py +173 -0
  496. package/.agent/workflows/architect.md +200 -0
  497. package/.agent/workflows/autopilot.md +254 -0
  498. package/.agent/workflows/boost.md +163 -0
  499. package/.agent/workflows/build.md +192 -0
  500. package/.agent/workflows/chronicle.md +172 -0
  501. package/.agent/workflows/diagnose.md +207 -0
  502. package/.agent/workflows/forge.md +123 -0
  503. package/.agent/workflows/inspect.md +187 -0
  504. package/.agent/workflows/launch.md +208 -0
  505. package/.agent/workflows/pulse.md +115 -0
  506. package/.agent/workflows/stage.md +117 -0
  507. package/.agent/workflows/studio.md +319 -0
  508. package/.agent/workflows/think.md +173 -0
  509. package/.agent/workflows/validate.md +226 -0
  510. package/.editorconfig +21 -0
  511. package/.github/workflows/release.yml +39 -0
  512. package/CHANGELOG.md +38 -0
  513. package/LICENSE +16 -0
  514. package/README.md +294 -0
  515. package/VERSIONING.md +45 -0
  516. package/docs/PATTERNS_REFERENCE.md +93 -0
  517. package/docs/PLAN-consolidation-final.md +14 -0
  518. package/docs/PLAN-integration.md +28 -0
  519. package/docs/PLAN-rebrand-agent-skills-kit.md +104 -0
  520. package/docs/PLAN-refactor.md +48 -0
  521. package/docs/PYTHON_SCRIPTS.md +55 -0
  522. package/docs/awf-user-guide.md +436 -0
  523. package/docs/context-engineering-guide.md +99 -0
  524. package/package.json +38 -0
  525. package/packages/cli/.agent/knowledge/lessons-learned.yaml +32 -0
  526. package/packages/cli/bin/ag-smart.js +155 -0
  527. package/packages/cli/bin/ag-smart.v1.js +78 -0
  528. package/packages/cli/lib/audit.js +69 -0
  529. package/packages/cli/lib/audit.v2.js +151 -0
  530. package/packages/cli/lib/auto-learn.js +319 -0
  531. package/packages/cli/lib/auto_preview.py +148 -0
  532. package/packages/cli/lib/checklist.py +222 -0
  533. package/packages/cli/lib/config.js +29 -0
  534. package/packages/cli/lib/eslint-fix.js +238 -0
  535. package/packages/cli/lib/fix.js +278 -0
  536. package/packages/cli/lib/generate-registry.js +42 -0
  537. package/packages/cli/lib/hooks/install-hooks.js +176 -0
  538. package/packages/cli/lib/hooks/lint-learn.js +172 -0
  539. package/packages/cli/lib/learn.js +173 -0
  540. package/packages/cli/lib/learn.test.js +70 -0
  541. package/packages/cli/lib/learn.v2.js +255 -0
  542. package/packages/cli/lib/recall.js +75 -0
  543. package/packages/cli/lib/recall.v2.js +252 -0
  544. package/packages/cli/lib/session_manager.py +120 -0
  545. package/packages/cli/lib/skill-learn.js +296 -0
  546. package/packages/cli/lib/stats.js +143 -0
  547. package/packages/cli/lib/types.js +33 -0
  548. package/packages/cli/lib/verify_all.py +327 -0
  549. package/packages/cli/lib/watcher.js +181 -0
  550. package/packages/cli/package-lock.json +1837 -0
  551. package/packages/cli/package.json +23 -0
  552. package/packages/cli/vitest.config.js +9 -0
@@ -0,0 +1,458 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Skill: vulnerability-scanner
4
+ Script: security_scan.py
5
+ Purpose: Validate that security principles from SKILL.md are applied correctly
6
+ Usage: python security_scan.py <project_path> [--scan-type all|deps|secrets|patterns|config]
7
+ Output: JSON with validation findings
8
+
9
+ This script verifies:
10
+ 1. Dependencies - Supply chain security (OWASP A03)
11
+ 2. Secrets - No hardcoded credentials (OWASP A04)
12
+ 3. Code Patterns - Dangerous patterns identified (OWASP A05)
13
+ 4. Configuration - Security settings validated (OWASP A02)
14
+ """
15
+ import subprocess
16
+ import json
17
+ import os
18
+ import sys
19
+ import re
20
+ import argparse
21
+ from pathlib import Path
22
+ from typing import Dict, List, Any
23
+ from datetime import datetime
24
+
25
+ # Fix Windows console encoding for Unicode output
26
+ try:
27
+ sys.stdout.reconfigure(encoding='utf-8', errors='replace')
28
+ sys.stderr.reconfigure(encoding='utf-8', errors='replace')
29
+ except AttributeError:
30
+ pass # Python < 3.7
31
+
32
+
33
+ # ============================================================================
34
+ # CONFIGURATION
35
+ # ============================================================================
36
+
37
+ SECRET_PATTERNS = [
38
+ # API Keys & Tokens
39
+ (r'api[_-]?key\s*[=:]\s*["\'][^"\']{10,}["\']', "API Key", "high"),
40
+ (r'token\s*[=:]\s*["\'][^"\']{10,}["\']', "Token", "high"),
41
+ (r'bearer\s+[a-zA-Z0-9\-_.]+', "Bearer Token", "critical"),
42
+
43
+ # Cloud Credentials
44
+ (r'AKIA[0-9A-Z]{16}', "AWS Access Key", "critical"),
45
+ (r'aws[_-]?secret[_-]?access[_-]?key\s*[=:]\s*["\'][^"\']+["\']', "AWS Secret", "critical"),
46
+ (r'AZURE[_-]?[A-Z_]+\s*[=:]\s*["\'][^"\']+["\']', "Azure Credential", "critical"),
47
+ (r'GOOGLE[_-]?[A-Z_]+\s*[=:]\s*["\'][^"\']+["\']', "GCP Credential", "critical"),
48
+
49
+ # Database & Connections
50
+ (r'password\s*[=:]\s*["\'][^"\']{4,}["\']', "Password", "high"),
51
+ (r'(mongodb|postgres|mysql|redis):\/\/[^\s"\']+', "Database Connection String", "critical"),
52
+
53
+ # Private Keys
54
+ (r'-----BEGIN\s+(RSA|PRIVATE|EC)\s+KEY-----', "Private Key", "critical"),
55
+ (r'ssh-rsa\s+[A-Za-z0-9+/]+', "SSH Key", "critical"),
56
+
57
+ # JWT
58
+ (r'eyJ[A-Za-z0-9-_]+\.eyJ[A-Za-z0-9-_]+\.[A-Za-z0-9-_]+', "JWT Token", "high"),
59
+ ]
60
+
61
+ DANGEROUS_PATTERNS = [
62
+ # Injection risks
63
+ (r'eval\s*\(', "eval() usage", "critical", "Code Injection risk"),
64
+ (r'exec\s*\(', "exec() usage", "critical", "Code Injection risk"),
65
+ (r'new\s+Function\s*\(', "Function constructor", "high", "Code Injection risk"),
66
+ (r'child_process\.exec\s*\(', "child_process.exec", "high", "Command Injection risk"),
67
+ (r'subprocess\.call\s*\([^)]*shell\s*=\s*True', "subprocess with shell=True", "high", "Command Injection risk"),
68
+
69
+ # XSS risks
70
+ (r'dangerouslySetInnerHTML', "dangerouslySetInnerHTML", "high", "XSS risk"),
71
+ (r'\.innerHTML\s*=', "innerHTML assignment", "medium", "XSS risk"),
72
+ (r'document\.write\s*\(', "document.write", "medium", "XSS risk"),
73
+
74
+ # SQL Injection indicators
75
+ (r'["\'][^"\']*\+\s*[a-zA-Z_]+\s*\+\s*["\'].*(?:SELECT|INSERT|UPDATE|DELETE)', "SQL String Concat", "critical", "SQL Injection risk"),
76
+ (r'f"[^"]*(?:SELECT|INSERT|UPDATE|DELETE)[^"]*\{', "SQL f-string", "critical", "SQL Injection risk"),
77
+
78
+ # Insecure configurations
79
+ (r'verify\s*=\s*False', "SSL Verify Disabled", "high", "MITM risk"),
80
+ (r'--insecure', "Insecure flag", "medium", "Security disabled"),
81
+ (r'disable[_-]?ssl', "SSL Disabled", "high", "MITM risk"),
82
+
83
+ # Unsafe deserialization
84
+ (r'pickle\.loads?\s*\(', "pickle usage", "high", "Deserialization risk"),
85
+ (r'yaml\.load\s*\([^)]*\)(?!\s*,\s*Loader)', "Unsafe YAML load", "high", "Deserialization risk"),
86
+ ]
87
+
88
+ SKIP_DIRS = {'node_modules', '.git', 'dist', 'build', '__pycache__', '.venv', 'venv', '.next'}
89
+ CODE_EXTENSIONS = {'.js', '.ts', '.jsx', '.tsx', '.py', '.go', '.java', '.rb', '.php'}
90
+ CONFIG_EXTENSIONS = {'.json', '.yaml', '.yml', '.toml', '.env', '.env.local', '.env.development'}
91
+
92
+
93
+ # ============================================================================
94
+ # SCANNING FUNCTIONS
95
+ # ============================================================================
96
+
97
+ def scan_dependencies(project_path: str) -> Dict[str, Any]:
98
+ """
99
+ Validate supply chain security (OWASP A03).
100
+ Checks: npm audit, lock file presence, dependency age.
101
+ """
102
+ results = {"tool": "dependency_scanner", "findings": [], "status": "[OK] Secure"}
103
+
104
+ # Check for lock files
105
+ lock_files = {
106
+ "npm": ["package-lock.json", "npm-shrinkwrap.json"],
107
+ "yarn": ["yarn.lock"],
108
+ "pnpm": ["pnpm-lock.yaml"],
109
+ "pip": ["requirements.txt", "Pipfile.lock", "poetry.lock"],
110
+ }
111
+
112
+ found_locks = []
113
+ missing_locks = []
114
+
115
+ for manager, files in lock_files.items():
116
+ pkg_file = "package.json" if manager in ["npm", "yarn", "pnpm"] else "setup.py"
117
+ pkg_path = Path(project_path) / pkg_file
118
+
119
+ if pkg_path.exists() or (manager == "pip" and (Path(project_path) / "requirements.txt").exists()):
120
+ has_lock = any((Path(project_path) / f).exists() for f in files)
121
+ if has_lock:
122
+ found_locks.append(manager)
123
+ else:
124
+ missing_locks.append(manager)
125
+ results["findings"].append({
126
+ "type": "Missing Lock File",
127
+ "severity": "high",
128
+ "message": f"{manager}: No lock file found. Supply chain integrity at risk."
129
+ })
130
+
131
+ # Run npm audit if applicable
132
+ if (Path(project_path) / "package.json").exists():
133
+ try:
134
+ result = subprocess.run(
135
+ ["npm", "audit", "--json"],
136
+ cwd=project_path,
137
+ capture_output=True,
138
+ text=True,
139
+ timeout=60
140
+ )
141
+
142
+ try:
143
+ audit_data = json.loads(result.stdout)
144
+ vulnerabilities = audit_data.get("vulnerabilities", {})
145
+
146
+ severity_count = {"critical": 0, "high": 0, "moderate": 0, "low": 0}
147
+ for vuln in vulnerabilities.values():
148
+ sev = vuln.get("severity", "low").lower()
149
+ if sev in severity_count:
150
+ severity_count[sev] += 1
151
+
152
+ if severity_count["critical"] > 0:
153
+ results["status"] = "[!!] Critical vulnerabilities"
154
+ results["findings"].append({
155
+ "type": "npm audit",
156
+ "severity": "critical",
157
+ "message": f"{severity_count['critical']} critical vulnerabilities in dependencies"
158
+ })
159
+ elif severity_count["high"] > 0:
160
+ results["status"] = "[!] High vulnerabilities"
161
+ results["findings"].append({
162
+ "type": "npm audit",
163
+ "severity": "high",
164
+ "message": f"{severity_count['high']} high severity vulnerabilities"
165
+ })
166
+
167
+ results["npm_audit"] = severity_count
168
+
169
+ except json.JSONDecodeError:
170
+ pass
171
+
172
+ except (FileNotFoundError, subprocess.TimeoutExpired):
173
+ pass
174
+
175
+ if not results["findings"]:
176
+ results["status"] = "[OK] Supply chain checks passed"
177
+
178
+ return results
179
+
180
+
181
+ def scan_secrets(project_path: str) -> Dict[str, Any]:
182
+ """
183
+ Validate no hardcoded secrets (OWASP A04).
184
+ Checks: API keys, tokens, passwords, cloud credentials.
185
+ """
186
+ results = {
187
+ "tool": "secret_scanner",
188
+ "findings": [],
189
+ "status": "[OK] No secrets detected",
190
+ "scanned_files": 0,
191
+ "by_severity": {"critical": 0, "high": 0, "medium": 0}
192
+ }
193
+
194
+ for root, dirs, files in os.walk(project_path):
195
+ dirs[:] = [d for d in dirs if d not in SKIP_DIRS]
196
+
197
+ for file in files:
198
+ ext = Path(file).suffix.lower()
199
+ if ext not in CODE_EXTENSIONS and ext not in CONFIG_EXTENSIONS:
200
+ continue
201
+
202
+ filepath = Path(root) / file
203
+ results["scanned_files"] += 1
204
+
205
+ try:
206
+ with open(filepath, 'r', encoding='utf-8', errors='ignore') as f:
207
+ content = f.read()
208
+
209
+ for pattern, secret_type, severity in SECRET_PATTERNS:
210
+ matches = re.findall(pattern, content, re.IGNORECASE)
211
+ if matches:
212
+ results["findings"].append({
213
+ "file": str(filepath.relative_to(project_path)),
214
+ "type": secret_type,
215
+ "severity": severity,
216
+ "count": len(matches)
217
+ })
218
+ results["by_severity"][severity] += len(matches)
219
+
220
+ except Exception:
221
+ pass
222
+
223
+ if results["by_severity"]["critical"] > 0:
224
+ results["status"] = "[!!] CRITICAL: Secrets exposed!"
225
+ elif results["by_severity"]["high"] > 0:
226
+ results["status"] = "[!] HIGH: Secrets found"
227
+ elif sum(results["by_severity"].values()) > 0:
228
+ results["status"] = "[?] Potential secrets detected"
229
+
230
+ # Limit findings for output
231
+ results["findings"] = results["findings"][:15]
232
+
233
+ return results
234
+
235
+
236
+ def scan_code_patterns(project_path: str) -> Dict[str, Any]:
237
+ """
238
+ Validate dangerous code patterns (OWASP A05).
239
+ Checks: Injection risks, XSS, unsafe deserialization.
240
+ """
241
+ results = {
242
+ "tool": "pattern_scanner",
243
+ "findings": [],
244
+ "status": "[OK] No dangerous patterns",
245
+ "scanned_files": 0,
246
+ "by_category": {}
247
+ }
248
+
249
+ for root, dirs, files in os.walk(project_path):
250
+ dirs[:] = [d for d in dirs if d not in SKIP_DIRS]
251
+
252
+ for file in files:
253
+ ext = Path(file).suffix.lower()
254
+ if ext not in CODE_EXTENSIONS:
255
+ continue
256
+
257
+ filepath = Path(root) / file
258
+ results["scanned_files"] += 1
259
+
260
+ try:
261
+ with open(filepath, 'r', encoding='utf-8', errors='ignore') as f:
262
+ lines = f.readlines()
263
+
264
+ for line_num, line in enumerate(lines, 1):
265
+ for pattern, name, severity, category in DANGEROUS_PATTERNS:
266
+ if re.search(pattern, line, re.IGNORECASE):
267
+ results["findings"].append({
268
+ "file": str(filepath.relative_to(project_path)),
269
+ "line": line_num,
270
+ "pattern": name,
271
+ "severity": severity,
272
+ "category": category,
273
+ "snippet": line.strip()[:80]
274
+ })
275
+ results["by_category"][category] = results["by_category"].get(category, 0) + 1
276
+
277
+ except Exception:
278
+ pass
279
+
280
+ critical_count = sum(1 for f in results["findings"] if f["severity"] == "critical")
281
+ high_count = sum(1 for f in results["findings"] if f["severity"] == "high")
282
+
283
+ if critical_count > 0:
284
+ results["status"] = f"[!!] CRITICAL: {critical_count} dangerous patterns"
285
+ elif high_count > 0:
286
+ results["status"] = f"[!] HIGH: {high_count} risky patterns"
287
+ elif results["findings"]:
288
+ results["status"] = "[?] Some patterns need review"
289
+
290
+ # Limit findings
291
+ results["findings"] = results["findings"][:20]
292
+
293
+ return results
294
+
295
+
296
+ def scan_configuration(project_path: str) -> Dict[str, Any]:
297
+ """
298
+ Validate security configuration (OWASP A02).
299
+ Checks: Security headers, CORS, debug modes.
300
+ """
301
+ results = {
302
+ "tool": "config_scanner",
303
+ "findings": [],
304
+ "status": "[OK] Configuration secure",
305
+ "checks": {}
306
+ }
307
+
308
+ # Check common config files for issues
309
+ config_issues = [
310
+ (r'"DEBUG"\s*:\s*true', "Debug mode enabled", "high"),
311
+ (r'debug\s*=\s*True', "Debug mode enabled", "high"),
312
+ (r'NODE_ENV.*development', "Development mode in config", "medium"),
313
+ (r'"CORS_ALLOW_ALL".*true', "CORS allow all origins", "high"),
314
+ (r'"Access-Control-Allow-Origin".*\*', "CORS wildcard", "high"),
315
+ (r'allowCredentials.*true.*origin.*\*', "Dangerous CORS combo", "critical"),
316
+ ]
317
+
318
+ for root, dirs, files in os.walk(project_path):
319
+ dirs[:] = [d for d in dirs if d not in SKIP_DIRS]
320
+
321
+ for file in files:
322
+ ext = Path(file).suffix.lower()
323
+ if ext not in CONFIG_EXTENSIONS and file not in ['next.config.js', 'webpack.config.js', '.eslintrc.js']:
324
+ continue
325
+
326
+ filepath = Path(root) / file
327
+
328
+ try:
329
+ with open(filepath, 'r', encoding='utf-8', errors='ignore') as f:
330
+ content = f.read()
331
+
332
+ for pattern, issue, severity in config_issues:
333
+ if re.search(pattern, content, re.IGNORECASE):
334
+ results["findings"].append({
335
+ "file": str(filepath.relative_to(project_path)),
336
+ "issue": issue,
337
+ "severity": severity
338
+ })
339
+
340
+ except Exception:
341
+ pass
342
+
343
+ # Check for security header configurations
344
+ header_files = ["next.config.js", "next.config.mjs", "middleware.ts", "nginx.conf"]
345
+ for hf in header_files:
346
+ hf_path = Path(project_path) / hf
347
+ if hf_path.exists():
348
+ results["checks"]["security_headers_config"] = True
349
+ break
350
+ else:
351
+ results["checks"]["security_headers_config"] = False
352
+ results["findings"].append({
353
+ "issue": "No security headers configuration found",
354
+ "severity": "medium",
355
+ "recommendation": "Configure CSP, HSTS, X-Frame-Options headers"
356
+ })
357
+
358
+ if any(f["severity"] == "critical" for f in results["findings"]):
359
+ results["status"] = "[!!] CRITICAL: Configuration issues"
360
+ elif any(f["severity"] == "high" for f in results["findings"]):
361
+ results["status"] = "[!] HIGH: Configuration review needed"
362
+ elif results["findings"]:
363
+ results["status"] = "[?] Minor configuration issues"
364
+
365
+ return results
366
+
367
+
368
+ # ============================================================================
369
+ # MAIN
370
+ # ============================================================================
371
+
372
+ def run_full_scan(project_path: str, scan_type: str = "all") -> Dict[str, Any]:
373
+ """Execute security validation scans."""
374
+
375
+ report = {
376
+ "project": project_path,
377
+ "timestamp": datetime.now().isoformat(),
378
+ "scan_type": scan_type,
379
+ "scans": {},
380
+ "summary": {
381
+ "total_findings": 0,
382
+ "critical": 0,
383
+ "high": 0,
384
+ "overall_status": "[OK] SECURE"
385
+ }
386
+ }
387
+
388
+ scanners = {
389
+ "deps": ("dependencies", scan_dependencies),
390
+ "secrets": ("secrets", scan_secrets),
391
+ "patterns": ("code_patterns", scan_code_patterns),
392
+ "config": ("configuration", scan_configuration),
393
+ }
394
+
395
+ for key, (name, scanner) in scanners.items():
396
+ if scan_type == "all" or scan_type == key:
397
+ result = scanner(project_path)
398
+ report["scans"][name] = result
399
+
400
+ findings_count = len(result.get("findings", []))
401
+ report["summary"]["total_findings"] += findings_count
402
+
403
+ for finding in result.get("findings", []):
404
+ sev = finding.get("severity", "low")
405
+ if sev == "critical":
406
+ report["summary"]["critical"] += 1
407
+ elif sev == "high":
408
+ report["summary"]["high"] += 1
409
+
410
+ # Determine overall status
411
+ if report["summary"]["critical"] > 0:
412
+ report["summary"]["overall_status"] = "[!!] CRITICAL ISSUES FOUND"
413
+ elif report["summary"]["high"] > 0:
414
+ report["summary"]["overall_status"] = "[!] HIGH RISK ISSUES"
415
+ elif report["summary"]["total_findings"] > 0:
416
+ report["summary"]["overall_status"] = "[?] REVIEW RECOMMENDED"
417
+
418
+ return report
419
+
420
+
421
+ def main():
422
+ parser = argparse.ArgumentParser(
423
+ description="Validate security principles from vulnerability-scanner skill"
424
+ )
425
+ parser.add_argument("project_path", nargs="?", default=".", help="Project directory to scan")
426
+ parser.add_argument("--scan-type", choices=["all", "deps", "secrets", "patterns", "config"],
427
+ default="all", help="Type of scan to run")
428
+ parser.add_argument("--output", choices=["json", "summary"], default="json",
429
+ help="Output format")
430
+
431
+ args = parser.parse_args()
432
+
433
+ if not os.path.isdir(args.project_path):
434
+ print(json.dumps({"error": f"Directory not found: {args.project_path}"}))
435
+ sys.exit(1)
436
+
437
+ result = run_full_scan(args.project_path, args.scan_type)
438
+
439
+ if args.output == "summary":
440
+ print(f"\n{'='*60}")
441
+ print(f"Security Scan: {result['project']}")
442
+ print(f"{'='*60}")
443
+ print(f"Status: {result['summary']['overall_status']}")
444
+ print(f"Total Findings: {result['summary']['total_findings']}")
445
+ print(f" Critical: {result['summary']['critical']}")
446
+ print(f" High: {result['summary']['high']}")
447
+ print(f"{'='*60}\n")
448
+
449
+ for scan_name, scan_result in result['scans'].items():
450
+ print(f"\n{scan_name.upper()}: {scan_result['status']}")
451
+ for finding in scan_result.get('findings', [])[:5]:
452
+ print(f" - {finding}")
453
+ else:
454
+ print(json.dumps(result, indent=2))
455
+
456
+
457
+ if __name__ == "__main__":
458
+ main()
@@ -0,0 +1,187 @@
1
+ ---
2
+ name: webapp-testing
3
+ description: Web application testing principles. E2E, Playwright, deep audit strategies.
4
+ allowed-tools: Read, Write, Edit, Glob, Grep, Bash
5
+ ---
6
+
7
+ # Web App Testing
8
+
9
+ > Discover and test everything. Leave no route untested.
10
+
11
+ ## 🔧 Runtime Scripts
12
+
13
+ **Execute these for automated browser testing:**
14
+
15
+ | Script | Purpose | Usage |
16
+ |--------|---------|-------|
17
+ | `scripts/playwright_runner.py` | Basic browser test | `python scripts/playwright_runner.py https://example.com` |
18
+ | | With screenshot | `python scripts/playwright_runner.py <url> --screenshot` |
19
+ | | Accessibility check | `python scripts/playwright_runner.py <url> --a11y` |
20
+
21
+ **Requires:** `pip install playwright && playwright install chromium`
22
+
23
+ ---
24
+
25
+ ## 1. Deep Audit Approach
26
+
27
+ ### Discovery First
28
+
29
+ | Target | How to Find |
30
+ |--------|-------------|
31
+ | Routes | Scan app/, pages/, router files |
32
+ | API endpoints | Grep for HTTP methods |
33
+ | Components | Find component directories |
34
+ | Features | Read documentation |
35
+
36
+ ### Systematic Testing
37
+
38
+ 1. **Map** - List all routes/APIs
39
+ 2. **Scan** - Verify they respond
40
+ 3. **Test** - Cover critical paths
41
+
42
+ ---
43
+
44
+ ## 2. Testing Pyramid for Web
45
+
46
+ ```
47
+ /\ E2E (Few)
48
+ / \ Critical user flows
49
+ /----\
50
+ / \ Integration (Some)
51
+ /--------\ API, data flow
52
+ / \
53
+ /------------\ Component (Many)
54
+ Individual UI pieces
55
+ ```
56
+
57
+ ---
58
+
59
+ ## 3. E2E Test Principles
60
+
61
+ ### What to Test
62
+
63
+ | Priority | Tests |
64
+ |----------|-------|
65
+ | 1 | Happy path user flows |
66
+ | 2 | Authentication flows |
67
+ | 3 | Critical business actions |
68
+ | 4 | Error handling |
69
+
70
+ ### E2E Best Practices
71
+
72
+ | Practice | Why |
73
+ |----------|-----|
74
+ | Use data-testid | Stable selectors |
75
+ | Wait for elements | Avoid flaky tests |
76
+ | Clean state | Independent tests |
77
+ | Avoid implementation details | Test user behavior |
78
+
79
+ ---
80
+
81
+ ## 4. Playwright Principles
82
+
83
+ ### Core Concepts
84
+
85
+ | Concept | Use |
86
+ |---------|-----|
87
+ | Page Object Model | Encapsulate page logic |
88
+ | Fixtures | Reusable test setup |
89
+ | Assertions | Built-in auto-wait |
90
+ | Trace Viewer | Debug failures |
91
+
92
+ ### Configuration
93
+
94
+ | Setting | Recommendation |
95
+ |---------|----------------|
96
+ | Retries | 2 on CI |
97
+ | Trace | on-first-retry |
98
+ | Screenshots | on-failure |
99
+ | Video | retain-on-failure |
100
+
101
+ ---
102
+
103
+ ## 5. Visual Testing
104
+
105
+ ### When to Use
106
+
107
+ | Scenario | Value |
108
+ |----------|-------|
109
+ | Design system | High |
110
+ | Marketing pages | High |
111
+ | Component library | Medium |
112
+ | Dynamic content | Lower |
113
+
114
+ ### Strategy
115
+
116
+ - Baseline screenshots
117
+ - Compare on changes
118
+ - Review visual diffs
119
+ - Update intentional changes
120
+
121
+ ---
122
+
123
+ ## 6. API Testing Principles
124
+
125
+ ### Coverage Areas
126
+
127
+ | Area | Tests |
128
+ |------|-------|
129
+ | Status codes | 200, 400, 404, 500 |
130
+ | Response shape | Matches schema |
131
+ | Error messages | User-friendly |
132
+ | Edge cases | Empty, large, special chars |
133
+
134
+ ---
135
+
136
+ ## 7. Test Organization
137
+
138
+ ### File Structure
139
+
140
+ ```
141
+ tests/
142
+ ├── e2e/ # Full user flows
143
+ ├── integration/ # API, data
144
+ ├── component/ # UI units
145
+ └── fixtures/ # Shared data
146
+ ```
147
+
148
+ ### Naming Convention
149
+
150
+ | Pattern | Example |
151
+ |---------|---------|
152
+ | Feature-based | `login.spec.ts` |
153
+ | Descriptive | `user-can-checkout.spec.ts` |
154
+
155
+ ---
156
+
157
+ ## 8. CI Integration
158
+
159
+ ### Pipeline Steps
160
+
161
+ 1. Install dependencies
162
+ 2. Install browsers
163
+ 3. Run tests
164
+ 4. Upload artifacts (traces, screenshots)
165
+
166
+ ### Parallelization
167
+
168
+ | Strategy | Use |
169
+ |----------|-----|
170
+ | Per file | Playwright default |
171
+ | Sharding | Large suites |
172
+ | Workers | Multiple browsers |
173
+
174
+ ---
175
+
176
+ ## 9. Anti-Patterns
177
+
178
+ | ❌ Don't | ✅ Do |
179
+ |----------|-------|
180
+ | Test implementation | Test behavior |
181
+ | Hardcode waits | Use auto-wait |
182
+ | Skip cleanup | Isolate tests |
183
+ | Ignore flaky tests | Fix root cause |
184
+
185
+ ---
186
+
187
+ > **Remember:** E2E tests are expensive. Use them for critical paths only.