bluera-knowledge 0.13.3 → 0.14.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (663) hide show
  1. package/.claude-plugin/plugin.json +1 -1
  2. package/CHANGELOG.md +14 -0
  3. package/commands/uninstall.md +65 -0
  4. package/dist/{chunk-AOSDVRRH.js → chunk-AIS5S77C.js} +2 -2
  5. package/dist/{chunk-XL2UHMBL.js → chunk-UAWKTJWN.js} +134 -15
  6. package/dist/chunk-UAWKTJWN.js.map +1 -0
  7. package/dist/{chunk-AJI5DCKY.js → chunk-Y24ZJRZP.js} +8 -3
  8. package/dist/{chunk-AJI5DCKY.js.map → chunk-Y24ZJRZP.js.map} +1 -1
  9. package/dist/index.js +3 -3
  10. package/dist/mcp/server.js +2 -2
  11. package/dist/workers/background-worker-cli.js +2 -2
  12. package/hooks/check-dependencies.sh +46 -57
  13. package/package.json +12 -1
  14. package/.claude/commands/code-review.md +0 -15
  15. package/.claude/commands/commit.md +0 -34
  16. package/.claude/council-cache/1a43ed5977b8f29afc79a9bf5c4082ee5ad8338c42ab991a4241a48f80c1e46d.json +0 -7
  17. package/.claude/hooks/post-edit-check.sh +0 -40
  18. package/.claude/rules/code-quality.md +0 -12
  19. package/.claude/rules/git.md +0 -5
  20. package/.claude/rules/versioning.md +0 -7
  21. package/.claude/settings.local.json.example +0 -45
  22. package/.claude/skills/atomic-commits/SKILL.md +0 -61
  23. package/.claude/skills/code-review-repo/skill.md +0 -62
  24. package/.editorconfig +0 -15
  25. package/.env.example +0 -21
  26. package/.github/workflows/auto-release.yml +0 -64
  27. package/.github/workflows/ci.yml +0 -168
  28. package/.github/workflows/release.yml +0 -74
  29. package/.github/workflows/update-marketplace.yml +0 -96
  30. package/.husky/pre-commit +0 -48
  31. package/.husky/pre-push +0 -39
  32. package/.mcp.json +0 -11
  33. package/.prettierrc +0 -9
  34. package/.versionrc.json +0 -24
  35. package/CLAUDE.md +0 -110
  36. package/CONTRIBUTING.md +0 -307
  37. package/NOTICE +0 -47
  38. package/SECURITY.md +0 -65
  39. package/bun.lock +0 -2036
  40. package/dist/chunk-XL2UHMBL.js.map +0 -1
  41. package/docs/claude-code-best-practices.md +0 -458
  42. package/docs/cli.md +0 -170
  43. package/docs/commands.md +0 -392
  44. package/docs/crawler-architecture.md +0 -89
  45. package/docs/mcp-integration.md +0 -130
  46. package/docs/token-efficiency.md +0 -91
  47. package/eslint-rules/require-skip-comment.js +0 -81
  48. package/eslint.config.js +0 -103
  49. package/knip.json +0 -43
  50. package/scripts/test-mcp-dev.js +0 -260
  51. package/scripts/validate-npm-release.sh +0 -314
  52. package/src/analysis/adapter-registry.test.ts +0 -211
  53. package/src/analysis/adapter-registry.ts +0 -155
  54. package/src/analysis/ast-parser.test.ts +0 -470
  55. package/src/analysis/ast-parser.ts +0 -198
  56. package/src/analysis/code-graph.test.ts +0 -718
  57. package/src/analysis/code-graph.ts +0 -249
  58. package/src/analysis/dependency-usage-analyzer.test.ts +0 -619
  59. package/src/analysis/dependency-usage-analyzer.ts +0 -433
  60. package/src/analysis/go-ast-parser.test.ts +0 -531
  61. package/src/analysis/go-ast-parser.ts +0 -471
  62. package/src/analysis/language-adapter.ts +0 -127
  63. package/src/analysis/parser-factory.test.ts +0 -210
  64. package/src/analysis/parser-factory.ts +0 -52
  65. package/src/analysis/python-ast-parser.test.ts +0 -210
  66. package/src/analysis/python-ast-parser.ts +0 -34
  67. package/src/analysis/repo-url-resolver.test.ts +0 -533
  68. package/src/analysis/repo-url-resolver.ts +0 -233
  69. package/src/analysis/rust-ast-parser.test.ts +0 -568
  70. package/src/analysis/rust-ast-parser.ts +0 -467
  71. package/src/analysis/tree-sitter-parser.test.ts +0 -297
  72. package/src/analysis/tree-sitter-parser.ts +0 -217
  73. package/src/analysis/zil/index.ts +0 -34
  74. package/src/analysis/zil/zil-adapter.test.ts +0 -187
  75. package/src/analysis/zil/zil-adapter.ts +0 -121
  76. package/src/analysis/zil/zil-lexer.test.ts +0 -222
  77. package/src/analysis/zil/zil-lexer.ts +0 -239
  78. package/src/analysis/zil/zil-parser.test.ts +0 -210
  79. package/src/analysis/zil/zil-parser.ts +0 -360
  80. package/src/analysis/zil/zil-special-forms.ts +0 -193
  81. package/src/cli/commands/crawl.test.ts +0 -1086
  82. package/src/cli/commands/crawl.ts +0 -220
  83. package/src/cli/commands/index-cmd.test.ts +0 -733
  84. package/src/cli/commands/index-cmd.ts +0 -128
  85. package/src/cli/commands/mcp.test.ts +0 -218
  86. package/src/cli/commands/mcp.ts +0 -18
  87. package/src/cli/commands/plugin-api.test.ts +0 -373
  88. package/src/cli/commands/plugin-api.ts +0 -82
  89. package/src/cli/commands/search.test.ts +0 -1047
  90. package/src/cli/commands/search.ts +0 -197
  91. package/src/cli/commands/serve.test.ts +0 -371
  92. package/src/cli/commands/serve.ts +0 -43
  93. package/src/cli/commands/setup.test.ts +0 -895
  94. package/src/cli/commands/setup.ts +0 -176
  95. package/src/cli/commands/store.test.ts +0 -1370
  96. package/src/cli/commands/store.ts +0 -229
  97. package/src/cli/commands/sync.test.ts +0 -54
  98. package/src/cli/commands/sync.ts +0 -313
  99. package/src/cli/index.ts +0 -8
  100. package/src/cli/program.ts +0 -59
  101. package/src/crawl/article-converter.test.ts +0 -576
  102. package/src/crawl/article-converter.ts +0 -142
  103. package/src/crawl/bridge.test.ts +0 -796
  104. package/src/crawl/bridge.ts +0 -339
  105. package/src/crawl/claude-client.test.ts +0 -902
  106. package/src/crawl/claude-client.ts +0 -261
  107. package/src/crawl/intelligent-crawler.test.ts +0 -1028
  108. package/src/crawl/intelligent-crawler.ts +0 -478
  109. package/src/crawl/markdown-utils.test.ts +0 -703
  110. package/src/crawl/markdown-utils.ts +0 -225
  111. package/src/crawl/schemas.ts +0 -114
  112. package/src/db/embeddings.test.ts +0 -79
  113. package/src/db/embeddings.ts +0 -78
  114. package/src/db/index.ts +0 -2
  115. package/src/db/lance.test.ts +0 -479
  116. package/src/db/lance.ts +0 -190
  117. package/src/defaults/repos.ts +0 -67
  118. package/src/index.ts +0 -124
  119. package/src/logging/index.ts +0 -25
  120. package/src/logging/logger.test.ts +0 -75
  121. package/src/logging/logger.ts +0 -145
  122. package/src/logging/payload.test.ts +0 -152
  123. package/src/logging/payload.ts +0 -119
  124. package/src/mcp/cache.test.ts +0 -202
  125. package/src/mcp/cache.ts +0 -103
  126. package/src/mcp/commands/index.ts +0 -22
  127. package/src/mcp/commands/job.commands.ts +0 -48
  128. package/src/mcp/commands/meta.commands.ts +0 -54
  129. package/src/mcp/commands/registry.ts +0 -180
  130. package/src/mcp/commands/store.commands.ts +0 -75
  131. package/src/mcp/commands/sync.commands.test.ts +0 -371
  132. package/src/mcp/commands/sync.commands.ts +0 -263
  133. package/src/mcp/handlers/execute.handler.test.ts +0 -179
  134. package/src/mcp/handlers/execute.handler.ts +0 -23
  135. package/src/mcp/handlers/index.ts +0 -39
  136. package/src/mcp/handlers/job.handler.test.ts +0 -189
  137. package/src/mcp/handlers/job.handler.ts +0 -118
  138. package/src/mcp/handlers/search.handler.test.ts +0 -324
  139. package/src/mcp/handlers/search.handler.ts +0 -287
  140. package/src/mcp/handlers/store.handler.test.ts +0 -408
  141. package/src/mcp/handlers/store.handler.ts +0 -318
  142. package/src/mcp/plugin-mcp-config.test.ts +0 -71
  143. package/src/mcp/schemas/index.test.ts +0 -356
  144. package/src/mcp/schemas/index.ts +0 -155
  145. package/src/mcp/server.test.ts +0 -91
  146. package/src/mcp/server.ts +0 -235
  147. package/src/mcp/types.ts +0 -41
  148. package/src/plugin/commands.test.ts +0 -925
  149. package/src/plugin/commands.ts +0 -311
  150. package/src/plugin/dependency-analyzer.test.ts +0 -380
  151. package/src/plugin/dependency-analyzer.ts +0 -210
  152. package/src/plugin/git-clone.test.ts +0 -387
  153. package/src/plugin/git-clone.ts +0 -57
  154. package/src/scripts/validate-npm-release.test.ts +0 -70
  155. package/src/server/app.test.ts +0 -752
  156. package/src/server/app.ts +0 -128
  157. package/src/server/index.test.ts +0 -475
  158. package/src/server/index.ts +0 -1
  159. package/src/services/chunking.service.test.ts +0 -363
  160. package/src/services/chunking.service.ts +0 -380
  161. package/src/services/code-graph.service.test.ts +0 -298
  162. package/src/services/code-graph.service.ts +0 -326
  163. package/src/services/code-unit.service.test.ts +0 -693
  164. package/src/services/code-unit.service.ts +0 -234
  165. package/src/services/config.service.test.ts +0 -146
  166. package/src/services/config.service.ts +0 -92
  167. package/src/services/gitignore.service.test.ts +0 -157
  168. package/src/services/gitignore.service.ts +0 -132
  169. package/src/services/index.service.test.ts +0 -2301
  170. package/src/services/index.service.ts +0 -442
  171. package/src/services/index.ts +0 -119
  172. package/src/services/job.service.test.ts +0 -531
  173. package/src/services/job.service.ts +0 -298
  174. package/src/services/project-root.service.test.ts +0 -504
  175. package/src/services/project-root.service.ts +0 -112
  176. package/src/services/search.service.test.ts +0 -2263
  177. package/src/services/search.service.ts +0 -1341
  178. package/src/services/services.test.ts +0 -108
  179. package/src/services/snippet.service.test.ts +0 -213
  180. package/src/services/snippet.service.ts +0 -193
  181. package/src/services/store-definition.service.test.ts +0 -440
  182. package/src/services/store-definition.service.ts +0 -198
  183. package/src/services/store.service.test.ts +0 -843
  184. package/src/services/store.service.ts +0 -363
  185. package/src/services/token.service.test.ts +0 -45
  186. package/src/services/token.service.ts +0 -33
  187. package/src/services/watch.service.test.ts +0 -600
  188. package/src/services/watch.service.ts +0 -84
  189. package/src/types/brands.test.ts +0 -47
  190. package/src/types/brands.ts +0 -32
  191. package/src/types/config.ts +0 -79
  192. package/src/types/document.ts +0 -54
  193. package/src/types/index.ts +0 -73
  194. package/src/types/job.ts +0 -61
  195. package/src/types/progress.ts +0 -9
  196. package/src/types/result.test.ts +0 -54
  197. package/src/types/result.ts +0 -41
  198. package/src/types/search.ts +0 -105
  199. package/src/types/store-definition.test.ts +0 -492
  200. package/src/types/store-definition.ts +0 -129
  201. package/src/types/store.test.ts +0 -69
  202. package/src/types/store.ts +0 -47
  203. package/src/utils/type-guards.test.ts +0 -351
  204. package/src/utils/type-guards.ts +0 -61
  205. package/src/workers/background-worker-cli.test.ts +0 -35
  206. package/src/workers/background-worker-cli.ts +0 -149
  207. package/src/workers/background-worker.test.ts +0 -222
  208. package/src/workers/background-worker.ts +0 -322
  209. package/src/workers/pid-file.test.ts +0 -167
  210. package/src/workers/pid-file.ts +0 -82
  211. package/src/workers/spawn-worker.test.ts +0 -194
  212. package/src/workers/spawn-worker.ts +0 -70
  213. package/tests/analysis/ast-parser.test.ts +0 -98
  214. package/tests/analysis/code-graph.test.ts +0 -60
  215. package/tests/fixtures/README.md +0 -114
  216. package/tests/fixtures/code-snippets/api/error-handling.ts +0 -256
  217. package/tests/fixtures/code-snippets/api/rest-controller.ts +0 -297
  218. package/tests/fixtures/code-snippets/auth/jwt-auth.ts +0 -197
  219. package/tests/fixtures/code-snippets/auth/oauth-flow.ts +0 -245
  220. package/tests/fixtures/code-snippets/database/repository-pattern.ts +0 -280
  221. package/tests/fixtures/corpus/VERSION.md +0 -25
  222. package/tests/fixtures/corpus/articles/jwt-authentication.md +0 -97
  223. package/tests/fixtures/corpus/articles/react-hooks-patterns.md +0 -127
  224. package/tests/fixtures/corpus/articles/typescript-generics.md +0 -111
  225. package/tests/fixtures/corpus/documentation/express-middleware.md +0 -71
  226. package/tests/fixtures/corpus/documentation/express-routing.md +0 -83
  227. package/tests/fixtures/corpus/documentation/node-streams.md +0 -78
  228. package/tests/fixtures/corpus/oss-repos/express/History.md +0 -3871
  229. package/tests/fixtures/corpus/oss-repos/express/LICENSE +0 -24
  230. package/tests/fixtures/corpus/oss-repos/express/README.md +0 -276
  231. package/tests/fixtures/corpus/oss-repos/express/SECURITY.md +0 -56
  232. package/tests/fixtures/corpus/oss-repos/express/benchmarks/Makefile +0 -17
  233. package/tests/fixtures/corpus/oss-repos/express/benchmarks/README.md +0 -34
  234. package/tests/fixtures/corpus/oss-repos/express/benchmarks/middleware.js +0 -20
  235. package/tests/fixtures/corpus/oss-repos/express/benchmarks/run +0 -18
  236. package/tests/fixtures/corpus/oss-repos/express/examples/README.md +0 -29
  237. package/tests/fixtures/corpus/oss-repos/express/examples/auth/index.js +0 -134
  238. package/tests/fixtures/corpus/oss-repos/express/examples/auth/views/foot.ejs +0 -2
  239. package/tests/fixtures/corpus/oss-repos/express/examples/auth/views/head.ejs +0 -20
  240. package/tests/fixtures/corpus/oss-repos/express/examples/auth/views/login.ejs +0 -21
  241. package/tests/fixtures/corpus/oss-repos/express/examples/content-negotiation/db.js +0 -9
  242. package/tests/fixtures/corpus/oss-repos/express/examples/content-negotiation/index.js +0 -46
  243. package/tests/fixtures/corpus/oss-repos/express/examples/content-negotiation/users.js +0 -19
  244. package/tests/fixtures/corpus/oss-repos/express/examples/cookie-sessions/index.js +0 -25
  245. package/tests/fixtures/corpus/oss-repos/express/examples/cookies/index.js +0 -53
  246. package/tests/fixtures/corpus/oss-repos/express/examples/downloads/files/CCTV/345/244/247/350/265/233/344/270/212/346/265/267/345/210/206/350/265/233/345/214/272.txt +0 -2
  247. package/tests/fixtures/corpus/oss-repos/express/examples/downloads/files/amazing.txt +0 -1
  248. package/tests/fixtures/corpus/oss-repos/express/examples/downloads/files/notes/groceries.txt +0 -3
  249. package/tests/fixtures/corpus/oss-repos/express/examples/downloads/index.js +0 -40
  250. package/tests/fixtures/corpus/oss-repos/express/examples/ejs/index.js +0 -57
  251. package/tests/fixtures/corpus/oss-repos/express/examples/ejs/public/stylesheets/style.css +0 -4
  252. package/tests/fixtures/corpus/oss-repos/express/examples/ejs/views/footer.html +0 -2
  253. package/tests/fixtures/corpus/oss-repos/express/examples/ejs/views/header.html +0 -9
  254. package/tests/fixtures/corpus/oss-repos/express/examples/ejs/views/users.html +0 -10
  255. package/tests/fixtures/corpus/oss-repos/express/examples/error/index.js +0 -53
  256. package/tests/fixtures/corpus/oss-repos/express/examples/error-pages/index.js +0 -103
  257. package/tests/fixtures/corpus/oss-repos/express/examples/error-pages/views/404.ejs +0 -3
  258. package/tests/fixtures/corpus/oss-repos/express/examples/error-pages/views/500.ejs +0 -8
  259. package/tests/fixtures/corpus/oss-repos/express/examples/error-pages/views/error_header.ejs +0 -10
  260. package/tests/fixtures/corpus/oss-repos/express/examples/error-pages/views/footer.ejs +0 -2
  261. package/tests/fixtures/corpus/oss-repos/express/examples/error-pages/views/index.ejs +0 -20
  262. package/tests/fixtures/corpus/oss-repos/express/examples/hello-world/index.js +0 -15
  263. package/tests/fixtures/corpus/oss-repos/express/examples/markdown/index.js +0 -44
  264. package/tests/fixtures/corpus/oss-repos/express/examples/markdown/views/index.md +0 -4
  265. package/tests/fixtures/corpus/oss-repos/express/examples/multi-router/controllers/api_v1.js +0 -15
  266. package/tests/fixtures/corpus/oss-repos/express/examples/multi-router/controllers/api_v2.js +0 -15
  267. package/tests/fixtures/corpus/oss-repos/express/examples/multi-router/index.js +0 -18
  268. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/main/index.js +0 -5
  269. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/pet/index.js +0 -31
  270. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/pet/views/edit.ejs +0 -17
  271. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/pet/views/show.ejs +0 -15
  272. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/user/index.js +0 -41
  273. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/user/views/edit.hbs +0 -27
  274. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/user/views/list.hbs +0 -18
  275. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/user/views/show.hbs +0 -31
  276. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/controllers/user-pet/index.js +0 -22
  277. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/db.js +0 -16
  278. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/index.js +0 -95
  279. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/lib/boot.js +0 -83
  280. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/public/style.css +0 -14
  281. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/views/404.ejs +0 -13
  282. package/tests/fixtures/corpus/oss-repos/express/examples/mvc/views/5xx.ejs +0 -13
  283. package/tests/fixtures/corpus/oss-repos/express/examples/online/index.js +0 -61
  284. package/tests/fixtures/corpus/oss-repos/express/examples/params/index.js +0 -74
  285. package/tests/fixtures/corpus/oss-repos/express/examples/resource/index.js +0 -95
  286. package/tests/fixtures/corpus/oss-repos/express/examples/route-map/index.js +0 -75
  287. package/tests/fixtures/corpus/oss-repos/express/examples/route-middleware/index.js +0 -90
  288. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/index.js +0 -55
  289. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/post.js +0 -13
  290. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/public/style.css +0 -24
  291. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/site.js +0 -5
  292. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/user.js +0 -47
  293. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/views/footer.ejs +0 -2
  294. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/views/header.ejs +0 -9
  295. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/views/index.ejs +0 -10
  296. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/views/posts/index.ejs +0 -12
  297. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/views/users/edit.ejs +0 -23
  298. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/views/users/index.ejs +0 -14
  299. package/tests/fixtures/corpus/oss-repos/express/examples/route-separation/views/users/view.ejs +0 -9
  300. package/tests/fixtures/corpus/oss-repos/express/examples/search/index.js +0 -61
  301. package/tests/fixtures/corpus/oss-repos/express/examples/search/public/client.js +0 -15
  302. package/tests/fixtures/corpus/oss-repos/express/examples/search/public/index.html +0 -21
  303. package/tests/fixtures/corpus/oss-repos/express/examples/session/index.js +0 -37
  304. package/tests/fixtures/corpus/oss-repos/express/examples/session/redis.js +0 -39
  305. package/tests/fixtures/corpus/oss-repos/express/examples/static-files/index.js +0 -43
  306. package/tests/fixtures/corpus/oss-repos/express/examples/static-files/public/css/style.css +0 -3
  307. package/tests/fixtures/corpus/oss-repos/express/examples/static-files/public/hello.txt +0 -1
  308. package/tests/fixtures/corpus/oss-repos/express/examples/static-files/public/js/app.js +0 -1
  309. package/tests/fixtures/corpus/oss-repos/express/examples/vhost/index.js +0 -53
  310. package/tests/fixtures/corpus/oss-repos/express/examples/view-constructor/github-view.js +0 -53
  311. package/tests/fixtures/corpus/oss-repos/express/examples/view-constructor/index.js +0 -48
  312. package/tests/fixtures/corpus/oss-repos/express/examples/view-locals/index.js +0 -155
  313. package/tests/fixtures/corpus/oss-repos/express/examples/view-locals/user.js +0 -36
  314. package/tests/fixtures/corpus/oss-repos/express/examples/view-locals/views/index.ejs +0 -20
  315. package/tests/fixtures/corpus/oss-repos/express/examples/web-service/index.js +0 -117
  316. package/tests/fixtures/corpus/oss-repos/express/index.js +0 -11
  317. package/tests/fixtures/corpus/oss-repos/express/lib/application.js +0 -631
  318. package/tests/fixtures/corpus/oss-repos/express/lib/express.js +0 -81
  319. package/tests/fixtures/corpus/oss-repos/express/lib/request.js +0 -514
  320. package/tests/fixtures/corpus/oss-repos/express/lib/response.js +0 -1053
  321. package/tests/fixtures/corpus/oss-repos/express/lib/utils.js +0 -271
  322. package/tests/fixtures/corpus/oss-repos/express/lib/view.js +0 -205
  323. package/tests/fixtures/corpus/oss-repos/express/package.json +0 -99
  324. package/tests/fixtures/corpus/oss-repos/express/test/Route.js +0 -274
  325. package/tests/fixtures/corpus/oss-repos/express/test/Router.js +0 -636
  326. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/auth.js +0 -117
  327. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/content-negotiation.js +0 -49
  328. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/cookie-sessions.js +0 -38
  329. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/cookies.js +0 -71
  330. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/downloads.js +0 -47
  331. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/ejs.js +0 -17
  332. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/error-pages.js +0 -99
  333. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/error.js +0 -29
  334. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/hello-world.js +0 -21
  335. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/markdown.js +0 -21
  336. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/multi-router.js +0 -44
  337. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/mvc.js +0 -132
  338. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/params.js +0 -44
  339. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/resource.js +0 -68
  340. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/route-map.js +0 -45
  341. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/route-separation.js +0 -97
  342. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/vhost.js +0 -46
  343. package/tests/fixtures/corpus/oss-repos/express/test/acceptance/web-service.js +0 -105
  344. package/tests/fixtures/corpus/oss-repos/express/test/app.all.js +0 -38
  345. package/tests/fixtures/corpus/oss-repos/express/test/app.engine.js +0 -83
  346. package/tests/fixtures/corpus/oss-repos/express/test/app.head.js +0 -66
  347. package/tests/fixtures/corpus/oss-repos/express/test/app.js +0 -120
  348. package/tests/fixtures/corpus/oss-repos/express/test/app.listen.js +0 -55
  349. package/tests/fixtures/corpus/oss-repos/express/test/app.locals.js +0 -26
  350. package/tests/fixtures/corpus/oss-repos/express/test/app.options.js +0 -116
  351. package/tests/fixtures/corpus/oss-repos/express/test/app.param.js +0 -323
  352. package/tests/fixtures/corpus/oss-repos/express/test/app.render.js +0 -374
  353. package/tests/fixtures/corpus/oss-repos/express/test/app.request.js +0 -143
  354. package/tests/fixtures/corpus/oss-repos/express/test/app.response.js +0 -143
  355. package/tests/fixtures/corpus/oss-repos/express/test/app.route.js +0 -197
  356. package/tests/fixtures/corpus/oss-repos/express/test/app.router.js +0 -1217
  357. package/tests/fixtures/corpus/oss-repos/express/test/app.routes.error.js +0 -62
  358. package/tests/fixtures/corpus/oss-repos/express/test/app.use.js +0 -542
  359. package/tests/fixtures/corpus/oss-repos/express/test/config.js +0 -207
  360. package/tests/fixtures/corpus/oss-repos/express/test/exports.js +0 -82
  361. package/tests/fixtures/corpus/oss-repos/express/test/express.json.js +0 -755
  362. package/tests/fixtures/corpus/oss-repos/express/test/express.raw.js +0 -513
  363. package/tests/fixtures/corpus/oss-repos/express/test/express.static.js +0 -815
  364. package/tests/fixtures/corpus/oss-repos/express/test/express.text.js +0 -566
  365. package/tests/fixtures/corpus/oss-repos/express/test/express.urlencoded.js +0 -828
  366. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/% of dogs.txt +0 -1
  367. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/.name +0 -1
  368. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/blog/index.html +0 -1
  369. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/blog/post/index.tmpl +0 -1
  370. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/broken.send +0 -0
  371. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/default_layout/name.tmpl +0 -1
  372. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/default_layout/user.tmpl +0 -1
  373. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/email.tmpl +0 -1
  374. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/empty.txt +0 -0
  375. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/local_layout/user.tmpl +0 -1
  376. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/name.tmpl +0 -1
  377. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/name.txt +0 -1
  378. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/nums.txt +0 -1
  379. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/pets/names.txt +0 -1
  380. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/snow /342/230/203/.gitkeep +0 -0
  381. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/todo.html +0 -1
  382. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/todo.txt +0 -1
  383. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/user.html +0 -1
  384. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/user.tmpl +0 -1
  385. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/users/index.html +0 -1
  386. package/tests/fixtures/corpus/oss-repos/express/test/fixtures/users/tobi.txt +0 -1
  387. package/tests/fixtures/corpus/oss-repos/express/test/middleware.basic.js +0 -42
  388. package/tests/fixtures/corpus/oss-repos/express/test/regression.js +0 -20
  389. package/tests/fixtures/corpus/oss-repos/express/test/req.accepts.js +0 -125
  390. package/tests/fixtures/corpus/oss-repos/express/test/req.acceptsCharsets.js +0 -50
  391. package/tests/fixtures/corpus/oss-repos/express/test/req.acceptsEncodings.js +0 -39
  392. package/tests/fixtures/corpus/oss-repos/express/test/req.acceptsLanguages.js +0 -57
  393. package/tests/fixtures/corpus/oss-repos/express/test/req.baseUrl.js +0 -88
  394. package/tests/fixtures/corpus/oss-repos/express/test/req.fresh.js +0 -70
  395. package/tests/fixtures/corpus/oss-repos/express/test/req.get.js +0 -60
  396. package/tests/fixtures/corpus/oss-repos/express/test/req.host.js +0 -156
  397. package/tests/fixtures/corpus/oss-repos/express/test/req.hostname.js +0 -188
  398. package/tests/fixtures/corpus/oss-repos/express/test/req.ip.js +0 -113
  399. package/tests/fixtures/corpus/oss-repos/express/test/req.ips.js +0 -71
  400. package/tests/fixtures/corpus/oss-repos/express/test/req.is.js +0 -169
  401. package/tests/fixtures/corpus/oss-repos/express/test/req.path.js +0 -20
  402. package/tests/fixtures/corpus/oss-repos/express/test/req.protocol.js +0 -113
  403. package/tests/fixtures/corpus/oss-repos/express/test/req.query.js +0 -106
  404. package/tests/fixtures/corpus/oss-repos/express/test/req.range.js +0 -104
  405. package/tests/fixtures/corpus/oss-repos/express/test/req.route.js +0 -28
  406. package/tests/fixtures/corpus/oss-repos/express/test/req.secure.js +0 -101
  407. package/tests/fixtures/corpus/oss-repos/express/test/req.signedCookies.js +0 -37
  408. package/tests/fixtures/corpus/oss-repos/express/test/req.stale.js +0 -50
  409. package/tests/fixtures/corpus/oss-repos/express/test/req.subdomains.js +0 -173
  410. package/tests/fixtures/corpus/oss-repos/express/test/req.xhr.js +0 -42
  411. package/tests/fixtures/corpus/oss-repos/express/test/res.append.js +0 -116
  412. package/tests/fixtures/corpus/oss-repos/express/test/res.attachment.js +0 -79
  413. package/tests/fixtures/corpus/oss-repos/express/test/res.clearCookie.js +0 -62
  414. package/tests/fixtures/corpus/oss-repos/express/test/res.cookie.js +0 -295
  415. package/tests/fixtures/corpus/oss-repos/express/test/res.download.js +0 -487
  416. package/tests/fixtures/corpus/oss-repos/express/test/res.format.js +0 -248
  417. package/tests/fixtures/corpus/oss-repos/express/test/res.get.js +0 -21
  418. package/tests/fixtures/corpus/oss-repos/express/test/res.json.js +0 -186
  419. package/tests/fixtures/corpus/oss-repos/express/test/res.jsonp.js +0 -344
  420. package/tests/fixtures/corpus/oss-repos/express/test/res.links.js +0 -65
  421. package/tests/fixtures/corpus/oss-repos/express/test/res.locals.js +0 -40
  422. package/tests/fixtures/corpus/oss-repos/express/test/res.location.js +0 -316
  423. package/tests/fixtures/corpus/oss-repos/express/test/res.redirect.js +0 -214
  424. package/tests/fixtures/corpus/oss-repos/express/test/res.render.js +0 -367
  425. package/tests/fixtures/corpus/oss-repos/express/test/res.send.js +0 -569
  426. package/tests/fixtures/corpus/oss-repos/express/test/res.sendFile.js +0 -913
  427. package/tests/fixtures/corpus/oss-repos/express/test/res.sendStatus.js +0 -44
  428. package/tests/fixtures/corpus/oss-repos/express/test/res.set.js +0 -124
  429. package/tests/fixtures/corpus/oss-repos/express/test/res.status.js +0 -206
  430. package/tests/fixtures/corpus/oss-repos/express/test/res.type.js +0 -46
  431. package/tests/fixtures/corpus/oss-repos/express/test/res.vary.js +0 -90
  432. package/tests/fixtures/corpus/oss-repos/express/test/support/env.js +0 -3
  433. package/tests/fixtures/corpus/oss-repos/express/test/support/tmpl.js +0 -36
  434. package/tests/fixtures/corpus/oss-repos/express/test/support/utils.js +0 -86
  435. package/tests/fixtures/corpus/oss-repos/express/test/utils.js +0 -83
  436. package/tests/fixtures/corpus/oss-repos/hono/.devcontainer/Dockerfile +0 -11
  437. package/tests/fixtures/corpus/oss-repos/hono/.devcontainer/devcontainer.json +0 -21
  438. package/tests/fixtures/corpus/oss-repos/hono/.devcontainer/docker-compose.yml +0 -18
  439. package/tests/fixtures/corpus/oss-repos/hono/.eslintignore +0 -1
  440. package/tests/fixtures/corpus/oss-repos/hono/.eslintrc.cjs +0 -9
  441. package/tests/fixtures/corpus/oss-repos/hono/.gitpod.yml +0 -9
  442. package/tests/fixtures/corpus/oss-repos/hono/.prettierrc +0 -9
  443. package/tests/fixtures/corpus/oss-repos/hono/.vitest.config/jsx-runtime-default.ts +0 -15
  444. package/tests/fixtures/corpus/oss-repos/hono/.vitest.config/jsx-runtime-dom.ts +0 -15
  445. package/tests/fixtures/corpus/oss-repos/hono/.vitest.config/setup-vitest.ts +0 -47
  446. package/tests/fixtures/corpus/oss-repos/hono/LICENSE +0 -21
  447. package/tests/fixtures/corpus/oss-repos/hono/README.md +0 -91
  448. package/tests/fixtures/corpus/oss-repos/hono/build.ts +0 -80
  449. package/tests/fixtures/corpus/oss-repos/hono/bun.lockb +0 -0
  450. package/tests/fixtures/corpus/oss-repos/hono/bunfig.toml +0 -7
  451. package/tests/fixtures/corpus/oss-repos/hono/codecov.yml +0 -13
  452. package/tests/fixtures/corpus/oss-repos/hono/docs/CODE_OF_CONDUCT.md +0 -128
  453. package/tests/fixtures/corpus/oss-repos/hono/docs/CONTRIBUTING.md +0 -62
  454. package/tests/fixtures/corpus/oss-repos/hono/docs/MIGRATION.md +0 -295
  455. package/tests/fixtures/corpus/oss-repos/hono/docs/images/hono-logo.png +0 -0
  456. package/tests/fixtures/corpus/oss-repos/hono/docs/images/hono-logo.pxm +0 -0
  457. package/tests/fixtures/corpus/oss-repos/hono/docs/images/hono-logo.svg +0 -6
  458. package/tests/fixtures/corpus/oss-repos/hono/docs/images/hono-title.png +0 -0
  459. package/tests/fixtures/corpus/oss-repos/hono/docs/images/hono-title.pxm +0 -0
  460. package/tests/fixtures/corpus/oss-repos/hono/jsr.json +0 -119
  461. package/tests/fixtures/corpus/oss-repos/hono/package.cjs.json +0 -3
  462. package/tests/fixtures/corpus/oss-repos/hono/package.json +0 -650
  463. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/aws-lambda/handler.ts +0 -492
  464. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/aws-lambda/index.ts +0 -13
  465. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/aws-lambda/types.ts +0 -144
  466. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/bun/conninfo.ts +0 -28
  467. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/bun/index.ts +0 -9
  468. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/bun/serve-static.ts +0 -35
  469. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/bun/server.ts +0 -30
  470. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/bun/ssg.ts +0 -27
  471. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/bun/websocket.ts +0 -110
  472. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/cloudflare-pages/handler.ts +0 -120
  473. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/cloudflare-pages/index.ts +0 -7
  474. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/cloudflare-workers/conninfo.ts +0 -7
  475. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/cloudflare-workers/index.ts +0 -8
  476. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/cloudflare-workers/serve-static-module.ts +0 -12
  477. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/cloudflare-workers/serve-static.ts +0 -39
  478. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/cloudflare-workers/utils.ts +0 -50
  479. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/cloudflare-workers/websocket.ts +0 -50
  480. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/deno/conninfo.ts +0 -17
  481. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/deno/deno.d.ts +0 -28
  482. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/deno/index.ts +0 -9
  483. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/deno/serve-static.ts +0 -40
  484. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/deno/ssg.ts +0 -27
  485. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/deno/websocket.ts +0 -51
  486. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/lambda-edge/conninfo.ts +0 -15
  487. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/lambda-edge/handler.ts +0 -189
  488. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/lambda-edge/index.ts +0 -14
  489. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/netlify/handler.ts +0 -10
  490. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/netlify/index.ts +0 -6
  491. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/netlify/mod.ts +0 -1
  492. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/service-worker/handler.ts +0 -34
  493. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/service-worker/index.ts +0 -5
  494. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/service-worker/types.ts +0 -14
  495. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/vercel/conninfo.ts +0 -8
  496. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/vercel/handler.ts +0 -9
  497. package/tests/fixtures/corpus/oss-repos/hono/src/adapter/vercel/index.ts +0 -7
  498. package/tests/fixtures/corpus/oss-repos/hono/src/client/client.ts +0 -214
  499. package/tests/fixtures/corpus/oss-repos/hono/src/client/index.ts +0 -14
  500. package/tests/fixtures/corpus/oss-repos/hono/src/client/types.ts +0 -182
  501. package/tests/fixtures/corpus/oss-repos/hono/src/client/utils.ts +0 -54
  502. package/tests/fixtures/corpus/oss-repos/hono/src/compose.ts +0 -94
  503. package/tests/fixtures/corpus/oss-repos/hono/src/context.ts +0 -917
  504. package/tests/fixtures/corpus/oss-repos/hono/src/helper/accepts/accepts.ts +0 -84
  505. package/tests/fixtures/corpus/oss-repos/hono/src/helper/accepts/index.ts +0 -6
  506. package/tests/fixtures/corpus/oss-repos/hono/src/helper/adapter/index.ts +0 -85
  507. package/tests/fixtures/corpus/oss-repos/hono/src/helper/conninfo/index.ts +0 -6
  508. package/tests/fixtures/corpus/oss-repos/hono/src/helper/conninfo/types.ts +0 -45
  509. package/tests/fixtures/corpus/oss-repos/hono/src/helper/cookie/index.ts +0 -130
  510. package/tests/fixtures/corpus/oss-repos/hono/src/helper/css/common.ts +0 -243
  511. package/tests/fixtures/corpus/oss-repos/hono/src/helper/css/index.ts +0 -220
  512. package/tests/fixtures/corpus/oss-repos/hono/src/helper/dev/index.ts +0 -79
  513. package/tests/fixtures/corpus/oss-repos/hono/src/helper/factory/index.ts +0 -246
  514. package/tests/fixtures/corpus/oss-repos/hono/src/helper/html/index.ts +0 -56
  515. package/tests/fixtures/corpus/oss-repos/hono/src/helper/ssg/index.ts +0 -13
  516. package/tests/fixtures/corpus/oss-repos/hono/src/helper/ssg/middleware.ts +0 -79
  517. package/tests/fixtures/corpus/oss-repos/hono/src/helper/ssg/ssg.ts +0 -388
  518. package/tests/fixtures/corpus/oss-repos/hono/src/helper/ssg/utils.ts +0 -71
  519. package/tests/fixtures/corpus/oss-repos/hono/src/helper/streaming/index.ts +0 -9
  520. package/tests/fixtures/corpus/oss-repos/hono/src/helper/streaming/sse.ts +0 -89
  521. package/tests/fixtures/corpus/oss-repos/hono/src/helper/streaming/stream.ts +0 -36
  522. package/tests/fixtures/corpus/oss-repos/hono/src/helper/streaming/text.ts +0 -15
  523. package/tests/fixtures/corpus/oss-repos/hono/src/helper/testing/index.ts +0 -26
  524. package/tests/fixtures/corpus/oss-repos/hono/src/helper/websocket/index.ts +0 -57
  525. package/tests/fixtures/corpus/oss-repos/hono/src/hono-base.ts +0 -523
  526. package/tests/fixtures/corpus/oss-repos/hono/src/hono.ts +0 -34
  527. package/tests/fixtures/corpus/oss-repos/hono/src/http-exception.ts +0 -78
  528. package/tests/fixtures/corpus/oss-repos/hono/src/index.ts +0 -51
  529. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/base.ts +0 -419
  530. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/children.ts +0 -20
  531. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/components.ts +0 -195
  532. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/constants.ts +0 -5
  533. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/context.ts +0 -50
  534. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/client.ts +0 -89
  535. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/components.ts +0 -39
  536. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/context.ts +0 -52
  537. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/css.ts +0 -246
  538. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/hooks/index.ts +0 -91
  539. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/index.ts +0 -159
  540. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/intrinsic-element/components.ts +0 -398
  541. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/jsx-dev-runtime.ts +0 -22
  542. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/jsx-runtime.ts +0 -7
  543. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/render.ts +0 -772
  544. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/server.ts +0 -70
  545. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/dom/utils.ts +0 -7
  546. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/hooks/index.ts +0 -426
  547. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/index.ts +0 -114
  548. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/intrinsic-element/common.ts +0 -11
  549. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/intrinsic-element/components.ts +0 -196
  550. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/intrinsic-elements.ts +0 -924
  551. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/jsx-dev-runtime.ts +0 -26
  552. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/jsx-runtime.ts +0 -18
  553. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/streaming.ts +0 -184
  554. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/types.ts +0 -41
  555. package/tests/fixtures/corpus/oss-repos/hono/src/jsx/utils.ts +0 -36
  556. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/basic-auth/index.ts +0 -128
  557. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/bearer-auth/index.ts +0 -159
  558. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/body-limit/index.ts +0 -115
  559. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/cache/index.ts +0 -127
  560. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/combine/index.ts +0 -153
  561. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/compress/index.ts +0 -79
  562. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/context-storage/index.ts +0 -55
  563. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/cors/index.ts +0 -141
  564. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/csrf/index.ts +0 -90
  565. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/etag/index.ts +0 -88
  566. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/ip-restriction/index.ts +0 -178
  567. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/jsx-renderer/index.ts +0 -158
  568. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/jwt/index.ts +0 -8
  569. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/jwt/jwt.ts +0 -159
  570. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/logger/index.ts +0 -93
  571. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/method-override/index.ts +0 -146
  572. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/powered-by/index.ts +0 -13
  573. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/pretty-json/index.ts +0 -50
  574. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/request-id/index.ts +0 -8
  575. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/request-id/request-id.ts +0 -59
  576. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/secure-headers/index.ts +0 -8
  577. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/secure-headers/permissions-policy.ts +0 -86
  578. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/secure-headers/secure-headers.ts +0 -319
  579. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/serve-static/index.ts +0 -140
  580. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/timeout/index.ts +0 -58
  581. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/timing/index.ts +0 -7
  582. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/timing/timing.ts +0 -225
  583. package/tests/fixtures/corpus/oss-repos/hono/src/middleware/trailing-slash/index.ts +0 -71
  584. package/tests/fixtures/corpus/oss-repos/hono/src/preset/quick.ts +0 -24
  585. package/tests/fixtures/corpus/oss-repos/hono/src/preset/tiny.ts +0 -20
  586. package/tests/fixtures/corpus/oss-repos/hono/src/request.ts +0 -403
  587. package/tests/fixtures/corpus/oss-repos/hono/src/router/linear-router/index.ts +0 -6
  588. package/tests/fixtures/corpus/oss-repos/hono/src/router/linear-router/router.ts +0 -132
  589. package/tests/fixtures/corpus/oss-repos/hono/src/router/pattern-router/index.ts +0 -6
  590. package/tests/fixtures/corpus/oss-repos/hono/src/router/pattern-router/router.ts +0 -54
  591. package/tests/fixtures/corpus/oss-repos/hono/src/router/reg-exp-router/index.ts +0 -6
  592. package/tests/fixtures/corpus/oss-repos/hono/src/router/reg-exp-router/node.ts +0 -159
  593. package/tests/fixtures/corpus/oss-repos/hono/src/router/reg-exp-router/router.ts +0 -274
  594. package/tests/fixtures/corpus/oss-repos/hono/src/router/reg-exp-router/trie.ts +0 -74
  595. package/tests/fixtures/corpus/oss-repos/hono/src/router/smart-router/index.ts +0 -6
  596. package/tests/fixtures/corpus/oss-repos/hono/src/router/smart-router/router.ts +0 -69
  597. package/tests/fixtures/corpus/oss-repos/hono/src/router/trie-router/index.ts +0 -6
  598. package/tests/fixtures/corpus/oss-repos/hono/src/router/trie-router/node.ts +0 -205
  599. package/tests/fixtures/corpus/oss-repos/hono/src/router/trie-router/router.ts +0 -28
  600. package/tests/fixtures/corpus/oss-repos/hono/src/router.ts +0 -103
  601. package/tests/fixtures/corpus/oss-repos/hono/src/types.ts +0 -2006
  602. package/tests/fixtures/corpus/oss-repos/hono/src/utils/basic-auth.ts +0 -26
  603. package/tests/fixtures/corpus/oss-repos/hono/src/utils/body.ts +0 -225
  604. package/tests/fixtures/corpus/oss-repos/hono/src/utils/buffer.ts +0 -65
  605. package/tests/fixtures/corpus/oss-repos/hono/src/utils/color.ts +0 -26
  606. package/tests/fixtures/corpus/oss-repos/hono/src/utils/concurrent.ts +0 -55
  607. package/tests/fixtures/corpus/oss-repos/hono/src/utils/cookie.ts +0 -230
  608. package/tests/fixtures/corpus/oss-repos/hono/src/utils/crypto.ts +0 -65
  609. package/tests/fixtures/corpus/oss-repos/hono/src/utils/encode.ts +0 -34
  610. package/tests/fixtures/corpus/oss-repos/hono/src/utils/filepath.ts +0 -56
  611. package/tests/fixtures/corpus/oss-repos/hono/src/utils/handler.ts +0 -15
  612. package/tests/fixtures/corpus/oss-repos/hono/src/utils/html.ts +0 -182
  613. package/tests/fixtures/corpus/oss-repos/hono/src/utils/http-status.ts +0 -69
  614. package/tests/fixtures/corpus/oss-repos/hono/src/utils/ipaddr.ts +0 -113
  615. package/tests/fixtures/corpus/oss-repos/hono/src/utils/jwt/index.ts +0 -7
  616. package/tests/fixtures/corpus/oss-repos/hono/src/utils/jwt/jwa.ts +0 -23
  617. package/tests/fixtures/corpus/oss-repos/hono/src/utils/jwt/jws.ts +0 -226
  618. package/tests/fixtures/corpus/oss-repos/hono/src/utils/jwt/jwt.ts +0 -114
  619. package/tests/fixtures/corpus/oss-repos/hono/src/utils/jwt/types.ts +0 -83
  620. package/tests/fixtures/corpus/oss-repos/hono/src/utils/jwt/utf8.ts +0 -7
  621. package/tests/fixtures/corpus/oss-repos/hono/src/utils/mime.ts +0 -142
  622. package/tests/fixtures/corpus/oss-repos/hono/src/utils/stream.ts +0 -96
  623. package/tests/fixtures/corpus/oss-repos/hono/src/utils/types.ts +0 -102
  624. package/tests/fixtures/corpus/oss-repos/hono/src/utils/url.ts +0 -310
  625. package/tests/fixtures/corpus/oss-repos/hono/src/validator/index.ts +0 -7
  626. package/tests/fixtures/corpus/oss-repos/hono/src/validator/validator.ts +0 -151
  627. package/tests/fixtures/corpus/oss-repos/hono/tsconfig.build.json +0 -23
  628. package/tests/fixtures/corpus/oss-repos/hono/tsconfig.json +0 -28
  629. package/tests/fixtures/corpus/oss-repos/hono/vitest.config.ts +0 -34
  630. package/tests/fixtures/corpus/oss-repos/hono/yarn.lock +0 -6232
  631. package/tests/fixtures/documentation/api-reference.md +0 -412
  632. package/tests/fixtures/documentation/architecture.md +0 -214
  633. package/tests/fixtures/documentation/deployment-guide.md +0 -420
  634. package/tests/fixtures/github-readmes/express.md +0 -133
  635. package/tests/fixtures/github-readmes/nextjs.md +0 -106
  636. package/tests/fixtures/github-readmes/react.md +0 -74
  637. package/tests/fixtures/github-readmes/typescript.md +0 -93
  638. package/tests/fixtures/github-readmes/vite.md +0 -79
  639. package/tests/fixtures/queries/core.json +0 -125
  640. package/tests/fixtures/queries/extended.json +0 -427
  641. package/tests/fixtures/queries/generated/.gitkeep +0 -0
  642. package/tests/fixtures/test-server.ts +0 -268
  643. package/tests/helpers/performance-metrics.ts +0 -370
  644. package/tests/helpers/search-relevance.ts +0 -326
  645. package/tests/integration/cli-consistency.test.ts +0 -298
  646. package/tests/integration/cli.test.ts +0 -69
  647. package/tests/integration/e2e-workflow.test.ts +0 -614
  648. package/tests/integration/mcp.test.ts +0 -250
  649. package/tests/integration/python-bridge.test.ts +0 -193
  650. package/tests/integration/search-quality.test.ts +0 -720
  651. package/tests/integration/serve.test.ts +0 -260
  652. package/tests/integration/stress.test.ts +0 -326
  653. package/tests/mcp/server.test.ts +0 -15
  654. package/tests/scripts/schemas/evaluation.json +0 -44
  655. package/tests/scripts/schemas/query-generation.json +0 -21
  656. package/tests/services/code-unit.service.test.ts +0 -95
  657. package/tests/services/job.service.test.ts +0 -124
  658. package/tests/services/search.progressive-context.test.ts +0 -35
  659. package/tsconfig.json +0 -34
  660. package/tsup.config.ts +0 -15
  661. package/turndown-plugin-gfm.d.ts +0 -29
  662. package/vitest.config.ts +0 -90
  663. /package/dist/{chunk-AOSDVRRH.js.map → chunk-AIS5S77C.js.map} +0 -0
@@ -1,600 +0,0 @@
1
- import { describe, it, expect, beforeEach, vi, afterEach } from 'vitest';
2
- import { WatchService } from './watch.service.js';
3
- import type { IndexService } from './index.service.js';
4
- import type { LanceStore } from '../db/lance.js';
5
- import type { FileStore, RepoStore } from '../types/store.js';
6
-
7
- // Create fresh mock watcher for each call
8
- const createMockWatcher = () => ({
9
- on: vi.fn().mockReturnThis(),
10
- close: vi.fn().mockResolvedValue(undefined),
11
- });
12
-
13
- let mockWatchers: ReturnType<typeof createMockWatcher>[] = [];
14
-
15
- // Mock chokidar
16
- vi.mock('chokidar', () => ({
17
- watch: vi.fn(() => {
18
- const watcher = createMockWatcher();
19
- mockWatchers.push(watcher);
20
- return watcher;
21
- }),
22
- }));
23
-
24
- // Import chokidar once after mock is set up to avoid dynamic import flakiness
25
- import * as chokidar from 'chokidar';
26
-
27
- describe('WatchService', () => {
28
- let watchService: WatchService;
29
- let mockIndexService: IndexService;
30
- let mockLanceStore: LanceStore;
31
- let mockFileStore: FileStore;
32
- let mockRepoStore: RepoStore;
33
-
34
- beforeEach(async () => {
35
- // Clear mock watchers array
36
- mockWatchers = [];
37
-
38
- // Reset mocks
39
- vi.clearAllMocks();
40
- vi.useFakeTimers();
41
-
42
- // Create mock services
43
- mockIndexService = {
44
- indexStore: vi.fn().mockResolvedValue({ ok: true }),
45
- } as unknown as IndexService;
46
-
47
- mockLanceStore = {
48
- initialize: vi.fn().mockResolvedValue(undefined),
49
- } as unknown as LanceStore;
50
-
51
- mockFileStore = {
52
- id: 'file-store-1',
53
- type: 'file',
54
- path: '/test/path',
55
- name: 'Test File Store',
56
- description: 'Test store',
57
- createdAt: new Date(),
58
- updatedAt: new Date(),
59
- };
60
-
61
- mockRepoStore = {
62
- id: 'repo-store-1',
63
- type: 'repo',
64
- path: '/test/repo',
65
- name: 'Test Repo Store',
66
- description: 'Test repo',
67
- url: 'https://github.com/test/repo',
68
- branch: 'main',
69
- createdAt: new Date(),
70
- updatedAt: new Date(),
71
- };
72
-
73
- watchService = new WatchService(mockIndexService, mockLanceStore);
74
- });
75
-
76
- afterEach(() => {
77
- vi.useRealTimers();
78
- });
79
-
80
- describe('watch - Lifecycle', () => {
81
- const noopErrorHandler = (): void => {};
82
-
83
- it('starts watching a file store', async () => {
84
- const { watch } = chokidar;
85
-
86
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
87
-
88
- expect(watch).toHaveBeenCalledWith(
89
- mockFileStore.path,
90
- expect.objectContaining({
91
- ignored: expect.any(RegExp),
92
- persistent: true,
93
- ignoreInitial: true,
94
- })
95
- );
96
- });
97
-
98
- it('starts watching a repo store', async () => {
99
- const { watch } = chokidar;
100
-
101
- await watchService.watch(mockRepoStore, 1000, undefined, noopErrorHandler);
102
-
103
- expect(watch).toHaveBeenCalledWith(mockRepoStore.path, expect.any(Object));
104
- });
105
-
106
- it('sets up event handlers on watcher', async () => {
107
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
108
-
109
- const watcher = mockWatchers[0];
110
- expect(watcher?.on).toHaveBeenCalledWith('all', expect.any(Function));
111
- expect(watcher?.on).toHaveBeenCalledWith('error', expect.any(Function));
112
- });
113
-
114
- it('does not start watching if already watching the same store', async () => {
115
- const { watch } = chokidar;
116
-
117
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
118
- const callCount1 = (watch as ReturnType<typeof vi.fn>).mock.calls.length;
119
-
120
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
121
- const callCount2 = (watch as ReturnType<typeof vi.fn>).mock.calls.length;
122
-
123
- expect(callCount2).toBe(callCount1);
124
- });
125
-
126
- it('allows watching multiple different stores', async () => {
127
- const { watch } = chokidar;
128
-
129
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
130
- await watchService.watch(mockRepoStore, 1000, undefined, noopErrorHandler);
131
-
132
- expect(watch).toHaveBeenCalledTimes(2);
133
- });
134
-
135
- it('resolves immediately when store is already being watched', async () => {
136
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
137
-
138
- const startTime = Date.now();
139
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
140
- const endTime = Date.now();
141
-
142
- // Should resolve immediately
143
- expect(endTime - startTime).toBeLessThan(10);
144
- });
145
- });
146
-
147
- describe('watch - Debounce Logic', () => {
148
- const noopErrorHandler = (): void => {};
149
-
150
- it('debounces rapid file changes with default timeout', async () => {
151
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
152
-
153
- const watcher = mockWatchers[0];
154
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
155
- (call: unknown[]) => call[0] === 'all'
156
- )?.[1] as (() => void) | undefined;
157
-
158
- // Trigger multiple rapid changes
159
- allHandler?.();
160
- allHandler?.();
161
- allHandler?.();
162
-
163
- // Fast-forward less than debounce time
164
- vi.advanceTimersByTime(500);
165
-
166
- // Should not have triggered reindex yet
167
- expect(mockIndexService.indexStore).not.toHaveBeenCalled();
168
-
169
- // Fast-forward past debounce time
170
- vi.advanceTimersByTime(600);
171
- await vi.runAllTimersAsync();
172
-
173
- // Should have triggered reindex only once
174
- expect(mockIndexService.indexStore).toHaveBeenCalledTimes(1);
175
- });
176
-
177
- it('uses custom debounce timeout', async () => {
178
- await watchService.watch(mockFileStore, 2000);
179
-
180
- const watcher = mockWatchers[0];
181
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
182
- (call: unknown[]) => call[0] === 'all'
183
- )?.[1] as (() => void) | undefined;
184
-
185
- allHandler?.();
186
-
187
- // Advance less than custom debounce
188
- vi.advanceTimersByTime(1500);
189
- expect(mockIndexService.indexStore).not.toHaveBeenCalled();
190
-
191
- // Advance past custom debounce
192
- vi.advanceTimersByTime(600);
193
- await vi.runAllTimersAsync();
194
-
195
- expect(mockIndexService.indexStore).toHaveBeenCalledTimes(1);
196
- });
197
-
198
- it('resets debounce timer on each change', async () => {
199
- await watchService.watch(mockFileStore, 1000);
200
-
201
- const watcher = mockWatchers[0];
202
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
203
- (call: unknown[]) => call[0] === 'all'
204
- )?.[1] as (() => void) | undefined;
205
-
206
- // Trigger change
207
- allHandler?.();
208
- vi.advanceTimersByTime(800);
209
-
210
- // Trigger another change (should reset timer)
211
- allHandler?.();
212
- vi.advanceTimersByTime(800);
213
-
214
- // Still no reindex (timer was reset)
215
- expect(mockIndexService.indexStore).not.toHaveBeenCalled();
216
-
217
- // Complete the timeout
218
- vi.advanceTimersByTime(300);
219
- await vi.runAllTimersAsync();
220
-
221
- expect(mockIndexService.indexStore).toHaveBeenCalledTimes(1);
222
- });
223
-
224
- it('clears previous timeout on new change', async () => {
225
- await watchService.watch(mockFileStore, 1000);
226
-
227
- const watcher = mockWatchers[0];
228
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
229
- (call: unknown[]) => call[0] === 'all'
230
- )?.[1] as (() => void) | undefined;
231
-
232
- // Multiple rapid changes
233
- for (let i = 0; i < 10; i++) {
234
- allHandler?.();
235
- vi.advanceTimersByTime(100);
236
- }
237
-
238
- await vi.runAllTimersAsync();
239
-
240
- // Should only index once despite 10 changes
241
- expect(mockIndexService.indexStore).toHaveBeenCalledTimes(1);
242
- });
243
- });
244
-
245
- describe('watch - Reindexing', () => {
246
- const noopErrorHandler = (): void => {};
247
-
248
- it('initializes lance store before reindexing', async () => {
249
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
250
-
251
- const watcher = mockWatchers[0];
252
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
253
- (call: unknown[]) => call[0] === 'all'
254
- )?.[1] as (() => void) | undefined;
255
-
256
- allHandler?.();
257
- vi.advanceTimersByTime(1100);
258
- await vi.runAllTimersAsync();
259
-
260
- expect(mockLanceStore.initialize).toHaveBeenCalledWith(mockFileStore.id);
261
- expect(mockLanceStore.initialize).toHaveBeenCalledBefore(
262
- mockIndexService.indexStore as ReturnType<typeof vi.fn>
263
- );
264
- });
265
-
266
- it('calls indexStore with correct store', async () => {
267
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
268
-
269
- const watcher = mockWatchers[0];
270
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
271
- (call: unknown[]) => call[0] === 'all'
272
- )?.[1] as (() => void) | undefined;
273
-
274
- allHandler?.();
275
- vi.advanceTimersByTime(1100);
276
- await vi.runAllTimersAsync();
277
-
278
- expect(mockIndexService.indexStore).toHaveBeenCalledWith(mockFileStore);
279
- });
280
-
281
- it('calls onReindex callback after successful reindex', async () => {
282
- const onReindex = vi.fn();
283
-
284
- await watchService.watch(mockFileStore, 1000, onReindex, noopErrorHandler);
285
-
286
- const watcher = mockWatchers[0];
287
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
288
- (call: unknown[]) => call[0] === 'all'
289
- )?.[1] as (() => void) | undefined;
290
-
291
- allHandler?.();
292
- vi.advanceTimersByTime(1100);
293
- await vi.runAllTimersAsync();
294
-
295
- expect(onReindex).toHaveBeenCalledTimes(1);
296
- });
297
-
298
- it('does not call onReindex if not provided', async () => {
299
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
300
-
301
- const watcher = mockWatchers[0];
302
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
303
- (call: unknown[]) => call[0] === 'all'
304
- )?.[1] as (() => void) | undefined;
305
-
306
- allHandler?.();
307
- vi.advanceTimersByTime(1100);
308
- await vi.runAllTimersAsync();
309
-
310
- // Should not throw
311
- expect(mockIndexService.indexStore).toHaveBeenCalled();
312
- });
313
-
314
- it('handles concurrent reindexing for different stores', async () => {
315
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
316
- await watchService.watch(mockRepoStore, 1000, undefined, noopErrorHandler);
317
-
318
- const watcher1 = mockWatchers[0];
319
- const watcher2 = mockWatchers[1];
320
-
321
- const handler1 = (watcher1?.on as ReturnType<typeof vi.fn>).mock.calls.find(
322
- (call: unknown[]) => call[0] === 'all'
323
- )?.[1] as (() => void) | undefined;
324
-
325
- const handler2 = (watcher2?.on as ReturnType<typeof vi.fn>).mock.calls.find(
326
- (call: unknown[]) => call[0] === 'all'
327
- )?.[1] as (() => void) | undefined;
328
-
329
- handler1?.();
330
- handler2?.();
331
-
332
- vi.advanceTimersByTime(1100);
333
- await vi.runAllTimersAsync();
334
-
335
- expect(mockIndexService.indexStore).toHaveBeenCalledTimes(2);
336
- expect(mockIndexService.indexStore).toHaveBeenCalledWith(mockFileStore);
337
- expect(mockIndexService.indexStore).toHaveBeenCalledWith(mockRepoStore);
338
- });
339
- });
340
-
341
- describe('watch - Error Handling', () => {
342
- it('calls onError when reindexing fails', async () => {
343
- const onError = vi.fn();
344
- const indexError = new Error('Index failed');
345
-
346
- mockIndexService.indexStore = vi.fn().mockRejectedValue(indexError);
347
-
348
- await watchService.watch(mockFileStore, 1000, undefined, onError);
349
-
350
- const watcher = mockWatchers[0];
351
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
352
- (call: unknown[]) => call[0] === 'all'
353
- )?.[1] as (() => void) | undefined;
354
-
355
- allHandler?.();
356
- vi.advanceTimersByTime(1100);
357
- await vi.runAllTimersAsync();
358
-
359
- expect(onError).toHaveBeenCalledWith(indexError);
360
- });
361
-
362
- it('calls onError when lance initialization fails', async () => {
363
- const onError = vi.fn();
364
- const initError = new Error('Init failed');
365
-
366
- mockLanceStore.initialize = vi.fn().mockRejectedValue(initError);
367
-
368
- await watchService.watch(mockFileStore, 1000, undefined, onError);
369
-
370
- const watcher = mockWatchers[0];
371
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
372
- (call: unknown[]) => call[0] === 'all'
373
- )?.[1] as (() => void) | undefined;
374
-
375
- allHandler?.();
376
- vi.advanceTimersByTime(1100);
377
- await vi.runAllTimersAsync();
378
-
379
- expect(onError).toHaveBeenCalledWith(initError);
380
- });
381
-
382
- it('calls onError for watcher errors', async () => {
383
- const onError = vi.fn();
384
-
385
- await watchService.watch(mockFileStore, 1000, undefined, onError);
386
-
387
- const watcher = mockWatchers[0];
388
- const errorHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
389
- (call: unknown[]) => call[0] === 'error'
390
- )?.[1] as ((error: Error) => void) | undefined;
391
-
392
- const testError = new Error('Watcher error');
393
- errorHandler?.(testError);
394
-
395
- expect(onError).toHaveBeenCalledWith(testError);
396
- });
397
-
398
- it('requires onError callback to be provided', async () => {
399
- // onError is now required - this test verifies the type signature enforces it
400
- // TypeScript would catch this at compile time, but runtime behavior should still work
401
- const onError = vi.fn();
402
- await watchService.watch(mockFileStore, 1000, undefined, onError);
403
-
404
- const watcher = mockWatchers[0];
405
- const errorHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
406
- (call: unknown[]) => call[0] === 'error'
407
- )?.[1] as ((error: Error) => void) | undefined;
408
-
409
- const testError = new Error('Watcher error');
410
- errorHandler?.(testError);
411
-
412
- // Error should be passed to onError, not thrown
413
- expect(onError).toHaveBeenCalledWith(testError);
414
- });
415
-
416
- it('continues watching after error during reindex', async () => {
417
- const onError = vi.fn();
418
-
419
- // First call fails
420
- mockIndexService.indexStore = vi
421
- .fn()
422
- .mockRejectedValueOnce(new Error('First fail'))
423
- .mockResolvedValueOnce({ ok: true });
424
-
425
- await watchService.watch(mockFileStore, 1000, undefined, onError);
426
-
427
- const watcher = mockWatchers[0];
428
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
429
- (call: unknown[]) => call[0] === 'all'
430
- )?.[1] as (() => void) | undefined;
431
-
432
- // First change - will fail
433
- allHandler?.();
434
- vi.advanceTimersByTime(1100);
435
- await vi.runAllTimersAsync();
436
-
437
- // Second change - should succeed
438
- allHandler?.();
439
- vi.advanceTimersByTime(1100);
440
- await vi.runAllTimersAsync();
441
-
442
- expect(mockIndexService.indexStore).toHaveBeenCalledTimes(2);
443
- expect(onError).toHaveBeenCalledTimes(1);
444
- });
445
- });
446
-
447
- describe('unwatch', () => {
448
- const noopErrorHandler = (): void => {};
449
-
450
- it('stops watching a store', async () => {
451
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
452
-
453
- const watcher = mockWatchers[0];
454
- await watchService.unwatch(mockFileStore.id);
455
-
456
- expect(watcher?.close).toHaveBeenCalled();
457
- });
458
-
459
- it('removes watcher from internal map', async () => {
460
- const { watch } = chokidar;
461
-
462
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
463
- await watchService.unwatch(mockFileStore.id);
464
-
465
- // Trying to watch again should create new watcher
466
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
467
-
468
- expect(watch).toHaveBeenCalledTimes(2);
469
- });
470
-
471
- it('does nothing when unwatching non-existent store', async () => {
472
- // Should not throw
473
- await expect(watchService.unwatch('non-existent-id')).resolves.toBeUndefined();
474
- });
475
-
476
- it('does not affect other watchers', async () => {
477
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
478
- await watchService.watch(mockRepoStore, 1000, undefined, noopErrorHandler);
479
-
480
- const watcher1 = mockWatchers[0];
481
- const watcher2 = mockWatchers[1];
482
-
483
- await watchService.unwatch(mockFileStore.id);
484
-
485
- expect(watcher1?.close).toHaveBeenCalled();
486
- expect(watcher2?.close).not.toHaveBeenCalled();
487
- });
488
-
489
- it('clears pending timeout to prevent timer leak', async () => {
490
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
491
-
492
- const watcher = mockWatchers[0];
493
- const allHandler = (watcher?.on as ReturnType<typeof vi.fn>).mock.calls.find(
494
- (call: unknown[]) => call[0] === 'all'
495
- )?.[1] as (() => void) | undefined;
496
-
497
- // Trigger a file change (sets timeout)
498
- allHandler?.();
499
-
500
- // Unwatch before timeout fires
501
- await watchService.unwatch(mockFileStore.id);
502
-
503
- // Advance past debounce time - timeout should NOT fire
504
- vi.advanceTimersByTime(1500);
505
- await vi.runAllTimersAsync();
506
-
507
- // indexStore should NOT have been called since we unwatched
508
- expect(mockIndexService.indexStore).not.toHaveBeenCalled();
509
- });
510
- });
511
-
512
- describe('unwatchAll', () => {
513
- const noopErrorHandler = (): void => {};
514
-
515
- it('stops all watchers', async () => {
516
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
517
- await watchService.watch(mockRepoStore, 1000, undefined, noopErrorHandler);
518
-
519
- const watcher1 = mockWatchers[0];
520
- const watcher2 = mockWatchers[1];
521
-
522
- await watchService.unwatchAll();
523
-
524
- expect(watcher1?.close).toHaveBeenCalled();
525
- expect(watcher2?.close).toHaveBeenCalled();
526
- });
527
-
528
- it('clears all watchers from map', async () => {
529
- const { watch } = chokidar;
530
-
531
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
532
- await watchService.watch(mockRepoStore, 1000, undefined, noopErrorHandler);
533
-
534
- await watchService.unwatchAll();
535
-
536
- // Watching again should create new watchers
537
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
538
-
539
- expect(watch).toHaveBeenCalledTimes(3); // 2 initial + 1 after unwatchAll
540
- });
541
-
542
- it('does nothing when no watchers exist', async () => {
543
- // Should not throw
544
- await expect(watchService.unwatchAll()).resolves.toBeUndefined();
545
- });
546
- });
547
-
548
- describe('File Watching Configuration', () => {
549
- const noopErrorHandler = (): void => {};
550
-
551
- it('ignores .git directories', async () => {
552
- const { watch } = chokidar;
553
-
554
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
555
-
556
- const config = (watch as ReturnType<typeof vi.fn>).mock.calls[0]?.[1];
557
- expect(config.ignored).toBeInstanceOf(RegExp);
558
- expect(config.ignored.test('.git')).toBe(true);
559
- expect(config.ignored.test('some/path/.git/file')).toBe(true);
560
- });
561
-
562
- it('ignores node_modules directories', async () => {
563
- const { watch } = chokidar;
564
-
565
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
566
-
567
- const config = (watch as ReturnType<typeof vi.fn>).mock.calls[0]?.[1];
568
- expect(config.ignored.test('.node_modules')).toBe(true);
569
- expect(config.ignored.test('some/path/.node_modules/pkg')).toBe(true);
570
- });
571
-
572
- it('ignores dist and build directories', async () => {
573
- const { watch } = chokidar;
574
-
575
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
576
-
577
- const config = (watch as ReturnType<typeof vi.fn>).mock.calls[0]?.[1];
578
- expect(config.ignored.test('.dist')).toBe(true);
579
- expect(config.ignored.test('.build')).toBe(true);
580
- });
581
-
582
- it('sets persistent to true', async () => {
583
- const { watch } = chokidar;
584
-
585
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
586
-
587
- const config = (watch as ReturnType<typeof vi.fn>).mock.calls[0]?.[1];
588
- expect(config.persistent).toBe(true);
589
- });
590
-
591
- it('sets ignoreInitial to true', async () => {
592
- const { watch } = chokidar;
593
-
594
- await watchService.watch(mockFileStore, 1000, undefined, noopErrorHandler);
595
-
596
- const config = (watch as ReturnType<typeof vi.fn>).mock.calls[0]?.[1];
597
- expect(config.ignoreInitial).toBe(true);
598
- });
599
- });
600
- });
@@ -1,84 +0,0 @@
1
- import { watch, type FSWatcher } from 'chokidar';
2
- import type { IndexService } from './index.service.js';
3
- import type { LanceStore } from '../db/lance.js';
4
- import type { FileStore, RepoStore } from '../types/store.js';
5
-
6
- export class WatchService {
7
- private readonly watchers: Map<string, FSWatcher> = new Map();
8
- private readonly pendingTimeouts: Map<string, NodeJS.Timeout> = new Map();
9
- private readonly indexService: IndexService;
10
- private readonly lanceStore: LanceStore;
11
-
12
- constructor(indexService: IndexService, lanceStore: LanceStore) {
13
- this.indexService = indexService;
14
- this.lanceStore = lanceStore;
15
- }
16
-
17
- async watch(
18
- store: FileStore | RepoStore,
19
- debounceMs: number,
20
- onReindex: (() => void) | undefined,
21
- onError: (error: Error) => void
22
- ): Promise<void> {
23
- if (this.watchers.has(store.id)) {
24
- return Promise.resolve(); // Already watching
25
- }
26
-
27
- let timeout: NodeJS.Timeout | null = null;
28
-
29
- const watcher = watch(store.path, {
30
- ignored: /(^|[/\\])\.(git|node_modules|dist|build)/,
31
- persistent: true,
32
- ignoreInitial: true,
33
- });
34
-
35
- const reindexHandler = (): void => {
36
- if (timeout) clearTimeout(timeout);
37
- timeout = setTimeout(() => {
38
- this.pendingTimeouts.delete(store.id);
39
- void (async (): Promise<void> => {
40
- try {
41
- await this.lanceStore.initialize(store.id);
42
- await this.indexService.indexStore(store);
43
- onReindex?.();
44
- } catch (e) {
45
- const error = e instanceof Error ? e : new Error(String(e));
46
- onError(error);
47
- }
48
- })();
49
- }, debounceMs);
50
- this.pendingTimeouts.set(store.id, timeout);
51
- };
52
-
53
- watcher.on('all', reindexHandler);
54
-
55
- watcher.on('error', (e) => {
56
- const error = e instanceof Error ? e : new Error(String(e));
57
- onError(error);
58
- });
59
-
60
- this.watchers.set(store.id, watcher);
61
- return Promise.resolve();
62
- }
63
-
64
- async unwatch(storeId: string): Promise<void> {
65
- // Clear any pending timeout to prevent timer leak
66
- const pendingTimeout = this.pendingTimeouts.get(storeId);
67
- if (pendingTimeout) {
68
- clearTimeout(pendingTimeout);
69
- this.pendingTimeouts.delete(storeId);
70
- }
71
-
72
- const watcher = this.watchers.get(storeId);
73
- if (watcher) {
74
- await watcher.close();
75
- this.watchers.delete(storeId);
76
- }
77
- }
78
-
79
- async unwatchAll(): Promise<void> {
80
- for (const [id] of this.watchers) {
81
- await this.unwatch(id);
82
- }
83
- }
84
- }