xtrm-tools 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (447) hide show
  1. package/CHANGELOG.md +496 -0
  2. package/README.md +762 -0
  3. package/cli/dist/index.cjs +55245 -0
  4. package/cli/dist/index.cjs.map +1 -0
  5. package/cli/dist/index.d.cts +2 -0
  6. package/cli/package.json +43 -0
  7. package/config/.env.example +40 -0
  8. package/config/hooks.json +36 -0
  9. package/config/mcp_servers.json +46 -0
  10. package/config/mcp_servers_optional.json +53 -0
  11. package/config/settings.json +70 -0
  12. package/hooks/README.md +156 -0
  13. package/hooks/__pycache__/agent_context.cpython-314.pyc +0 -0
  14. package/hooks/agent_context.py +105 -0
  15. package/hooks/gitnexus/gitnexus-hook.cjs +133 -0
  16. package/hooks/serena-workflow-reminder.py +74 -0
  17. package/hooks/skill-discovery.py +90 -0
  18. package/hooks/skill-suggestion.py +112 -0
  19. package/hooks/test_agent_context.py +112 -0
  20. package/hooks/type-safety-enforcement.py +107 -0
  21. package/package.json +48 -0
  22. package/project-skills/main-guard/.claude/hooks/main-guard.cjs +188 -0
  23. package/project-skills/main-guard/.claude/settings.json +16 -0
  24. package/project-skills/main-guard/.claude/skills/using-main-guard/SKILL.md +135 -0
  25. package/project-skills/main-guard/README.md +163 -0
  26. package/project-skills/py-quality-gate/.claude/hooks/quality-check.py +311 -0
  27. package/project-skills/py-quality-gate/.claude/settings.json +16 -0
  28. package/project-skills/py-quality-gate/.claude/skills/using-py-quality-gate/SKILL.md +112 -0
  29. package/project-skills/py-quality-gate/README.md +147 -0
  30. package/project-skills/service-skills-set/.claude/git-hooks/__pycache__/doc_reminder.cpython-314.pyc +0 -0
  31. package/project-skills/service-skills-set/.claude/git-hooks/__pycache__/skill_staleness.cpython-314.pyc +0 -0
  32. package/project-skills/service-skills-set/.claude/git-hooks/doc_reminder.py +67 -0
  33. package/project-skills/service-skills-set/.claude/git-hooks/skill_staleness.py +194 -0
  34. package/project-skills/service-skills-set/.claude/service-registry.json +4 -0
  35. package/project-skills/service-skills-set/.claude/settings.json +37 -0
  36. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/SKILL.md +433 -0
  37. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/script_quality_standards.md +412 -0
  38. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/service_skill_system_guide.md +264 -0
  39. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/bootstrap.py +308 -0
  40. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/deep_dive.py +304 -0
  41. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/scaffolder.py +482 -0
  42. package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/SKILL.md +231 -0
  43. package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/scripts/scope.py +74 -0
  44. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/SKILL.md +136 -0
  45. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/scripts/__pycache__/drift_detector.cpython-314.pyc +0 -0
  46. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/scripts/drift_detector.py +222 -0
  47. package/project-skills/service-skills-set/.claude/skills/using-service-skills/SKILL.md +108 -0
  48. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/__pycache__/cataloger.cpython-314.pyc +0 -0
  49. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/__pycache__/skill_activator.cpython-314.pyc +0 -0
  50. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/cataloger.py +74 -0
  51. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/skill_activator.py +152 -0
  52. package/project-skills/service-skills-set/README.md +93 -0
  53. package/project-skills/service-skills-set/__pycache__/install-service-skills.cpython-314.pyc +0 -0
  54. package/project-skills/service-skills-set/install-service-skills.py +163 -0
  55. package/project-skills/service-skills-set/service-skills-readme.md +236 -0
  56. package/project-skills/tdd-guard/.claude/settings.json +38 -0
  57. package/project-skills/tdd-guard/.claude/skills/using-tdd-guard/SKILL.md +74 -0
  58. package/project-skills/tdd-guard/CLAUDE.md +98 -0
  59. package/project-skills/tdd-guard/CONTRIBUTING.md +38 -0
  60. package/project-skills/tdd-guard/DEVELOPMENT.md +127 -0
  61. package/project-skills/tdd-guard/LICENSE +21 -0
  62. package/project-skills/tdd-guard/README.md +396 -0
  63. package/project-skills/tdd-guard/docs/adr/001-claude-session-subdirectory.md +52 -0
  64. package/project-skills/tdd-guard/docs/adr/002-secure-claude-binary-path.md +56 -0
  65. package/project-skills/tdd-guard/docs/adr/003-remove-configurable-data-directory.md +56 -0
  66. package/project-skills/tdd-guard/docs/adr/004-monorepo-architecture.md +64 -0
  67. package/project-skills/tdd-guard/docs/adr/005-claude-project-dir-support.md +55 -0
  68. package/project-skills/tdd-guard/docs/adr/006-phpunit-separate-repository.md +93 -0
  69. package/project-skills/tdd-guard/docs/adr/007-golangci-lint-path-support.md +83 -0
  70. package/project-skills/tdd-guard/docs/adr/008-storybook-reporter-design.md +182 -0
  71. package/project-skills/tdd-guard/docs/assets/tdd-guard-demo-screenshot.gif +0 -0
  72. package/project-skills/tdd-guard/docs/config-migration.md +143 -0
  73. package/project-skills/tdd-guard/docs/configuration.md +137 -0
  74. package/project-skills/tdd-guard/docs/custom-instructions.md +43 -0
  75. package/project-skills/tdd-guard/docs/enforcement.md +46 -0
  76. package/project-skills/tdd-guard/docs/ignore-patterns.md +81 -0
  77. package/project-skills/tdd-guard/docs/linting.md +109 -0
  78. package/project-skills/tdd-guard/docs/quick-commands.md +52 -0
  79. package/project-skills/tdd-guard/docs/session-management.md +75 -0
  80. package/project-skills/tdd-guard/docs/storybook-vitest-addon.md +120 -0
  81. package/project-skills/tdd-guard/docs/validation-model.md +63 -0
  82. package/project-skills/tdd-guard/eslint.config.mjs +140 -0
  83. package/project-skills/tdd-guard/package-lock.json +16937 -0
  84. package/project-skills/tdd-guard/package.json +102 -0
  85. package/project-skills/tdd-guard/reporters/go/README.md +67 -0
  86. package/project-skills/tdd-guard/reporters/go/cmd/tdd-guard-go/main.go +127 -0
  87. package/project-skills/tdd-guard/reporters/go/cmd/tdd-guard-go/main_test.go +280 -0
  88. package/project-skills/tdd-guard/reporters/go/go.mod +3 -0
  89. package/project-skills/tdd-guard/reporters/go/go.sum +0 -0
  90. package/project-skills/tdd-guard/reporters/go/internal/formatter/formatter.go +126 -0
  91. package/project-skills/tdd-guard/reporters/go/internal/formatter/formatter_test.go +264 -0
  92. package/project-skills/tdd-guard/reporters/go/internal/io/tee_reader.go +26 -0
  93. package/project-skills/tdd-guard/reporters/go/internal/io/tee_reader_test.go +37 -0
  94. package/project-skills/tdd-guard/reporters/go/internal/parser/mixed_reader.go +94 -0
  95. package/project-skills/tdd-guard/reporters/go/internal/parser/mixed_reader_test.go +198 -0
  96. package/project-skills/tdd-guard/reporters/go/internal/parser/parser.go +245 -0
  97. package/project-skills/tdd-guard/reporters/go/internal/parser/parser_test.go +547 -0
  98. package/project-skills/tdd-guard/reporters/go/internal/storage/storage.go +35 -0
  99. package/project-skills/tdd-guard/reporters/go/internal/storage/storage_test.go +113 -0
  100. package/project-skills/tdd-guard/reporters/go/internal/transformer/transformer.go +103 -0
  101. package/project-skills/tdd-guard/reporters/go/internal/transformer/transformer_test.go +303 -0
  102. package/project-skills/tdd-guard/reporters/jest/README.md +102 -0
  103. package/project-skills/tdd-guard/reporters/jest/package.json +38 -0
  104. package/project-skills/tdd-guard/reporters/phpunit/.php-cs-fixer.php +28 -0
  105. package/project-skills/tdd-guard/reporters/phpunit/README.md +97 -0
  106. package/project-skills/tdd-guard/reporters/phpunit/SYNC_README.md +29 -0
  107. package/project-skills/tdd-guard/reporters/phpunit/composer.json +55 -0
  108. package/project-skills/tdd-guard/reporters/phpunit/phpunit.xml.dist +19 -0
  109. package/project-skills/tdd-guard/reporters/phpunit/psalm.xml +44 -0
  110. package/project-skills/tdd-guard/reporters/phpunit/src/Event/ErroredTestSubscriber.php +28 -0
  111. package/project-skills/tdd-guard/reporters/phpunit/src/Event/FailedTestSubscriber.php +28 -0
  112. package/project-skills/tdd-guard/reporters/phpunit/src/Event/IncompleteTestSubscriber.php +28 -0
  113. package/project-skills/tdd-guard/reporters/phpunit/src/Event/PassedTestSubscriber.php +27 -0
  114. package/project-skills/tdd-guard/reporters/phpunit/src/Event/SkippedTestSubscriber.php +28 -0
  115. package/project-skills/tdd-guard/reporters/phpunit/src/Event/TestRunnerFinishedSubscriber.php +24 -0
  116. package/project-skills/tdd-guard/reporters/phpunit/src/PathValidator.php +88 -0
  117. package/project-skills/tdd-guard/reporters/phpunit/src/Storage.php +26 -0
  118. package/project-skills/tdd-guard/reporters/phpunit/src/TddGuardExtension.php +33 -0
  119. package/project-skills/tdd-guard/reporters/phpunit/src/TddGuardListener.php +158 -0
  120. package/project-skills/tdd-guard/reporters/phpunit/src/TddGuardSubscriber.php +35 -0
  121. package/project-skills/tdd-guard/reporters/phpunit/src/TestResultCollector.php +105 -0
  122. package/project-skills/tdd-guard/reporters/phpunit/tests/PathValidatorTest.php +74 -0
  123. package/project-skills/tdd-guard/reporters/phpunit/tests/TddGuardExtensionFailedTest.php +241 -0
  124. package/project-skills/tdd-guard/reporters/phpunit/tests/TddGuardExtensionTest.php +84 -0
  125. package/project-skills/tdd-guard/reporters/phpunit/tests/TddGuardStorageLocationTest.php +71 -0
  126. package/project-skills/tdd-guard/reporters/pytest/README.md +77 -0
  127. package/project-skills/tdd-guard/reporters/pytest/pyproject.toml +43 -0
  128. package/project-skills/tdd-guard/reporters/pytest/pytest.ini.example +7 -0
  129. package/project-skills/tdd-guard/reporters/pytest/tdd_guard_pytest/__init__.py +1 -0
  130. package/project-skills/tdd-guard/reporters/pytest/tdd_guard_pytest/pytest_reporter.py +134 -0
  131. package/project-skills/tdd-guard/reporters/pytest/tests/__init__.py +1 -0
  132. package/project-skills/tdd-guard/reporters/pytest/tests/conftest.py +3 -0
  133. package/project-skills/tdd-guard/reporters/pytest/tests/helpers.py +293 -0
  134. package/project-skills/tdd-guard/reporters/pytest/tests/test_config_option.py +38 -0
  135. package/project-skills/tdd-guard/reporters/pytest/tests/test_path_validation.py +59 -0
  136. package/project-skills/tdd-guard/reporters/pytest/tests/test_plugin_config.py +32 -0
  137. package/project-skills/tdd-guard/reporters/pytest/tests/test_project_root.py +296 -0
  138. package/project-skills/tdd-guard/reporters/pytest/tests/test_pytest_reporter.py +137 -0
  139. package/project-skills/tdd-guard/reporters/rspec/Gemfile +3 -0
  140. package/project-skills/tdd-guard/reporters/rust/Cargo.lock +458 -0
  141. package/project-skills/tdd-guard/reporters/rust/Cargo.toml +33 -0
  142. package/project-skills/tdd-guard/reporters/rust/Makefile.example +95 -0
  143. package/project-skills/tdd-guard/reporters/rust/README.md +88 -0
  144. package/project-skills/tdd-guard/reporters/rust/src/error_parser.rs +309 -0
  145. package/project-skills/tdd-guard/reporters/rust/src/main.rs +464 -0
  146. package/project-skills/tdd-guard/reporters/rust/src/parser.rs +225 -0
  147. package/project-skills/tdd-guard/reporters/rust/src/transformer.rs +409 -0
  148. package/project-skills/tdd-guard/reporters/storybook/README.md +108 -0
  149. package/project-skills/tdd-guard/reporters/storybook/package-lock.json +9482 -0
  150. package/project-skills/tdd-guard/reporters/storybook/package.json +43 -0
  151. package/project-skills/tdd-guard/reporters/storybook/src/StorybookReporter.test-data.ts +22 -0
  152. package/project-skills/tdd-guard/reporters/storybook/src/StorybookReporter.test.ts +190 -0
  153. package/project-skills/tdd-guard/reporters/storybook/src/StorybookReporter.ts +88 -0
  154. package/project-skills/tdd-guard/reporters/storybook/src/index.ts +12 -0
  155. package/project-skills/tdd-guard/reporters/storybook/src/types.ts +37 -0
  156. package/project-skills/tdd-guard/reporters/storybook/tsconfig.json +11 -0
  157. package/project-skills/tdd-guard/reporters/test/artifacts/go/failing/go.mod +3 -0
  158. package/project-skills/tdd-guard/reporters/test/artifacts/go/failing/single_failing_test.go +13 -0
  159. package/project-skills/tdd-guard/reporters/test/artifacts/go/import/go.mod +3 -0
  160. package/project-skills/tdd-guard/reporters/test/artifacts/go/import/single_import_error_test.go +17 -0
  161. package/project-skills/tdd-guard/reporters/test/artifacts/go/passing/go.mod +3 -0
  162. package/project-skills/tdd-guard/reporters/test/artifacts/go/passing/single_passing_test.go +13 -0
  163. package/project-skills/tdd-guard/reporters/test/artifacts/jest/single-failing.test.js +5 -0
  164. package/project-skills/tdd-guard/reporters/test/artifacts/jest/single-import-error.test.js +8 -0
  165. package/project-skills/tdd-guard/reporters/test/artifacts/jest/single-passing.test.js +5 -0
  166. package/project-skills/tdd-guard/reporters/test/artifacts/phpunit/SingleFailingTest.php +11 -0
  167. package/project-skills/tdd-guard/reporters/test/artifacts/phpunit/SingleImportErrorTest.php +14 -0
  168. package/project-skills/tdd-guard/reporters/test/artifacts/phpunit/SinglePassingTest.php +11 -0
  169. package/project-skills/tdd-guard/reporters/test/artifacts/pytest/test_single_failing.py +3 -0
  170. package/project-skills/tdd-guard/reporters/test/artifacts/pytest/test_single_import_error.py +6 -0
  171. package/project-skills/tdd-guard/reporters/test/artifacts/pytest/test_single_passing.py +3 -0
  172. package/project-skills/tdd-guard/reporters/test/artifacts/rust/failing/Cargo.lock +7 -0
  173. package/project-skills/tdd-guard/reporters/test/artifacts/rust/failing/Cargo.toml +4 -0
  174. package/project-skills/tdd-guard/reporters/test/artifacts/rust/failing/src/lib.rs +14 -0
  175. package/project-skills/tdd-guard/reporters/test/artifacts/rust/import/Cargo.lock +7 -0
  176. package/project-skills/tdd-guard/reporters/test/artifacts/rust/import/Cargo.toml +4 -0
  177. package/project-skills/tdd-guard/reporters/test/artifacts/rust/import/src/lib.rs +13 -0
  178. package/project-skills/tdd-guard/reporters/test/artifacts/rust/passing/Cargo.lock +7 -0
  179. package/project-skills/tdd-guard/reporters/test/artifacts/rust/passing/Cargo.toml +4 -0
  180. package/project-skills/tdd-guard/reporters/test/artifacts/rust/passing/src/lib.rs +14 -0
  181. package/project-skills/tdd-guard/reporters/test/artifacts/storybook/Calculator.js +4 -0
  182. package/project-skills/tdd-guard/reporters/test/artifacts/storybook/single-failing.stories.js +15 -0
  183. package/project-skills/tdd-guard/reporters/test/artifacts/storybook/single-import-error.stories.js +14 -0
  184. package/project-skills/tdd-guard/reporters/test/artifacts/storybook/single-passing.stories.js +15 -0
  185. package/project-skills/tdd-guard/reporters/test/artifacts/vitest/single-failing.test.js +7 -0
  186. package/project-skills/tdd-guard/reporters/test/artifacts/vitest/single-import-error.test.js +9 -0
  187. package/project-skills/tdd-guard/reporters/test/artifacts/vitest/single-passing.test.js +7 -0
  188. package/project-skills/tdd-guard/reporters/test/factories/go.ts +59 -0
  189. package/project-skills/tdd-guard/reporters/test/factories/helpers.ts +48 -0
  190. package/project-skills/tdd-guard/reporters/test/factories/index.ts +7 -0
  191. package/project-skills/tdd-guard/reporters/test/factories/jest.ts +51 -0
  192. package/project-skills/tdd-guard/reporters/test/factories/phpunit.ts +63 -0
  193. package/project-skills/tdd-guard/reporters/test/factories/pytest.ts +41 -0
  194. package/project-skills/tdd-guard/reporters/test/factories/rust.ts +158 -0
  195. package/project-skills/tdd-guard/reporters/test/factories/storybook.ts +198 -0
  196. package/project-skills/tdd-guard/reporters/test/factories/vitest.ts +51 -0
  197. package/project-skills/tdd-guard/reporters/test/reporters.integration.test.ts +735 -0
  198. package/project-skills/tdd-guard/reporters/test/types.ts +28 -0
  199. package/project-skills/tdd-guard/reporters/vitest/README.md +64 -0
  200. package/project-skills/tdd-guard/reporters/vitest/package.json +35 -0
  201. package/project-skills/tdd-guard/src/cli/buildContext.test.ts +200 -0
  202. package/project-skills/tdd-guard/src/cli/buildContext.ts +48 -0
  203. package/project-skills/tdd-guard/src/cli/tdd-guard.test.ts +159 -0
  204. package/project-skills/tdd-guard/src/cli/tdd-guard.ts +48 -0
  205. package/project-skills/tdd-guard/src/config/Config.test.ts +538 -0
  206. package/project-skills/tdd-guard/src/config/Config.ts +172 -0
  207. package/project-skills/tdd-guard/src/contracts/schemas/guardSchemas.test.ts +58 -0
  208. package/project-skills/tdd-guard/src/contracts/schemas/guardSchemas.ts +8 -0
  209. package/project-skills/tdd-guard/src/contracts/schemas/lintSchemas.test.ts +347 -0
  210. package/project-skills/tdd-guard/src/contracts/schemas/lintSchemas.ts +61 -0
  211. package/project-skills/tdd-guard/src/contracts/schemas/pytestSchemas.test.ts +24 -0
  212. package/project-skills/tdd-guard/src/contracts/schemas/pytestSchemas.ts +7 -0
  213. package/project-skills/tdd-guard/src/contracts/schemas/reporterSchemas.test.ts +377 -0
  214. package/project-skills/tdd-guard/src/contracts/schemas/reporterSchemas.ts +75 -0
  215. package/project-skills/tdd-guard/src/contracts/schemas/toolSchemas.test.ts +563 -0
  216. package/project-skills/tdd-guard/src/contracts/schemas/toolSchemas.ts +140 -0
  217. package/project-skills/tdd-guard/src/contracts/types/ClientType.ts +1 -0
  218. package/project-skills/tdd-guard/src/contracts/types/ConfigOptions.ts +12 -0
  219. package/project-skills/tdd-guard/src/contracts/types/Context.ts +16 -0
  220. package/project-skills/tdd-guard/src/contracts/types/ModelClient.ts +3 -0
  221. package/project-skills/tdd-guard/src/contracts/types/ValidationResult.ts +6 -0
  222. package/project-skills/tdd-guard/src/guard/GuardManager.test.ts +336 -0
  223. package/project-skills/tdd-guard/src/guard/GuardManager.ts +83 -0
  224. package/project-skills/tdd-guard/src/hooks/HookEvents.test.ts +107 -0
  225. package/project-skills/tdd-guard/src/hooks/HookEvents.ts +39 -0
  226. package/project-skills/tdd-guard/src/hooks/fileTypeDetection.ts +16 -0
  227. package/project-skills/tdd-guard/src/hooks/postToolLint.test.ts +327 -0
  228. package/project-skills/tdd-guard/src/hooks/postToolLint.ts +165 -0
  229. package/project-skills/tdd-guard/src/hooks/processHookData.test.ts +465 -0
  230. package/project-skills/tdd-guard/src/hooks/processHookData.ts +203 -0
  231. package/project-skills/tdd-guard/src/hooks/sessionHandler.test.ts +136 -0
  232. package/project-skills/tdd-guard/src/hooks/sessionHandler.ts +31 -0
  233. package/project-skills/tdd-guard/src/hooks/userPromptHandler.test.ts +131 -0
  234. package/project-skills/tdd-guard/src/hooks/userPromptHandler.ts +55 -0
  235. package/project-skills/tdd-guard/src/index.ts +19 -0
  236. package/project-skills/tdd-guard/src/linters/Linter.ts +5 -0
  237. package/project-skills/tdd-guard/src/linters/eslint/ESLint.test.ts +183 -0
  238. package/project-skills/tdd-guard/src/linters/eslint/ESLint.ts +82 -0
  239. package/project-skills/tdd-guard/src/linters/golangci/GolangciLint.test.ts +170 -0
  240. package/project-skills/tdd-guard/src/linters/golangci/GolangciLint.ts +148 -0
  241. package/project-skills/tdd-guard/src/processors/index.ts +1 -0
  242. package/project-skills/tdd-guard/src/processors/lintProcessor.ts +77 -0
  243. package/project-skills/tdd-guard/src/processors/testResults/TestResultsProcessor.test.ts +303 -0
  244. package/project-skills/tdd-guard/src/processors/testResults/TestResultsProcessor.ts +255 -0
  245. package/project-skills/tdd-guard/src/providers/LinterProvider.test.ts +43 -0
  246. package/project-skills/tdd-guard/src/providers/LinterProvider.ts +20 -0
  247. package/project-skills/tdd-guard/src/providers/ModelClientProvider.test.ts +68 -0
  248. package/project-skills/tdd-guard/src/providers/ModelClientProvider.ts +22 -0
  249. package/project-skills/tdd-guard/src/storage/FileStorage.test.ts +76 -0
  250. package/project-skills/tdd-guard/src/storage/FileStorage.ts +108 -0
  251. package/project-skills/tdd-guard/src/storage/MemoryStorage.ts +57 -0
  252. package/project-skills/tdd-guard/src/storage/Storage.test.ts +227 -0
  253. package/project-skills/tdd-guard/src/storage/Storage.ts +17 -0
  254. package/project-skills/tdd-guard/src/validation/context/context.test.ts +364 -0
  255. package/project-skills/tdd-guard/src/validation/context/context.ts +155 -0
  256. package/project-skills/tdd-guard/src/validation/models/AnthropicApi.test.ts +171 -0
  257. package/project-skills/tdd-guard/src/validation/models/AnthropicApi.ts +49 -0
  258. package/project-skills/tdd-guard/src/validation/models/ClaudeAgentSdk.test.ts +167 -0
  259. package/project-skills/tdd-guard/src/validation/models/ClaudeAgentSdk.ts +54 -0
  260. package/project-skills/tdd-guard/src/validation/models/ClaudeCli.test.ts +239 -0
  261. package/project-skills/tdd-guard/src/validation/models/ClaudeCli.ts +57 -0
  262. package/project-skills/tdd-guard/src/validation/prompts/file-types.ts +52 -0
  263. package/project-skills/tdd-guard/src/validation/prompts/operations/edit.ts +58 -0
  264. package/project-skills/tdd-guard/src/validation/prompts/operations/multi-edit.ts +54 -0
  265. package/project-skills/tdd-guard/src/validation/prompts/operations/write.ts +54 -0
  266. package/project-skills/tdd-guard/src/validation/prompts/response.ts +40 -0
  267. package/project-skills/tdd-guard/src/validation/prompts/rules.ts +51 -0
  268. package/project-skills/tdd-guard/src/validation/prompts/system-prompt.ts +10 -0
  269. package/project-skills/tdd-guard/src/validation/prompts/tools/lint-results.ts +15 -0
  270. package/project-skills/tdd-guard/src/validation/prompts/tools/test-output.ts +14 -0
  271. package/project-skills/tdd-guard/src/validation/prompts/tools/todos.ts +9 -0
  272. package/project-skills/tdd-guard/src/validation/validator.test.ts +268 -0
  273. package/project-skills/tdd-guard/src/validation/validator.ts +159 -0
  274. package/project-skills/tdd-guard/test/artifacts/go/.golangci.yml +6 -0
  275. package/project-skills/tdd-guard/test/artifacts/go/with-issues/file-with-issues.go +12 -0
  276. package/project-skills/tdd-guard/test/artifacts/go/with-issues/go.mod +3 -0
  277. package/project-skills/tdd-guard/test/artifacts/go/without-issues/file-without-issues.go +7 -0
  278. package/project-skills/tdd-guard/test/artifacts/go/without-issues/go.mod +3 -0
  279. package/project-skills/tdd-guard/test/artifacts/javascript/eslint.config.js +20 -0
  280. package/project-skills/tdd-guard/test/artifacts/javascript/file-with-issues.js +12 -0
  281. package/project-skills/tdd-guard/test/artifacts/javascript/file-without-issues.js +10 -0
  282. package/project-skills/tdd-guard/test/hooks/fileTypeDetection.test.ts +26 -0
  283. package/project-skills/tdd-guard/test/hooks/processHookData.fileType.test.ts +46 -0
  284. package/project-skills/tdd-guard/test/hooks/processHookData.python.test.ts +68 -0
  285. package/project-skills/tdd-guard/test/integration/test-context.test.ts +66 -0
  286. package/project-skills/tdd-guard/test/integration/validator.core.test.ts +96 -0
  287. package/project-skills/tdd-guard/test/integration/validator.scenarios.test.ts +497 -0
  288. package/project-skills/tdd-guard/test/utils/assertions.ts +29 -0
  289. package/project-skills/tdd-guard/test/utils/factories/contextFactory.ts +30 -0
  290. package/project-skills/tdd-guard/test/utils/factories/editFactory.ts +82 -0
  291. package/project-skills/tdd-guard/test/utils/factories/helpers.test.ts +46 -0
  292. package/project-skills/tdd-guard/test/utils/factories/helpers.ts +46 -0
  293. package/project-skills/tdd-guard/test/utils/factories/lintFactory.ts +352 -0
  294. package/project-skills/tdd-guard/test/utils/factories/modelClientProviderFactory.ts +21 -0
  295. package/project-skills/tdd-guard/test/utils/factories/multiEditFactory.ts +79 -0
  296. package/project-skills/tdd-guard/test/utils/factories/operations.ts +57 -0
  297. package/project-skills/tdd-guard/test/utils/factories/reporterFactory.ts +55 -0
  298. package/project-skills/tdd-guard/test/utils/factories/scenarios/index.ts +22 -0
  299. package/project-skills/tdd-guard/test/utils/factories/scenarios/languages/python.ts +745 -0
  300. package/project-skills/tdd-guard/test/utils/factories/scenarios/languages/typescript.ts +767 -0
  301. package/project-skills/tdd-guard/test/utils/factories/scenarios/types.ts +77 -0
  302. package/project-skills/tdd-guard/test/utils/factories/scenarios/utils.ts +15 -0
  303. package/project-skills/tdd-guard/test/utils/factories/sessionStartFactory.ts +36 -0
  304. package/project-skills/tdd-guard/test/utils/factories/testDefaults.ts +90 -0
  305. package/project-skills/tdd-guard/test/utils/factories/testResultsFactory.ts +234 -0
  306. package/project-skills/tdd-guard/test/utils/factories/todoFactory.ts +99 -0
  307. package/project-skills/tdd-guard/test/utils/factories/userPromptSubmitFactory.ts +39 -0
  308. package/project-skills/tdd-guard/test/utils/factories/writeFactory.ts +70 -0
  309. package/project-skills/tdd-guard/test/utils/index.ts +131 -0
  310. package/project-skills/tdd-guard/tsconfig.build.json +16 -0
  311. package/project-skills/tdd-guard/tsconfig.eslint.json +17 -0
  312. package/project-skills/tdd-guard/tsconfig.json +32 -0
  313. package/project-skills/tdd-guard/tsconfig.node.json +10 -0
  314. package/project-skills/tdd-guard/vitest.config.ts +85 -0
  315. package/project-skills/ts-quality-gate/.claude/hooks/hook-config.json +66 -0
  316. package/project-skills/ts-quality-gate/.claude/hooks/quality-check.cjs +1251 -0
  317. package/project-skills/ts-quality-gate/.claude/settings.json +16 -0
  318. package/project-skills/ts-quality-gate/.claude/skills/using-ts-quality-gate/SKILL.md +81 -0
  319. package/project-skills/ts-quality-gate/README.md +115 -0
  320. package/skills/README.txt +31 -0
  321. package/skills/clean-code/SKILL.md +201 -0
  322. package/skills/delegating/SKILL.md +196 -0
  323. package/skills/delegating/config.yaml +210 -0
  324. package/skills/delegating/references/orchestration-protocols.md +41 -0
  325. package/skills/docker-expert/SKILL.md +409 -0
  326. package/skills/documenting/CHANGELOG.md +23 -0
  327. package/skills/documenting/README.md +148 -0
  328. package/skills/documenting/SKILL.md +113 -0
  329. package/skills/documenting/examples/example_pattern.md +70 -0
  330. package/skills/documenting/examples/example_reference.md +70 -0
  331. package/skills/documenting/examples/example_ssot_analytics.md +64 -0
  332. package/skills/documenting/examples/example_workflow.md +141 -0
  333. package/skills/documenting/references/changelog-format.md +97 -0
  334. package/skills/documenting/references/metadata-schema.md +136 -0
  335. package/skills/documenting/references/taxonomy.md +81 -0
  336. package/skills/documenting/references/versioning-rules.md +78 -0
  337. package/skills/documenting/scripts/__pycache__/drift_detector.cpython-314.pyc +0 -0
  338. package/skills/documenting/scripts/__pycache__/orchestrator.cpython-314.pyc +0 -0
  339. package/skills/documenting/scripts/__pycache__/validate_metadata.cpython-314.pyc +0 -0
  340. package/skills/documenting/scripts/bump_version.sh +60 -0
  341. package/skills/documenting/scripts/changelog/__init__.py +0 -0
  342. package/skills/documenting/scripts/changelog/__pycache__/__init__.cpython-314.pyc +0 -0
  343. package/skills/documenting/scripts/changelog/__pycache__/add_entry.cpython-314.pyc +0 -0
  344. package/skills/documenting/scripts/changelog/__pycache__/bump_release.cpython-314.pyc +0 -0
  345. package/skills/documenting/scripts/changelog/__pycache__/validate_changelog.cpython-314.pyc +0 -0
  346. package/skills/documenting/scripts/changelog/add_entry.py +216 -0
  347. package/skills/documenting/scripts/changelog/bump_release.py +117 -0
  348. package/skills/documenting/scripts/changelog/init_changelog.py +54 -0
  349. package/skills/documenting/scripts/changelog/validate_changelog.py +128 -0
  350. package/skills/documenting/scripts/drift_detector.py +266 -0
  351. package/skills/documenting/scripts/generate_template.py +311 -0
  352. package/skills/documenting/scripts/list_by_category.sh +84 -0
  353. package/skills/documenting/scripts/orchestrator.py +255 -0
  354. package/skills/documenting/scripts/validate_metadata.py +242 -0
  355. package/skills/documenting/templates/CHANGELOG.md.template +13 -0
  356. package/skills/documenting/tests/__pycache__/test_changelog.cpython-314-pytest-9.0.2.pyc +0 -0
  357. package/skills/documenting/tests/__pycache__/test_drift_detector.cpython-314-pytest-9.0.2.pyc +0 -0
  358. package/skills/documenting/tests/__pycache__/test_orchestrator.cpython-314-pytest-9.0.2.pyc +0 -0
  359. package/skills/documenting/tests/__pycache__/test_validate_metadata.cpython-314-pytest-9.0.2.pyc +0 -0
  360. package/skills/documenting/tests/integration_test.sh +70 -0
  361. package/skills/documenting/tests/test_changelog.py +201 -0
  362. package/skills/documenting/tests/test_drift_detector.py +80 -0
  363. package/skills/documenting/tests/test_orchestrator.py +52 -0
  364. package/skills/documenting/tests/test_validate_metadata.py +64 -0
  365. package/skills/find-skills/SKILL.md +133 -0
  366. package/skills/gitnexus-debugging/SKILL.md +85 -0
  367. package/skills/gitnexus-exploring/SKILL.md +75 -0
  368. package/skills/gitnexus-impact-analysis/SKILL.md +94 -0
  369. package/skills/gitnexus-refactoring/SKILL.md +113 -0
  370. package/skills/hook-development/SKILL.md +797 -0
  371. package/skills/hook-development/examples/load-context.sh +55 -0
  372. package/skills/hook-development/examples/quality-check.js +1168 -0
  373. package/skills/hook-development/examples/validate-bash.sh +43 -0
  374. package/skills/hook-development/examples/validate-write.sh +38 -0
  375. package/skills/hook-development/references/advanced.md +527 -0
  376. package/skills/hook-development/references/migration.md +369 -0
  377. package/skills/hook-development/references/patterns.md +412 -0
  378. package/skills/hook-development/scripts/README.md +164 -0
  379. package/skills/hook-development/scripts/hook-linter.sh +153 -0
  380. package/skills/hook-development/scripts/test-hook.sh +252 -0
  381. package/skills/hook-development/scripts/validate-hook-schema.sh +159 -0
  382. package/skills/obsidian-cli/SKILL.md +106 -0
  383. package/skills/orchestrating-agents/SKILL.md +135 -0
  384. package/skills/orchestrating-agents/config.yaml +45 -0
  385. package/skills/orchestrating-agents/references/agent-context-integration.md +37 -0
  386. package/skills/orchestrating-agents/references/examples.md +45 -0
  387. package/skills/orchestrating-agents/references/handover-protocol.md +31 -0
  388. package/skills/orchestrating-agents/references/workflows.md +42 -0
  389. package/skills/orchestrating-agents/scripts/detect_neighbors.py +23 -0
  390. package/skills/prompt-improving/README.md +162 -0
  391. package/skills/prompt-improving/SKILL.md +74 -0
  392. package/skills/prompt-improving/references/analysis_commands.md +24 -0
  393. package/skills/prompt-improving/references/chain_of_thought.md +24 -0
  394. package/skills/prompt-improving/references/mcp_definitions.md +20 -0
  395. package/skills/prompt-improving/references/multishot.md +23 -0
  396. package/skills/prompt-improving/references/xml_core.md +60 -0
  397. package/skills/python-testing/SKILL.md +815 -0
  398. package/skills/senior-backend/SKILL.md +209 -0
  399. package/skills/senior-backend/references/api_design_patterns.md +103 -0
  400. package/skills/senior-backend/references/backend_security_practices.md +103 -0
  401. package/skills/senior-backend/references/database_optimization_guide.md +103 -0
  402. package/skills/senior-backend/scripts/api_load_tester.py +114 -0
  403. package/skills/senior-backend/scripts/api_scaffolder.py +114 -0
  404. package/skills/senior-backend/scripts/database_migration_tool.py +114 -0
  405. package/skills/senior-data-scientist/SKILL.md +226 -0
  406. package/skills/senior-data-scientist/references/experiment_design_frameworks.md +80 -0
  407. package/skills/senior-data-scientist/references/feature_engineering_patterns.md +80 -0
  408. package/skills/senior-data-scientist/references/statistical_methods_advanced.md +80 -0
  409. package/skills/senior-data-scientist/scripts/experiment_designer.py +100 -0
  410. package/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +100 -0
  411. package/skills/senior-data-scientist/scripts/model_evaluation_suite.py +100 -0
  412. package/skills/senior-devops/SKILL.md +209 -0
  413. package/skills/senior-devops/references/cicd_pipeline_guide.md +103 -0
  414. package/skills/senior-devops/references/deployment_strategies.md +103 -0
  415. package/skills/senior-devops/references/infrastructure_as_code.md +103 -0
  416. package/skills/senior-devops/scripts/deployment_manager.py +114 -0
  417. package/skills/senior-devops/scripts/pipeline_generator.py +114 -0
  418. package/skills/senior-devops/scripts/terraform_scaffolder.py +114 -0
  419. package/skills/senior-security/SKILL.md +209 -0
  420. package/skills/senior-security/references/cryptography_implementation.md +103 -0
  421. package/skills/senior-security/references/penetration_testing_guide.md +103 -0
  422. package/skills/senior-security/references/security_architecture_patterns.md +103 -0
  423. package/skills/senior-security/scripts/pentest_automator.py +114 -0
  424. package/skills/senior-security/scripts/security_auditor.py +114 -0
  425. package/skills/senior-security/scripts/threat_modeler.py +114 -0
  426. package/skills/skill-creator/LICENSE.txt +202 -0
  427. package/skills/skill-creator/SKILL.md +479 -0
  428. package/skills/skill-creator/agents/analyzer.md +274 -0
  429. package/skills/skill-creator/agents/comparator.md +202 -0
  430. package/skills/skill-creator/agents/grader.md +223 -0
  431. package/skills/skill-creator/assets/eval_review.html +146 -0
  432. package/skills/skill-creator/eval-viewer/generate_review.py +471 -0
  433. package/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  434. package/skills/skill-creator/references/schemas.md +430 -0
  435. package/skills/skill-creator/scripts/__init__.py +0 -0
  436. package/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
  437. package/skills/skill-creator/scripts/generate_report.py +326 -0
  438. package/skills/skill-creator/scripts/improve_description.py +248 -0
  439. package/skills/skill-creator/scripts/package_skill.py +136 -0
  440. package/skills/skill-creator/scripts/quick_validate.py +103 -0
  441. package/skills/skill-creator/scripts/run_eval.py +310 -0
  442. package/skills/skill-creator/scripts/run_loop.py +332 -0
  443. package/skills/skill-creator/scripts/utils.py +47 -0
  444. package/skills/using-TDD/SKILL.md +410 -0
  445. package/skills/using-serena-lsp/README.md +8 -0
  446. package/skills/using-serena-lsp/REFERENCE.md +194 -0
  447. package/skills/using-serena-lsp/SKILL.md +82 -0
@@ -0,0 +1,410 @@
1
+ ---
2
+ name: tdd-workflow
3
+ description: Use this skill when writing new features, fixing bugs, or refactoring code. Enforces test-driven development with 80%+ coverage including unit, integration, and E2E tests.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Test-Driven Development Workflow
8
+
9
+ This skill ensures all code development follows TDD principles with comprehensive test coverage.
10
+
11
+ ## When to Activate
12
+
13
+ - Writing new features or functionality
14
+ - Fixing bugs or issues
15
+ - Refactoring existing code
16
+ - Adding API endpoints
17
+ - Creating new components
18
+
19
+ ## Core Principles
20
+
21
+ ### 1. Tests BEFORE Code
22
+ ALWAYS write tests first, then implement code to make tests pass.
23
+
24
+ ### 2. Coverage Requirements
25
+ - Minimum 80% coverage (unit + integration + E2E)
26
+ - All edge cases covered
27
+ - Error scenarios tested
28
+ - Boundary conditions verified
29
+
30
+ ### 3. Test Types
31
+
32
+ #### Unit Tests
33
+ - Individual functions and utilities
34
+ - Component logic
35
+ - Pure functions
36
+ - Helpers and utilities
37
+
38
+ #### Integration Tests
39
+ - API endpoints
40
+ - Database operations
41
+ - Service interactions
42
+ - External API calls
43
+
44
+ #### E2E Tests (Playwright)
45
+ - Critical user flows
46
+ - Complete workflows
47
+ - Browser automation
48
+ - UI interactions
49
+
50
+ ## TDD Workflow Steps
51
+
52
+ ### Step 1: Write User Journeys
53
+ ```
54
+ As a [role], I want to [action], so that [benefit]
55
+
56
+ Example:
57
+ As a user, I want to search for markets semantically,
58
+ so that I can find relevant markets even without exact keywords.
59
+ ```
60
+
61
+ ### Step 2: Generate Test Cases
62
+ For each user journey, create comprehensive test cases:
63
+
64
+ ```typescript
65
+ describe('Semantic Search', () => {
66
+ it('returns relevant markets for query', async () => {
67
+ // Test implementation
68
+ })
69
+
70
+ it('handles empty query gracefully', async () => {
71
+ // Test edge case
72
+ })
73
+
74
+ it('falls back to substring search when Redis unavailable', async () => {
75
+ // Test fallback behavior
76
+ })
77
+
78
+ it('sorts results by similarity score', async () => {
79
+ // Test sorting logic
80
+ })
81
+ })
82
+ ```
83
+
84
+ ### Step 3: Run Tests (They Should Fail)
85
+ ```bash
86
+ npm test
87
+ # Tests should fail - we haven't implemented yet
88
+ ```
89
+
90
+ ### Step 4: Implement Code
91
+ Write minimal code to make tests pass:
92
+
93
+ ```typescript
94
+ // Implementation guided by tests
95
+ export async function searchMarkets(query: string) {
96
+ // Implementation here
97
+ }
98
+ ```
99
+
100
+ ### Step 5: Run Tests Again
101
+ ```bash
102
+ npm test
103
+ # Tests should now pass
104
+ ```
105
+
106
+ ### Step 6: Refactor
107
+ Improve code quality while keeping tests green:
108
+ - Remove duplication
109
+ - Improve naming
110
+ - Optimize performance
111
+ - Enhance readability
112
+
113
+ ### Step 7: Verify Coverage
114
+ ```bash
115
+ npm run test:coverage
116
+ # Verify 80%+ coverage achieved
117
+ ```
118
+
119
+ ## Testing Patterns
120
+
121
+ ### Unit Test Pattern (Jest/Vitest)
122
+ ```typescript
123
+ import { render, screen, fireEvent } from '@testing-library/react'
124
+ import { Button } from './Button'
125
+
126
+ describe('Button Component', () => {
127
+ it('renders with correct text', () => {
128
+ render(<Button>Click me</Button>)
129
+ expect(screen.getByText('Click me')).toBeInTheDocument()
130
+ })
131
+
132
+ it('calls onClick when clicked', () => {
133
+ const handleClick = jest.fn()
134
+ render(<Button onClick={handleClick}>Click</Button>)
135
+
136
+ fireEvent.click(screen.getByRole('button'))
137
+
138
+ expect(handleClick).toHaveBeenCalledTimes(1)
139
+ })
140
+
141
+ it('is disabled when disabled prop is true', () => {
142
+ render(<Button disabled>Click</Button>)
143
+ expect(screen.getByRole('button')).toBeDisabled()
144
+ })
145
+ })
146
+ ```
147
+
148
+ ### API Integration Test Pattern
149
+ ```typescript
150
+ import { NextRequest } from 'next/server'
151
+ import { GET } from './route'
152
+
153
+ describe('GET /api/markets', () => {
154
+ it('returns markets successfully', async () => {
155
+ const request = new NextRequest('http://localhost/api/markets')
156
+ const response = await GET(request)
157
+ const data = await response.json()
158
+
159
+ expect(response.status).toBe(200)
160
+ expect(data.success).toBe(true)
161
+ expect(Array.isArray(data.data)).toBe(true)
162
+ })
163
+
164
+ it('validates query parameters', async () => {
165
+ const request = new NextRequest('http://localhost/api/markets?limit=invalid')
166
+ const response = await GET(request)
167
+
168
+ expect(response.status).toBe(400)
169
+ })
170
+
171
+ it('handles database errors gracefully', async () => {
172
+ // Mock database failure
173
+ const request = new NextRequest('http://localhost/api/markets')
174
+ // Test error handling
175
+ })
176
+ })
177
+ ```
178
+
179
+ ### E2E Test Pattern (Playwright)
180
+ ```typescript
181
+ import { test, expect } from '@playwright/test'
182
+
183
+ test('user can search and filter markets', async ({ page }) => {
184
+ // Navigate to markets page
185
+ await page.goto('/')
186
+ await page.click('a[href="/markets"]')
187
+
188
+ // Verify page loaded
189
+ await expect(page.locator('h1')).toContainText('Markets')
190
+
191
+ // Search for markets
192
+ await page.fill('input[placeholder="Search markets"]', 'election')
193
+
194
+ // Wait for debounce and results
195
+ await page.waitForTimeout(600)
196
+
197
+ // Verify search results displayed
198
+ const results = page.locator('[data-testid="market-card"]')
199
+ await expect(results).toHaveCount(5, { timeout: 5000 })
200
+
201
+ // Verify results contain search term
202
+ const firstResult = results.first()
203
+ await expect(firstResult).toContainText('election', { ignoreCase: true })
204
+
205
+ // Filter by status
206
+ await page.click('button:has-text("Active")')
207
+
208
+ // Verify filtered results
209
+ await expect(results).toHaveCount(3)
210
+ })
211
+
212
+ test('user can create a new market', async ({ page }) => {
213
+ // Login first
214
+ await page.goto('/creator-dashboard')
215
+
216
+ // Fill market creation form
217
+ await page.fill('input[name="name"]', 'Test Market')
218
+ await page.fill('textarea[name="description"]', 'Test description')
219
+ await page.fill('input[name="endDate"]', '2025-12-31')
220
+
221
+ // Submit form
222
+ await page.click('button[type="submit"]')
223
+
224
+ // Verify success message
225
+ await expect(page.locator('text=Market created successfully')).toBeVisible()
226
+
227
+ // Verify redirect to market page
228
+ await expect(page).toHaveURL(/\/markets\/test-market/)
229
+ })
230
+ ```
231
+
232
+ ## Test File Organization
233
+
234
+ ```
235
+ src/
236
+ ├── components/
237
+ │ ├── Button/
238
+ │ │ ├── Button.tsx
239
+ │ │ ├── Button.test.tsx # Unit tests
240
+ │ │ └── Button.stories.tsx # Storybook
241
+ │ └── MarketCard/
242
+ │ ├── MarketCard.tsx
243
+ │ └── MarketCard.test.tsx
244
+ ├── app/
245
+ │ └── api/
246
+ │ └── markets/
247
+ │ ├── route.ts
248
+ │ └── route.test.ts # Integration tests
249
+ └── e2e/
250
+ ├── markets.spec.ts # E2E tests
251
+ ├── trading.spec.ts
252
+ └── auth.spec.ts
253
+ ```
254
+
255
+ ## Mocking External Services
256
+
257
+ ### Supabase Mock
258
+ ```typescript
259
+ jest.mock('@/lib/supabase', () => ({
260
+ supabase: {
261
+ from: jest.fn(() => ({
262
+ select: jest.fn(() => ({
263
+ eq: jest.fn(() => Promise.resolve({
264
+ data: [{ id: 1, name: 'Test Market' }],
265
+ error: null
266
+ }))
267
+ }))
268
+ }))
269
+ }
270
+ }))
271
+ ```
272
+
273
+ ### Redis Mock
274
+ ```typescript
275
+ jest.mock('@/lib/redis', () => ({
276
+ searchMarketsByVector: jest.fn(() => Promise.resolve([
277
+ { slug: 'test-market', similarity_score: 0.95 }
278
+ ])),
279
+ checkRedisHealth: jest.fn(() => Promise.resolve({ connected: true }))
280
+ }))
281
+ ```
282
+
283
+ ### OpenAI Mock
284
+ ```typescript
285
+ jest.mock('@/lib/openai', () => ({
286
+ generateEmbedding: jest.fn(() => Promise.resolve(
287
+ new Array(1536).fill(0.1) // Mock 1536-dim embedding
288
+ ))
289
+ }))
290
+ ```
291
+
292
+ ## Test Coverage Verification
293
+
294
+ ### Run Coverage Report
295
+ ```bash
296
+ npm run test:coverage
297
+ ```
298
+
299
+ ### Coverage Thresholds
300
+ ```json
301
+ {
302
+ "jest": {
303
+ "coverageThresholds": {
304
+ "global": {
305
+ "branches": 80,
306
+ "functions": 80,
307
+ "lines": 80,
308
+ "statements": 80
309
+ }
310
+ }
311
+ }
312
+ }
313
+ ```
314
+
315
+ ## Common Testing Mistakes to Avoid
316
+
317
+ ### ❌ WRONG: Testing Implementation Details
318
+ ```typescript
319
+ // Don't test internal state
320
+ expect(component.state.count).toBe(5)
321
+ ```
322
+
323
+ ### ✅ CORRECT: Test User-Visible Behavior
324
+ ```typescript
325
+ // Test what users see
326
+ expect(screen.getByText('Count: 5')).toBeInTheDocument()
327
+ ```
328
+
329
+ ### ❌ WRONG: Brittle Selectors
330
+ ```typescript
331
+ // Breaks easily
332
+ await page.click('.css-class-xyz')
333
+ ```
334
+
335
+ ### ✅ CORRECT: Semantic Selectors
336
+ ```typescript
337
+ // Resilient to changes
338
+ await page.click('button:has-text("Submit")')
339
+ await page.click('[data-testid="submit-button"]')
340
+ ```
341
+
342
+ ### ❌ WRONG: No Test Isolation
343
+ ```typescript
344
+ // Tests depend on each other
345
+ test('creates user', () => { /* ... */ })
346
+ test('updates same user', () => { /* depends on previous test */ })
347
+ ```
348
+
349
+ ### ✅ CORRECT: Independent Tests
350
+ ```typescript
351
+ // Each test sets up its own data
352
+ test('creates user', () => {
353
+ const user = createTestUser()
354
+ // Test logic
355
+ })
356
+
357
+ test('updates user', () => {
358
+ const user = createTestUser()
359
+ // Update logic
360
+ })
361
+ ```
362
+
363
+ ## Continuous Testing
364
+
365
+ ### Watch Mode During Development
366
+ ```bash
367
+ npm test -- --watch
368
+ # Tests run automatically on file changes
369
+ ```
370
+
371
+ ### Pre-Commit Hook
372
+ ```bash
373
+ # Runs before every commit
374
+ npm test && npm run lint
375
+ ```
376
+
377
+ ### CI/CD Integration
378
+ ```yaml
379
+ # GitHub Actions
380
+ - name: Run Tests
381
+ run: npm test -- --coverage
382
+ - name: Upload Coverage
383
+ uses: codecov/codecov-action@v3
384
+ ```
385
+
386
+ ## Best Practices
387
+
388
+ 1. **Write Tests First** - Always TDD
389
+ 2. **One Assert Per Test** - Focus on single behavior
390
+ 3. **Descriptive Test Names** - Explain what's tested
391
+ 4. **Arrange-Act-Assert** - Clear test structure
392
+ 5. **Mock External Dependencies** - Isolate unit tests
393
+ 6. **Test Edge Cases** - Null, undefined, empty, large
394
+ 7. **Test Error Paths** - Not just happy paths
395
+ 8. **Keep Tests Fast** - Unit tests < 50ms each
396
+ 9. **Clean Up After Tests** - No side effects
397
+ 10. **Review Coverage Reports** - Identify gaps
398
+
399
+ ## Success Metrics
400
+
401
+ - 80%+ code coverage achieved
402
+ - All tests passing (green)
403
+ - No skipped or disabled tests
404
+ - Fast test execution (< 30s for unit tests)
405
+ - E2E tests cover critical user flows
406
+ - Tests catch bugs before production
407
+
408
+ ---
409
+
410
+ **Remember**: Tests are not optional. They are the safety net that enables confident refactoring, rapid development, and production reliability.
@@ -0,0 +1,8 @@
1
+ # serena-lsp-workflow
2
+ Master workflow combining Serena MCP semantic tools with LSP plugins.
3
+ ## Origin
4
+ Provided by Serena MCP project.
5
+ ## Associated Hook
6
+ - serena-workflow-reminder.sh
7
+ ## Documentation
8
+ See Serena MCP documentation.
@@ -0,0 +1,194 @@
1
+ # Serena Tool Reference
2
+
3
+ Detailed documentation for Serena MCP semantic tools.
4
+
5
+ ## Contents
6
+ - [1. Exploration & Navigation](#1-exploration--navigation-tools)
7
+ - [2. Editing Tools](#2-editing-tools)
8
+ - [3. Memory Management](#3-memory-management-tools)
9
+ - [4. Meta & Thinking](#4-meta--thinking-tools)
10
+
11
+ ---
12
+
13
+ ## 1. Exploration & Navigation Tools
14
+
15
+ ### `list_dir`
16
+ List files and directories with optional recursion.
17
+ ```python
18
+ mcp__serena__list_dir(
19
+ relative_path=".", # or "src/analysis"
20
+ recursive=true,
21
+ skip_ignored_files=true
22
+ )
23
+ ```
24
+
25
+ ### `find_file`
26
+ Find files by name pattern (wildcards supported).
27
+ ```python
28
+ mcp__serena__find_file(
29
+ file_mask="*volatility*.py",
30
+ relative_path="scripts"
31
+ )
32
+ ```
33
+
34
+ ### `get_symbols_overview`
35
+ Get high-level code structure (symbol tree) without reading the file body.
36
+ ```python
37
+ mcp__serena__get_symbols_overview(
38
+ relative_path="scripts/core/analytics.py",
39
+ depth=1 # 0=top-level, 1=include children (methods)
40
+ )
41
+ ```
42
+
43
+ ### `find_symbol`
44
+ Locate specific symbols (functions, classes, methods) semantically.
45
+ ```python
46
+ mcp__serena__find_symbol(
47
+ name_path_pattern="VolatilityCalculator/analyze_rv_trend",
48
+ relative_path="scripts/core/volatility_suite.py",
49
+ depth=1,
50
+ include_body=true, # Set true only when needing source code
51
+ substring_matching=true,
52
+ include_kinds=[5, 6, 12] # 5=Class, 6=Method, 12=Function
53
+ )
54
+ ```
55
+
56
+ **LSP Symbol Kinds Reference**:
57
+ ```
58
+ 1=file, 2=module, 3=namespace, 4=package, 5=class, 6=method,
59
+ 7=property, 8=field, 9=constructor, 10=enum, 11=interface,
60
+ 12=function, 13=variable, 14=constant, 15=string, 16=number,
61
+ 17=boolean, 18=array, 19=object, 20=key, 21=null,
62
+ 22=enum member, 23=struct, 24=event, 25=operator, 26=type parameter
63
+ ```
64
+
65
+ ### `find_referencing_symbols`
66
+ Find all places that reference a symbol. Essential before editing.
67
+ ```python
68
+ mcp__serena__find_referencing_symbols(
69
+ name_path="calculate_volatility",
70
+ relative_path="scripts/core/analytics.py"
71
+ )
72
+ ```
73
+
74
+ ### `search_for_pattern`
75
+ Flexible regex/substring search in code.
76
+ ```python
77
+ mcp__serena__search_for_pattern(
78
+ substring_pattern="def.*volatility", # Regex (DOTALL enabled)
79
+ relative_path="scripts/core",
80
+ restrict_search_to_code_files=true,
81
+ context_lines_before=2,
82
+ context_lines_after=2
83
+ )
84
+ ```
85
+
86
+ ---
87
+
88
+ ## 2. Editing Tools
89
+
90
+ ### `replace_symbol_body`
91
+ Replace entire symbol definition atomically.
92
+ ```python
93
+ mcp__serena__replace_symbol_body(
94
+ name_path="get_db_engine",
95
+ relative_path="scripts/core/volatility_suite.py",
96
+ body="def get_db_engine(): ..."
97
+ )
98
+ ```
99
+
100
+ ### `insert_after_symbol`
101
+ Insert code after a symbol's definition ends.
102
+ ```python
103
+ mcp__serena__insert_after_symbol(
104
+ name_path="VolatilityCalculator",
105
+ relative_path="scripts/core/analytics.py",
106
+ body="
107
+
108
+ class RiskCalculator: ..."
109
+ )
110
+ ```
111
+
112
+ ### `insert_before_symbol`
113
+ Insert code before a symbol's definition starts (e.g., imports).
114
+ ```python
115
+ mcp__serena__insert_before_symbol(
116
+ name_path="VolatilityCalculator",
117
+ relative_path="scripts/core/analytics.py",
118
+ body="from typing import Protocol
119
+
120
+ "
121
+ )
122
+ ```
123
+
124
+ ### `rename_symbol`
125
+ Rename symbol across entire codebase using LSP.
126
+ ```python
127
+ mcp__serena__rename_symbol(
128
+ name_path="calculate_volatility",
129
+ relative_path="scripts/core/analytics.py",
130
+ new_name="compute_volatility"
131
+ )
132
+ ```
133
+
134
+ ---
135
+
136
+ ## 3. Memory Management Tools
137
+
138
+ ### `write_memory`
139
+ Store project decisions, patterns, architecture notes.
140
+ ```python
141
+ mcp__serena__write_memory(
142
+ memory_file_name="architecture_decision_auth",
143
+ content="# Auth Pattern
144
+ ..."
145
+ )
146
+ ```
147
+
148
+ ### `read_memory`
149
+ Retrieve stored project knowledge.
150
+ ```python
151
+ mcp__serena__read_memory(memory_file_name="architecture_decision_auth")
152
+ ```
153
+
154
+ ### `list_memories`
155
+ Discover available project knowledge.
156
+ ```python
157
+ mcp__serena__list_memories()
158
+ ```
159
+
160
+ ### `edit_memory`
161
+ Update existing memory files.
162
+ ```python
163
+ mcp__serena__edit_memory(
164
+ memory_file_name="architecture_decision_auth",
165
+ mode="regex",
166
+ needle="Old",
167
+ repl="New"
168
+ )
169
+ ```
170
+
171
+ ### `delete_memory`
172
+ Remove obsolete memory files.
173
+ ```python
174
+ mcp__serena__delete_memory(memory_file_name="deprecated_pattern")
175
+ ```
176
+
177
+ ---
178
+
179
+ ## 4. Meta & Thinking Tools
180
+
181
+ ### `check_onboarding_performed`
182
+ Check if project onboarding was completed.
183
+
184
+ ### `onboarding`
185
+ Get instructions for project onboarding.
186
+
187
+ ### `think_about_collected_information`
188
+ Reflect after exploration/search operations.
189
+
190
+ ### `think_about_task_adherence`
191
+ Verify you're still on track for the task.
192
+
193
+ ### `think_about_whether_you_are_done`
194
+ Assess task completion.
@@ -0,0 +1,82 @@
1
+ ---
2
+ name: using-serena-lsp
3
+ description: Explores and edits code using semantic tools and LSP plugins. Use when reading code, understanding structure, finding symbols, or performing surgical edits to functions and classes.
4
+ allowed-tools: mcp__serena__*, Read, Edit, Bash
5
+ priority: high
6
+ ---
7
+
8
+ # Using Serena LSP Workflow
9
+
10
+ **Core Principle**: Use semantic, symbol-level access to understand and edit code without reading entire files. Combine with LSP plugins for real-time analysis.
11
+
12
+ ## Tools Reference
13
+
14
+ **Full Tool Documentation**: See [REFERENCE.md](REFERENCE.md)
15
+
16
+ | Tool | Purpose |
17
+ |------|---------|
18
+ | `get_symbols_overview` | **Start here.** See high-level structure of a file. |
19
+ | `find_symbol` | Read specific functions/classes (set `include_body=true`). |
20
+ | `find_referencing_symbols` | Find usages before editing. |
21
+ | `replace_symbol_body` | Surgically replace a function/class. |
22
+ | `insert_after_symbol` | Add new code after an existing symbol. |
23
+ | `search_for_pattern` | Regex search when symbol names are unknown. |
24
+
25
+ ## Standard Workflows
26
+
27
+ **🚨 MANDATORY FIRST STEP FOR ALL WORKFLOWS:**
28
+
29
+ Before using ANY Serena semantic tools (`get_symbols_overview`, `find_symbol`, `replace_symbol_body`, etc.), you MUST activate the project:
30
+
31
+ ```javascript
32
+ mcp__plugin_serena_serena__activate_project({ project: "/path/to/current/working/directory" })
33
+ ```
34
+
35
+ **Why this is critical**: Without project activation, Serena cannot locate code symbols and will fail or loop indefinitely. This step establishes the working context for all symbolic operations.
36
+
37
+ ---
38
+
39
+ ### 1. Explore Code (The "Overview First" Pattern)
40
+
41
+ Avoid reading full files >300 LOC.
42
+
43
+ 1. **Activate Project**: `mcp__plugin_serena_serena__activate_project()`
44
+ 2. **Understand Structure**: `get_symbols_overview(depth=1)`
45
+ 3. **Drill Down**: `find_symbol(name_path="...", include_body=true)`
46
+ 4. **Reflect**: `think_about_collected_information()`
47
+
48
+ ### 2. Surgical Editing
49
+
50
+ 1. **Activate Project**: `mcp__plugin_serena_serena__activate_project()` (if not already done)
51
+ 2. **Locate**: `find_symbol(include_body=true)` to get current code.
52
+ 3. **Check Impact**: `find_referencing_symbols()` to find usages.
53
+ 4. **Edit**: `replace_symbol_body(...)` to update.
54
+ 5. **Verify**: Run tests or syntax checks (e.g., `python -m py_compile`).
55
+
56
+ ### 3. Adding Features
57
+
58
+ 1. **Activate Project**: `mcp__plugin_serena_serena__activate_project()` (if not already done)
59
+ 2. **Context**: `read_memory()` or `get_symbols_overview()` to understand patterns.
60
+ 3. **Locate Anchor**: `find_symbol()` to find where to insert.
61
+ 4. **Insert**: `insert_after_symbol(...)` to add new class/function.
62
+
63
+ ## File Size Guidelines
64
+
65
+ | Lines of Code | Recommended Approach |
66
+ |---------------|----------------------|
67
+ | < 100 LOC | `Read` is acceptable. |
68
+ | 100-300 LOC | `get_symbols_overview` → `find_symbol`. |
69
+ | > 300 LOC | **Semantic only.** Do not read full file. |
70
+
71
+ ## Quick Tips
72
+
73
+ * **LSP Integration**: `Read()` on a Python file automatically triggers Pyright analysis. Use the feedback to fix type errors surgically.
74
+ * **Symbol Names**: Use `substring_matching=true` if you aren't sure of the exact name.
75
+ * **Safety**: Always find references before renaming or changing signatures.
76
+
77
+ ## ⚠️ Critical Constraints
78
+
79
+ 1. **NEVER skip project activation** - It must be the first Serena operation in any workflow
80
+ 2. **Use the current working directory** - Pass the actual project path, not a placeholder
81
+ 3. **Activate once per session** - After activation, all subsequent Serena tools will work correctly
82
+ 4. **Check activation status** - If Serena tools fail with "symbol not found" errors, you likely forgot to activate