octocode-cli 1.2.6 → 1.2.8

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 (303) hide show
  1. package/LICENSE +21 -63
  2. package/README.md +85 -142
  3. package/out/octocode-cli.js +7063 -6934
  4. package/package.json +8 -6
  5. package/skills/README.md +97 -120
  6. package/skills/octocode-code-engineer/.claude/settings.local.json +18 -0
  7. package/skills/octocode-code-engineer/.octocode/rfc/RFC-code-engineer-weakness-fixes.md +255 -0
  8. package/skills/octocode-code-engineer/.plan/VALIDATED_PLAN.md +223 -0
  9. package/skills/octocode-code-engineer/README.md +178 -0
  10. package/skills/octocode-code-engineer/SKILL.md +418 -0
  11. package/skills/octocode-code-engineer/coverage/architecture.ts.html +7828 -0
  12. package/skills/octocode-code-engineer/coverage/ast-helpers.ts.html +211 -0
  13. package/skills/octocode-code-engineer/coverage/ast-search.ts.html +1795 -0
  14. package/skills/octocode-code-engineer/coverage/base.css +224 -0
  15. package/skills/octocode-code-engineer/coverage/block-navigation.js +87 -0
  16. package/skills/octocode-code-engineer/coverage/cache.ts.html +376 -0
  17. package/skills/octocode-code-engineer/coverage/cli.ts.html +982 -0
  18. package/skills/octocode-code-engineer/coverage/clover.xml +3217 -0
  19. package/skills/octocode-code-engineer/coverage/collect-effects.ts.html +664 -0
  20. package/skills/octocode-code-engineer/coverage/collect-input-sources.ts.html +577 -0
  21. package/skills/octocode-code-engineer/coverage/collect-performance.ts.html +331 -0
  22. package/skills/octocode-code-engineer/coverage/collect-prototype-pollution.ts.html +421 -0
  23. package/skills/octocode-code-engineer/coverage/collect-security.ts.html +604 -0
  24. package/skills/octocode-code-engineer/coverage/collect-test-profile.ts.html +589 -0
  25. package/skills/octocode-code-engineer/coverage/coverage-final.json +30 -0
  26. package/skills/octocode-code-engineer/coverage/dependencies.ts.html +997 -0
  27. package/skills/octocode-code-engineer/coverage/dependency-summary.ts.html +688 -0
  28. package/skills/octocode-code-engineer/coverage/discovery.ts.html +322 -0
  29. package/skills/octocode-code-engineer/coverage/favicon.png +0 -0
  30. package/skills/octocode-code-engineer/coverage/graph-analytics.ts.html +1510 -0
  31. package/skills/octocode-code-engineer/coverage/index.html +536 -0
  32. package/skills/octocode-code-engineer/coverage/index.ts.html +826 -0
  33. package/skills/octocode-code-engineer/coverage/metrics.ts.html +553 -0
  34. package/skills/octocode-code-engineer/coverage/pipeline.ts.html +2044 -0
  35. package/skills/octocode-code-engineer/coverage/prettify.css +1 -0
  36. package/skills/octocode-code-engineer/coverage/prettify.js +2 -0
  37. package/skills/octocode-code-engineer/coverage/report-analysis.ts.html +1570 -0
  38. package/skills/octocode-code-engineer/coverage/report-writer.ts.html +1102 -0
  39. package/skills/octocode-code-engineer/coverage/security-detectors.ts.html +1747 -0
  40. package/skills/octocode-code-engineer/coverage/semantic-detectors.ts.html +2152 -0
  41. package/skills/octocode-code-engineer/coverage/semantic.ts.html +1897 -0
  42. package/skills/octocode-code-engineer/coverage/sort-arrow-sprite.png +0 -0
  43. package/skills/octocode-code-engineer/coverage/sorter.js +210 -0
  44. package/skills/octocode-code-engineer/coverage/summary-md.ts.html +1222 -0
  45. package/skills/octocode-code-engineer/coverage/test-quality-detectors.ts.html +1039 -0
  46. package/skills/octocode-code-engineer/coverage/tree-sitter-analyzer.ts.html +955 -0
  47. package/skills/octocode-code-engineer/coverage/ts-analyzer.ts.html +1213 -0
  48. package/skills/octocode-code-engineer/coverage/types.ts.html +2473 -0
  49. package/skills/octocode-code-engineer/coverage/utils.ts.html +820 -0
  50. package/skills/octocode-code-engineer/eslint.config.mjs +54 -0
  51. package/skills/octocode-code-engineer/minify-scripts.mjs +32 -0
  52. package/skills/octocode-code-engineer/package.json +54 -0
  53. package/skills/octocode-code-engineer/references/agent-ast-reading-rfc.md +95 -0
  54. package/skills/octocode-code-engineer/references/architecture-techniques.md +121 -0
  55. package/skills/octocode-code-engineer/references/ast-search.md +210 -0
  56. package/skills/octocode-code-engineer/references/ast-tree-search.md +151 -0
  57. package/skills/octocode-code-engineer/references/cli-reference.md +167 -0
  58. package/skills/octocode-code-engineer/references/concepts.md +107 -0
  59. package/skills/octocode-code-engineer/references/finding-categories.md +128 -0
  60. package/skills/octocode-code-engineer/references/improvement-roadmap.md +304 -0
  61. package/skills/octocode-code-engineer/references/output-files.md +144 -0
  62. package/skills/octocode-code-engineer/references/playbooks.md +204 -0
  63. package/skills/octocode-code-engineer/references/present-results.md +136 -0
  64. package/skills/octocode-code-engineer/references/tool-workflows.md +566 -0
  65. package/skills/octocode-code-engineer/references/validate-investigate.md +225 -0
  66. package/skills/octocode-code-engineer/scripts/analysis/dependencies.js +1 -0
  67. package/skills/octocode-code-engineer/scripts/analysis/dependency-summary.js +1 -0
  68. package/skills/octocode-code-engineer/scripts/analysis/discovery.js +1 -0
  69. package/skills/octocode-code-engineer/scripts/analysis/graph-analytics.js +1 -0
  70. package/skills/octocode-code-engineer/scripts/analysis/semantic.js +1 -0
  71. package/skills/octocode-code-engineer/scripts/ast/helpers.js +1 -0
  72. package/skills/octocode-code-engineer/scripts/ast/metrics.js +1 -0
  73. package/skills/octocode-code-engineer/scripts/ast/search.js +2 -0
  74. package/skills/octocode-code-engineer/scripts/ast/tree-search.js +2 -0
  75. package/skills/octocode-code-engineer/scripts/ast/tree-sitter.js +1 -0
  76. package/skills/octocode-code-engineer/scripts/ast/ts-analyzer.js +1 -0
  77. package/skills/octocode-code-engineer/scripts/collectors/chains.js +1 -0
  78. package/skills/octocode-code-engineer/scripts/collectors/effects.js +1 -0
  79. package/skills/octocode-code-engineer/scripts/collectors/input-sources.js +1 -0
  80. package/skills/octocode-code-engineer/scripts/collectors/performance.js +1 -0
  81. package/skills/octocode-code-engineer/scripts/collectors/prototype-pollution.js +1 -0
  82. package/skills/octocode-code-engineer/scripts/collectors/security.js +1 -0
  83. package/skills/octocode-code-engineer/scripts/collectors/test-profile.js +1 -0
  84. package/skills/octocode-code-engineer/scripts/common/is-direct-run.js +1 -0
  85. package/skills/octocode-code-engineer/scripts/common/utils.js +1 -0
  86. package/skills/octocode-code-engineer/scripts/detectors/code-quality.js +1 -0
  87. package/skills/octocode-code-engineer/scripts/detectors/cohesion.js +1 -0
  88. package/skills/octocode-code-engineer/scripts/detectors/coupling.js +1 -0
  89. package/skills/octocode-code-engineer/scripts/detectors/cycle.js +1 -0
  90. package/skills/octocode-code-engineer/scripts/detectors/dead-code.js +1 -0
  91. package/skills/octocode-code-engineer/scripts/detectors/import-style.js +1 -0
  92. package/skills/octocode-code-engineer/scripts/detectors/index.js +1 -0
  93. package/skills/octocode-code-engineer/scripts/detectors/security.js +1 -0
  94. package/skills/octocode-code-engineer/scripts/detectors/semantic.js +1 -0
  95. package/skills/octocode-code-engineer/scripts/detectors/shared.js +1 -0
  96. package/skills/octocode-code-engineer/scripts/detectors/test-quality.js +1 -0
  97. package/skills/octocode-code-engineer/scripts/index.js +1 -0
  98. package/skills/octocode-code-engineer/scripts/pipeline/cache.js +1 -0
  99. package/skills/octocode-code-engineer/scripts/pipeline/cli.js +1 -0
  100. package/skills/octocode-code-engineer/scripts/pipeline/main.js +2 -0
  101. package/skills/octocode-code-engineer/scripts/reporting/analysis.js +1 -0
  102. package/skills/octocode-code-engineer/scripts/reporting/summary-md.js +1 -0
  103. package/skills/octocode-code-engineer/scripts/reporting/writer.js +1 -0
  104. package/skills/octocode-code-engineer/scripts/types/constants.js +1 -0
  105. package/skills/octocode-code-engineer/scripts/types/index.js +1 -0
  106. package/skills/octocode-code-engineer/scripts/types/interfaces.js +1 -0
  107. package/skills/octocode-code-engineer/src/analysis/dependencies.test.ts +545 -0
  108. package/skills/octocode-code-engineer/src/analysis/dependencies.ts +406 -0
  109. package/skills/octocode-code-engineer/src/analysis/dependency-summary.test.ts +566 -0
  110. package/skills/octocode-code-engineer/src/analysis/dependency-summary.ts +257 -0
  111. package/skills/octocode-code-engineer/src/analysis/discovery.test.ts +420 -0
  112. package/skills/octocode-code-engineer/src/analysis/discovery.ts +87 -0
  113. package/skills/octocode-code-engineer/src/analysis/graph-analytics.test.ts +449 -0
  114. package/skills/octocode-code-engineer/src/analysis/graph-analytics.ts +534 -0
  115. package/skills/octocode-code-engineer/src/analysis/semantic.test.ts +1533 -0
  116. package/skills/octocode-code-engineer/src/analysis/semantic.ts +830 -0
  117. package/skills/octocode-code-engineer/src/ast/helpers.test.ts +185 -0
  118. package/skills/octocode-code-engineer/src/ast/helpers.ts +62 -0
  119. package/skills/octocode-code-engineer/src/ast/metrics.test.ts +304 -0
  120. package/skills/octocode-code-engineer/src/ast/metrics.ts +204 -0
  121. package/skills/octocode-code-engineer/src/ast/search.test.ts +647 -0
  122. package/skills/octocode-code-engineer/src/ast/search.ts +648 -0
  123. package/skills/octocode-code-engineer/src/ast/tree-search.test.ts +199 -0
  124. package/skills/octocode-code-engineer/src/ast/tree-search.ts +392 -0
  125. package/skills/octocode-code-engineer/src/ast/tree-sitter.test.ts +407 -0
  126. package/skills/octocode-code-engineer/src/ast/tree-sitter.ts +402 -0
  127. package/skills/octocode-code-engineer/src/ast/ts-analyzer.test.ts +1864 -0
  128. package/skills/octocode-code-engineer/src/ast/ts-analyzer.ts +509 -0
  129. package/skills/octocode-code-engineer/src/collectors/chains.ts +74 -0
  130. package/skills/octocode-code-engineer/src/collectors/effects.test.ts +490 -0
  131. package/skills/octocode-code-engineer/src/collectors/effects.ts +332 -0
  132. package/skills/octocode-code-engineer/src/collectors/input-sources.test.ts +144 -0
  133. package/skills/octocode-code-engineer/src/collectors/input-sources.ts +196 -0
  134. package/skills/octocode-code-engineer/src/collectors/performance.test.ts +82 -0
  135. package/skills/octocode-code-engineer/src/collectors/performance.ts +141 -0
  136. package/skills/octocode-code-engineer/src/collectors/prototype-pollution.test.ts +55 -0
  137. package/skills/octocode-code-engineer/src/collectors/prototype-pollution.ts +162 -0
  138. package/skills/octocode-code-engineer/src/collectors/security.test.ts +124 -0
  139. package/skills/octocode-code-engineer/src/collectors/security.ts +309 -0
  140. package/skills/octocode-code-engineer/src/collectors/test-profile.test.ts +97 -0
  141. package/skills/octocode-code-engineer/src/collectors/test-profile.ts +269 -0
  142. package/skills/octocode-code-engineer/src/common/is-direct-run.test.ts +32 -0
  143. package/skills/octocode-code-engineer/src/common/is-direct-run.ts +13 -0
  144. package/skills/octocode-code-engineer/src/common/utils.test.ts +463 -0
  145. package/skills/octocode-code-engineer/src/common/utils.ts +304 -0
  146. package/skills/octocode-code-engineer/src/detectors/code-quality.ts +966 -0
  147. package/skills/octocode-code-engineer/src/detectors/cohesion.ts +539 -0
  148. package/skills/octocode-code-engineer/src/detectors/coupling.ts +323 -0
  149. package/skills/octocode-code-engineer/src/detectors/cycle.ts +349 -0
  150. package/skills/octocode-code-engineer/src/detectors/dead-code.ts +320 -0
  151. package/skills/octocode-code-engineer/src/detectors/import-style.ts +376 -0
  152. package/skills/octocode-code-engineer/src/detectors/index.test.ts +3061 -0
  153. package/skills/octocode-code-engineer/src/detectors/index.ts +88 -0
  154. package/skills/octocode-code-engineer/src/detectors/security.test.ts +882 -0
  155. package/skills/octocode-code-engineer/src/detectors/security.ts +821 -0
  156. package/skills/octocode-code-engineer/src/detectors/semantic.ts +758 -0
  157. package/skills/octocode-code-engineer/src/detectors/shared.ts +49 -0
  158. package/skills/octocode-code-engineer/src/detectors/test-quality.test.ts +388 -0
  159. package/skills/octocode-code-engineer/src/detectors/test-quality.ts +367 -0
  160. package/skills/octocode-code-engineer/src/index.test.ts +4425 -0
  161. package/skills/octocode-code-engineer/src/index.ts +403 -0
  162. package/skills/octocode-code-engineer/src/pipeline/cache.test.ts +199 -0
  163. package/skills/octocode-code-engineer/src/pipeline/cache.ts +130 -0
  164. package/skills/octocode-code-engineer/src/pipeline/cli.test.ts +493 -0
  165. package/skills/octocode-code-engineer/src/pipeline/cli.ts +344 -0
  166. package/skills/octocode-code-engineer/src/pipeline/main.test.ts +174 -0
  167. package/skills/octocode-code-engineer/src/pipeline/main.ts +1074 -0
  168. package/skills/octocode-code-engineer/src/pipeline.test.ts +84 -0
  169. package/skills/octocode-code-engineer/src/reporting/analysis.test.ts +782 -0
  170. package/skills/octocode-code-engineer/src/reporting/analysis.ts +688 -0
  171. package/skills/octocode-code-engineer/src/reporting/output-contract.test.ts +463 -0
  172. package/skills/octocode-code-engineer/src/reporting/summary-md.test.ts +421 -0
  173. package/skills/octocode-code-engineer/src/reporting/summary-md.ts +714 -0
  174. package/skills/octocode-code-engineer/src/reporting/writer.ts +430 -0
  175. package/skills/octocode-code-engineer/src/sanity.test.ts +47 -0
  176. package/skills/octocode-code-engineer/src/types/constants.ts +248 -0
  177. package/skills/octocode-code-engineer/src/types/index.ts +80 -0
  178. package/skills/octocode-code-engineer/src/types/interfaces.ts +682 -0
  179. package/skills/octocode-code-engineer/tsconfig.json +17 -0
  180. package/skills/octocode-code-engineer/vitest.config.ts +8 -0
  181. package/skills/octocode-documentation-writer/README.md +113 -0
  182. package/skills/octocode-documentation-writer/SKILL.md +886 -0
  183. package/skills/octocode-documentation-writer/references/agent-discovery-analysis.md +453 -0
  184. package/skills/octocode-documentation-writer/references/agent-documentation-writer.md +255 -0
  185. package/skills/octocode-documentation-writer/references/agent-engineer-questions.md +247 -0
  186. package/skills/octocode-documentation-writer/references/agent-orchestrator.md +370 -0
  187. package/skills/octocode-documentation-writer/references/agent-qa-validator.md +227 -0
  188. package/skills/octocode-documentation-writer/references/agent-researcher.md +250 -0
  189. package/skills/octocode-documentation-writer/schemas/analysis-schema.json +886 -0
  190. package/skills/octocode-documentation-writer/schemas/discovery-tasks.json +96 -0
  191. package/skills/octocode-documentation-writer/schemas/documentation-structure.json +373 -0
  192. package/skills/octocode-documentation-writer/schemas/partial-discovery-schema.json +102 -0
  193. package/skills/octocode-documentation-writer/schemas/partial-research-schema.json +98 -0
  194. package/skills/octocode-documentation-writer/schemas/qa-results-schema.json +113 -0
  195. package/skills/octocode-documentation-writer/schemas/questions-schema.json +228 -0
  196. package/skills/octocode-documentation-writer/schemas/research-schema.json +104 -0
  197. package/skills/octocode-documentation-writer/schemas/state-schema.json +222 -0
  198. package/skills/octocode-documentation-writer/schemas/work-assignments-schema.json +74 -0
  199. package/skills/octocode-plan/SKILL.md +122 -116
  200. package/skills/octocode-prompt-optimizer/SKILL.md +617 -0
  201. package/skills/octocode-pull-request-reviewer/README.md +249 -0
  202. package/skills/octocode-pull-request-reviewer/SKILL.md +479 -0
  203. package/skills/octocode-pull-request-reviewer/references/dependency-check.md +74 -0
  204. package/skills/octocode-pull-request-reviewer/references/domain-reviewers.md +24 -0
  205. package/skills/octocode-pull-request-reviewer/references/execution-lifecycle.md +441 -0
  206. package/skills/octocode-pull-request-reviewer/references/flow-analysis-protocol.md +64 -0
  207. package/skills/octocode-pull-request-reviewer/references/output-template.md +174 -0
  208. package/skills/octocode-pull-request-reviewer/references/parallel-agent-protocol.md +182 -0
  209. package/skills/octocode-pull-request-reviewer/references/review-guidelines.md +26 -0
  210. package/skills/octocode-pull-request-reviewer/references/verification-checklist.md +40 -0
  211. package/skills/octocode-research/.claude/settings.local.json +46 -0
  212. package/skills/octocode-research/.octocode/plan/code-review-fixes/plan.md +312 -0
  213. package/skills/octocode-research/.octocode/plan/code-review-fixes/research.md +212 -0
  214. package/skills/octocode-research/.octocode/plans/NODE_SERVER_START_PLAN.md +755 -0
  215. package/skills/octocode-research/.octocode/research/code-review/research.md +371 -0
  216. package/skills/octocode-research/.octocode/review/IMPROVEMENTS.md +391 -0
  217. package/skills/octocode-research/.octocode/review/REVIEW_PLAN.md +289 -0
  218. package/skills/octocode-research/.octocode/review/REVIEW_REPORT.md +356 -0
  219. package/skills/octocode-research/AGENTS.md +349 -0
  220. package/skills/octocode-research/README.md +494 -0
  221. package/skills/octocode-research/SKILL.md +652 -274
  222. package/skills/octocode-research/docs/API_REFERENCE.md +562 -0
  223. package/skills/octocode-research/docs/ARCHITECTURE.md +554 -0
  224. package/skills/octocode-research/docs/FLOWS.md +577 -0
  225. package/skills/octocode-research/docs/OVERVIEW.md +564 -0
  226. package/skills/octocode-research/docs/SERVER_FLOWS.md +631 -0
  227. package/skills/octocode-research/ecosystem.config.cjs +88 -0
  228. package/skills/octocode-research/eslint.config.mjs +27 -0
  229. package/skills/octocode-research/package.json +84 -0
  230. package/skills/octocode-research/references/GUARDRAILS.md +40 -0
  231. package/skills/octocode-research/references/PARALLEL_AGENT_PROTOCOL.md +178 -0
  232. package/skills/octocode-research/references/roast-prompt.md +149 -0
  233. package/skills/octocode-research/scripts/server-init.d.ts +2 -0
  234. package/skills/octocode-research/scripts/server-init.js +2 -0
  235. package/skills/octocode-research/scripts/server.d.ts +8 -0
  236. package/skills/octocode-research/scripts/server.js +445 -0
  237. package/skills/octocode-research/src/__tests__/integration/circuitBreaker.test.ts +205 -0
  238. package/skills/octocode-research/src/__tests__/integration/routes.test.ts +374 -0
  239. package/skills/octocode-research/src/__tests__/unit/circuitBreaker.test.ts +245 -0
  240. package/skills/octocode-research/src/__tests__/unit/errorHandler.test.ts +183 -0
  241. package/skills/octocode-research/src/__tests__/unit/httpPreprocess.test.ts +157 -0
  242. package/skills/octocode-research/src/__tests__/unit/logger.test.ts +143 -0
  243. package/skills/octocode-research/src/__tests__/unit/queryParser.test.ts +130 -0
  244. package/skills/octocode-research/src/__tests__/unit/responseBuilder.test.ts +469 -0
  245. package/skills/octocode-research/src/__tests__/unit/retry.test.ts +205 -0
  246. package/skills/octocode-research/src/index.ts +186 -0
  247. package/skills/octocode-research/src/mcpCache.ts +49 -0
  248. package/skills/octocode-research/src/middleware/errorHandler.ts +65 -0
  249. package/skills/octocode-research/src/middleware/logger.ts +61 -0
  250. package/skills/octocode-research/src/middleware/queryParser.ts +115 -0
  251. package/skills/octocode-research/src/middleware/readiness.ts +17 -0
  252. package/skills/octocode-research/src/routes/github.ts +197 -0
  253. package/skills/octocode-research/src/routes/local.ts +175 -0
  254. package/skills/octocode-research/src/routes/lsp.ts +177 -0
  255. package/skills/octocode-research/src/routes/package.ts +127 -0
  256. package/skills/octocode-research/src/routes/prompts.ts +138 -0
  257. package/skills/octocode-research/src/routes/tools.ts +677 -0
  258. package/skills/octocode-research/src/server-init.ts +363 -0
  259. package/skills/octocode-research/src/server.ts +285 -0
  260. package/skills/octocode-research/src/types/errorGuards.ts +151 -0
  261. package/skills/octocode-research/src/types/express.d.ts +76 -0
  262. package/skills/octocode-research/src/types/guards.ts +98 -0
  263. package/skills/octocode-research/src/types/mcp.ts +119 -0
  264. package/skills/octocode-research/src/types/responses.ts +199 -0
  265. package/skills/octocode-research/src/types/toolTypes.ts +33 -0
  266. package/skills/octocode-research/src/utils/asyncTimeout.ts +116 -0
  267. package/skills/octocode-research/src/utils/circuitBreaker.ts +492 -0
  268. package/skills/octocode-research/src/utils/colors.ts +53 -0
  269. package/skills/octocode-research/src/utils/errorQueue.ts +71 -0
  270. package/skills/octocode-research/src/utils/logEmoji.ts +103 -0
  271. package/skills/octocode-research/src/utils/logger.ts +413 -0
  272. package/skills/octocode-research/src/utils/resilience.ts +169 -0
  273. package/skills/octocode-research/src/utils/responseBuilder.ts +495 -0
  274. package/skills/octocode-research/src/utils/responseFactory.ts +100 -0
  275. package/skills/octocode-research/src/utils/responseParser.ts +272 -0
  276. package/skills/octocode-research/src/utils/retry.ts +280 -0
  277. package/skills/octocode-research/src/utils/routeFactory.ts +117 -0
  278. package/skills/octocode-research/src/utils/url.ts +20 -0
  279. package/skills/octocode-research/src/validation/httpPreprocess.ts +155 -0
  280. package/skills/octocode-research/src/validation/index.ts +2 -0
  281. package/skills/octocode-research/src/validation/schemas.ts +578 -0
  282. package/skills/octocode-research/src/validation/toolCallSchema.ts +132 -0
  283. package/skills/octocode-research/tsconfig.json +21 -0
  284. package/skills/octocode-research/tsdown.config.ts +42 -0
  285. package/skills/octocode-research/vitest.config.ts +20 -0
  286. package/skills/octocode-researcher/SKILL.md +461 -0
  287. package/skills/octocode-researcher/references/fallbacks.md +120 -0
  288. package/skills/{octocode-local-search → octocode-researcher}/references/tool-reference.md +132 -49
  289. package/skills/{octocode-local-search → octocode-researcher}/references/workflow-patterns.md +204 -4
  290. package/skills/octocode-rfc-generator/SKILL.md +223 -0
  291. package/skills/octocode-rfc-generator/references/rfc-template.md +193 -0
  292. package/skills/octocode-roast/SKILL.md +63 -21
  293. package/skills/octocode-implement/SKILL.md +0 -293
  294. package/skills/octocode-implement/references/execution-phases.md +0 -317
  295. package/skills/octocode-implement/references/tool-reference.md +0 -403
  296. package/skills/octocode-implement/references/workflow-patterns.md +0 -385
  297. package/skills/octocode-local-search/SKILL.md +0 -449
  298. package/skills/octocode-pr-review/SKILL.md +0 -391
  299. package/skills/octocode-pr-review/references/domain-reviewers.md +0 -105
  300. package/skills/octocode-pr-review/references/execution-lifecycle.md +0 -116
  301. package/skills/octocode-pr-review/references/research-flows.md +0 -75
  302. package/skills/octocode-research/references/tool-reference.md +0 -304
  303. package/skills/octocode-research/references/workflow-patterns.md +0 -325
@@ -0,0 +1,490 @@
1
+ import * as ts from 'typescript';
2
+ import { describe, expect, it } from 'vitest';
3
+
4
+ import {
5
+ blockContainsCall,
6
+ collectTopLevelEffects,
7
+ findParentBlock,
8
+ } from './effects.js';
9
+
10
+ function parse(code: string, fileName = '/repo/src/test.ts'): ts.SourceFile {
11
+ return ts.createSourceFile(fileName, code, ts.ScriptTarget.ESNext, true);
12
+ }
13
+
14
+ describe('collectTopLevelEffects', () => {
15
+ describe('effect kinds', () => {
16
+ it('detects side-effect-import (bare import)', () => {
17
+ const src = parse("import './polyfill';");
18
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
19
+ expect(effects).toHaveLength(1);
20
+ expect(effects[0]).toMatchObject({
21
+ kind: 'side-effect-import',
22
+ detail: "import './polyfill'",
23
+ weight: 3,
24
+ confidence: 'medium',
25
+ });
26
+ });
27
+
28
+ it('detects top-level-await', () => {
29
+ const src = parse('await fetch("/api");');
30
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
31
+ expect(effects).toHaveLength(1);
32
+ expect(effects[0]).toMatchObject({
33
+ kind: 'top-level-await',
34
+ detail: 'top-level await',
35
+ weight: 4,
36
+ confidence: 'high',
37
+ });
38
+ });
39
+
40
+ it('detects top-level-await inside control flow (scanNodeForEffects path)', () => {
41
+ const src = parse('if (true) { await Promise.resolve(); }');
42
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
43
+ expect(effects).toHaveLength(1);
44
+ expect(effects[0]).toMatchObject({
45
+ kind: 'top-level-await',
46
+ detail: 'top-level await',
47
+ weight: 4,
48
+ confidence: 'high',
49
+ });
50
+ });
51
+
52
+ it('detects eval()', () => {
53
+ const src = parse('eval("1+1");');
54
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
55
+ expect(effects).toHaveLength(1);
56
+ expect(effects[0]).toMatchObject({
57
+ kind: 'eval',
58
+ detail: 'eval()',
59
+ weight: 8,
60
+ confidence: 'high',
61
+ });
62
+ });
63
+
64
+ it('detects Function() call', () => {
65
+ const src = parse('Function("return 1");');
66
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
67
+ expect(effects).toHaveLength(1);
68
+ expect(effects[0]).toMatchObject({
69
+ kind: 'eval',
70
+ detail: 'Function()',
71
+ weight: 8,
72
+ confidence: 'high',
73
+ });
74
+ });
75
+
76
+ it('detects new Function()', () => {
77
+ const src = parse('new Function("return 1");');
78
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
79
+ expect(effects).toHaveLength(1);
80
+ expect(effects[0]).toMatchObject({
81
+ kind: 'eval',
82
+ detail: 'new Function()',
83
+ weight: 8,
84
+ confidence: 'high',
85
+ });
86
+ });
87
+
88
+ it('detects setTimeout (timer)', () => {
89
+ const src = parse('setTimeout(() => {}, 0);');
90
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
91
+ expect(effects).toHaveLength(1);
92
+ expect(effects[0]).toMatchObject({
93
+ kind: 'timer',
94
+ detail: 'setTimeout()',
95
+ weight: 4,
96
+ confidence: 'high',
97
+ });
98
+ });
99
+
100
+ it('detects setInterval (timer)', () => {
101
+ const src = parse('setInterval(() => {}, 1000);');
102
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
103
+ expect(effects).toHaveLength(1);
104
+ expect(effects[0]).toMatchObject({
105
+ kind: 'timer',
106
+ detail: 'setInterval()',
107
+ weight: 4,
108
+ confidence: 'high',
109
+ });
110
+ });
111
+
112
+ it('detects execSync (exec-sync)', () => {
113
+ const src = parse('const out = require("child_process").execSync("ls");');
114
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
115
+ expect(effects).toHaveLength(1);
116
+ expect(effects[0]).toMatchObject({
117
+ kind: 'exec-sync',
118
+ weight: 8,
119
+ confidence: 'high',
120
+ });
121
+ });
122
+
123
+ it('detects execFileSync (exec-sync)', () => {
124
+ const src = parse(
125
+ 'const cp = require("child_process"); const x = cp.execFileSync("ls");'
126
+ );
127
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
128
+ expect(effects).toHaveLength(1);
129
+ expect(effects[0]).toMatchObject({
130
+ kind: 'exec-sync',
131
+ weight: 8,
132
+ confidence: 'high',
133
+ });
134
+ });
135
+
136
+ it('detects readFileSync (sync-io)', () => {
137
+ const src = parse(
138
+ 'const fs = require("fs"); const data = fs.readFileSync("/path", "utf8");'
139
+ );
140
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
141
+ expect(effects).toHaveLength(1);
142
+ expect(effects[0]).toMatchObject({
143
+ kind: 'sync-io',
144
+ weight: 5,
145
+ confidence: 'high',
146
+ });
147
+ });
148
+
149
+ it('detects writeFileSync (sync-io)', () => {
150
+ const src = parse(
151
+ 'const fs = require("fs"); fs.writeFileSync("/tmp/x", "data");'
152
+ );
153
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
154
+ expect(effects).toHaveLength(1);
155
+ expect(effects[0]).toMatchObject({
156
+ kind: 'sync-io',
157
+ weight: 5,
158
+ confidence: 'high',
159
+ });
160
+ });
161
+
162
+ it('detects process.on (process-handler)', () => {
163
+ const src = parse('process.on("uncaughtException", () => {});');
164
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
165
+ expect(effects).toHaveLength(1);
166
+ expect(effects[0]).toMatchObject({
167
+ kind: 'process-handler',
168
+ detail: 'process.on()',
169
+ weight: 4,
170
+ confidence: 'high',
171
+ });
172
+ });
173
+
174
+ it('detects process.once (process-handler)', () => {
175
+ const src = parse('process.once("SIGINT", () => {});');
176
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
177
+ expect(effects).toHaveLength(1);
178
+ expect(effects[0]).toMatchObject({
179
+ kind: 'process-handler',
180
+ detail: 'process.once()',
181
+ weight: 4,
182
+ confidence: 'high',
183
+ });
184
+ });
185
+
186
+ it('detects process.addListener (process-handler)', () => {
187
+ const src = parse('process.addListener("exit", () => {});');
188
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
189
+ expect(effects).toHaveLength(1);
190
+ expect(effects[0]).toMatchObject({
191
+ kind: 'process-handler',
192
+ detail: 'process.addListener()',
193
+ weight: 4,
194
+ confidence: 'high',
195
+ });
196
+ });
197
+
198
+ it('detects addEventListener (listener)', () => {
199
+ const src = parse('window.addEventListener("load", () => {});');
200
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
201
+ expect(effects).toHaveLength(1);
202
+ expect(effects[0]).toMatchObject({
203
+ kind: 'listener',
204
+ detail: 'window.addEventListener()',
205
+ weight: 4,
206
+ confidence: 'medium',
207
+ });
208
+ });
209
+
210
+ it('detects .on (listener, non-process)', () => {
211
+ const src = parse('emitter.on("event", () => {});');
212
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
213
+ expect(effects).toHaveLength(1);
214
+ expect(effects[0]).toMatchObject({
215
+ kind: 'listener',
216
+ weight: 4,
217
+ confidence: 'medium',
218
+ });
219
+ });
220
+
221
+ it('detects dynamic import()', () => {
222
+ const src = parse("import('./lazy');");
223
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
224
+ expect(effects).toHaveLength(1);
225
+ expect(effects[0]).toMatchObject({
226
+ kind: 'dynamic-import',
227
+ detail: 'dynamic import()',
228
+ weight: 3,
229
+ confidence: 'medium',
230
+ });
231
+ });
232
+ });
233
+
234
+ describe('edge cases - no effects', () => {
235
+ it('empty file produces no effects', () => {
236
+ const src = parse('');
237
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
238
+ expect(effects).toHaveLength(0);
239
+ });
240
+
241
+ it('regular import (with binding) does NOT produce side-effect-import', () => {
242
+ const src = parse("import path from 'node:path';");
243
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
244
+ expect(effects).toHaveLength(0);
245
+ });
246
+
247
+ it('import { x } does NOT produce side-effect-import', () => {
248
+ const src = parse("import { foo } from './bar';");
249
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
250
+ expect(effects).toHaveLength(0);
251
+ });
252
+
253
+ it('function declaration does NOT produce effects', () => {
254
+ const src = parse('function f() { fs.readFileSync("/path"); }');
255
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
256
+ expect(effects).toHaveLength(0);
257
+ });
258
+
259
+ it('class declaration does NOT produce effects', () => {
260
+ const src = parse('class C { m() { setTimeout(() => {}, 0); } }');
261
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
262
+ expect(effects).toHaveLength(0);
263
+ });
264
+
265
+ it('arrow function in variable does NOT produce effects', () => {
266
+ const src = parse('const f = () => { eval("1"); };');
267
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
268
+ expect(effects).toHaveLength(0);
269
+ });
270
+ });
271
+
272
+ describe('variable initializers', () => {
273
+ it('variable initializer with call expression', () => {
274
+ const src = parse(
275
+ 'const fs = require("fs"); const data = fs.readFileSync("/path", "utf8");'
276
+ );
277
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
278
+ expect(effects).toHaveLength(1);
279
+ expect(effects[0].kind).toBe('sync-io');
280
+ });
281
+
282
+ it('binary expression with call on right side (assignment)', () => {
283
+ const src = parse('x = setTimeout(() => {}, 0);');
284
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
285
+ expect(effects).toHaveLength(1);
286
+ expect(effects[0]).toMatchObject({
287
+ kind: 'timer',
288
+ detail: 'setTimeout()',
289
+ });
290
+ });
291
+
292
+ it('variable initializer as binary with call on right', () => {
293
+ const src = parse('let y; const x = y = eval("1");');
294
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
295
+ expect(effects).toHaveLength(1);
296
+ expect(effects[0].kind).toBe('eval');
297
+ });
298
+ });
299
+
300
+ describe('top-level control flow (scanNodeForEffects)', () => {
301
+ it('if statement with call inside', () => {
302
+ const src = parse('if (true) { setTimeout(() => {}, 0); }');
303
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
304
+ expect(effects).toHaveLength(1);
305
+ expect(effects[0]).toMatchObject({ kind: 'timer' });
306
+ });
307
+
308
+ it('for statement with call inside', () => {
309
+ const src = parse('for (let i = 0; i < 1; i++) { eval("1"); }');
310
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
311
+ expect(effects).toHaveLength(1);
312
+ expect(effects[0]).toMatchObject({ kind: 'eval' });
313
+ });
314
+
315
+ it('while statement with call inside', () => {
316
+ const src = parse('while (false) { new Function("1"); }');
317
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
318
+ expect(effects).toHaveLength(1);
319
+ expect(effects[0]).toMatchObject({
320
+ kind: 'eval',
321
+ detail: 'new Function()',
322
+ });
323
+ });
324
+
325
+ it('switch statement with call inside', () => {
326
+ const src = parse(
327
+ 'switch (1) { case 1: setInterval(() => {}, 100); break; }'
328
+ );
329
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
330
+ expect(effects).toHaveLength(1);
331
+ expect(effects[0]).toMatchObject({ kind: 'timer' });
332
+ });
333
+
334
+ it('try statement with call inside', () => {
335
+ const src = parse('try { process.on("exit", () => {}); } catch {}');
336
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
337
+ expect(effects).toHaveLength(1);
338
+ expect(effects[0]).toMatchObject({ kind: 'process-handler' });
339
+ });
340
+
341
+ it('do-while with call inside', () => {
342
+ const src = parse(
343
+ 'const cp = require("child_process"); do { cp.execSync("ls"); } while (false);'
344
+ );
345
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
346
+ expect(effects).toHaveLength(1);
347
+ expect(effects[0]).toMatchObject({ kind: 'exec-sync' });
348
+ });
349
+
350
+ it('for-of with call inside', () => {
351
+ const src = parse(
352
+ 'const fs = require("fs"); for (const x of []) { fs.readFileSync("/x"); }'
353
+ );
354
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
355
+ expect(effects).toHaveLength(1);
356
+ expect(effects[0]).toMatchObject({ kind: 'sync-io' });
357
+ });
358
+
359
+ it('for-in with call inside', () => {
360
+ const src = parse(
361
+ 'for (const k in {}) { document.addEventListener("click", () => {}); }'
362
+ );
363
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
364
+ expect(effects).toHaveLength(1);
365
+ expect(effects[0]).toMatchObject({ kind: 'listener' });
366
+ });
367
+ });
368
+
369
+ describe('skipped statement types', () => {
370
+ it('skips export declaration', () => {
371
+ const src = parse("export { x } from './a';");
372
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
373
+ expect(effects).toHaveLength(0);
374
+ });
375
+
376
+ it('skips type alias', () => {
377
+ const src = parse('type T = string;');
378
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
379
+ expect(effects).toHaveLength(0);
380
+ });
381
+
382
+ it('skips interface declaration', () => {
383
+ const src = parse('interface I {}');
384
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
385
+ expect(effects).toHaveLength(0);
386
+ });
387
+
388
+ it('skips enum declaration', () => {
389
+ const src = parse('enum E { A }');
390
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
391
+ expect(effects).toHaveLength(0);
392
+ });
393
+
394
+ it('skips module declaration', () => {
395
+ const src = parse('declare module "x" {}');
396
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
397
+ expect(effects).toHaveLength(0);
398
+ });
399
+ });
400
+
401
+ describe('process.on with different event names', () => {
402
+ it('detects process.on("uncaughtException")', () => {
403
+ const src = parse('process.on("uncaughtException", () => {});');
404
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
405
+ expect(effects[0]).toMatchObject({ kind: 'process-handler' });
406
+ });
407
+
408
+ it('detects process.on("SIGTERM")', () => {
409
+ const src = parse('process.on("SIGTERM", () => {});');
410
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
411
+ expect(effects[0]).toMatchObject({ kind: 'process-handler' });
412
+ });
413
+
414
+ it('detects process.on("exit")', () => {
415
+ const src = parse('process.on("exit", () => {});');
416
+ const effects = collectTopLevelEffects(src, 'src/test.ts');
417
+ expect(effects[0]).toMatchObject({ kind: 'process-handler' });
418
+ });
419
+ });
420
+ });
421
+
422
+ describe('findParentBlock', () => {
423
+ it('returns Block when node is inside a block', () => {
424
+ const src = parse('function f() { const x = 1; }');
425
+ const fn = src.statements[0] as ts.FunctionDeclaration;
426
+ const block = fn.body!;
427
+ const stmt = block.statements[0];
428
+ expect(findParentBlock(stmt)).toBe(block);
429
+ });
430
+
431
+ it('returns SourceFile when node is top-level statement', () => {
432
+ const src = parse('const x = 1;');
433
+ const stmt = src.statements[0];
434
+ expect(findParentBlock(stmt)).toBe(src);
435
+ });
436
+
437
+ it('returns null when node has no parent (e.g. SourceFile)', () => {
438
+ const src = parse('const x = 1;');
439
+ expect(findParentBlock(src)).toBe(null);
440
+ });
441
+
442
+ it('returns Block for node nested inside block', () => {
443
+ const src = parse('if (true) { if (false) { setTimeout(() => {}); } }');
444
+ const outerIf = src.statements[0] as ts.IfStatement;
445
+ const outerBlock = outerIf.thenStatement as ts.Block;
446
+ const innerIf = outerBlock.statements[0] as ts.IfStatement;
447
+ const innerBlock = innerIf.thenStatement as ts.Block;
448
+ const callStmt = innerBlock.statements[0] as ts.ExpressionStatement;
449
+ expect(findParentBlock(callStmt)).toBe(innerBlock);
450
+ });
451
+ });
452
+
453
+ describe('blockContainsCall', () => {
454
+ it('returns true when block contains call with given name', () => {
455
+ const src = parse('function f() { setTimeout(() => {}, 0); }');
456
+ const fn = src.statements[0] as ts.FunctionDeclaration;
457
+ const block = fn.body!;
458
+ expect(blockContainsCall(block, src, 'setTimeout')).toBe(true);
459
+ });
460
+
461
+ it('returns false when block does not contain call with given name', () => {
462
+ const src = parse('function f() { setInterval(() => {}, 0); }');
463
+ const fn = src.statements[0] as ts.FunctionDeclaration;
464
+ const block = fn.body!;
465
+ expect(blockContainsCall(block, src, 'setTimeout')).toBe(false);
466
+ });
467
+
468
+ it('returns true for nested call', () => {
469
+ const src = parse('function f() { if (true) { eval("1"); } }');
470
+ const fn = src.statements[0] as ts.FunctionDeclaration;
471
+ const block = fn.body!;
472
+ expect(blockContainsCall(block, src, 'eval')).toBe(true);
473
+ });
474
+
475
+ it('returns false for empty block', () => {
476
+ const src = parse('function f() {}');
477
+ const fn = src.statements[0] as ts.FunctionDeclaration;
478
+ const block = fn.body!;
479
+ expect(blockContainsCall(block, src, 'setTimeout')).toBe(false);
480
+ });
481
+
482
+ it('returns true when call is in variable initializer', () => {
483
+ const src = parse(
484
+ 'const fs = require("fs"); function f() { const x = fs.readFileSync("/x"); }'
485
+ );
486
+ const fn = src.statements[1] as ts.FunctionDeclaration;
487
+ const block = fn.body!;
488
+ expect(blockContainsCall(block, src, 'fs.readFileSync')).toBe(true);
489
+ });
490
+ });