@wingman-ai/gateway 0.5.3 → 0.5.4

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 (311) hide show
  1. package/dist/agent/config/agentConfig.cjs +4 -0
  2. package/dist/agent/config/agentConfig.d.ts +12 -0
  3. package/dist/agent/config/agentConfig.js +4 -0
  4. package/dist/agent/config/toolRegistry.cjs +75 -1
  5. package/dist/agent/config/toolRegistry.d.ts +3 -0
  6. package/dist/agent/config/toolRegistry.js +75 -1
  7. package/dist/agent/middleware/large-tool-results.cjs +207 -0
  8. package/dist/agent/middleware/large-tool-results.d.ts +16 -0
  9. package/dist/agent/middleware/large-tool-results.js +173 -0
  10. package/dist/agent/tools/browser_control.cjs +9 -1231
  11. package/dist/agent/tools/browser_control.d.ts +126 -234
  12. package/dist/agent/tools/browser_control.js +7 -1226
  13. package/dist/agent/tools/browser_runtime.cjs +1189 -0
  14. package/dist/agent/tools/browser_runtime.d.ts +560 -0
  15. package/dist/agent/tools/browser_runtime.js +1122 -0
  16. package/dist/agent/tools/browser_session.cjs +153 -0
  17. package/dist/agent/tools/browser_session.d.ts +741 -0
  18. package/dist/agent/tools/browser_session.js +110 -0
  19. package/dist/agent/tools/browser_session_manager.cjs +202 -0
  20. package/dist/agent/tools/browser_session_manager.d.ts +64 -0
  21. package/dist/agent/tools/browser_session_manager.js +165 -0
  22. package/dist/cli/commands/init.cjs +5 -1
  23. package/dist/cli/commands/init.js +5 -1
  24. package/dist/cli/config/loader.cjs +0 -5
  25. package/dist/cli/config/loader.js +0 -5
  26. package/dist/cli/config/schema.cjs +3 -7
  27. package/dist/cli/config/schema.d.ts +6 -6
  28. package/dist/cli/config/schema.js +3 -7
  29. package/dist/cli/core/agentInvoker.cjs +86 -22
  30. package/dist/cli/core/agentInvoker.d.ts +10 -3
  31. package/dist/cli/core/agentInvoker.js +86 -25
  32. package/dist/cli/core/outputManager.cjs +7 -2
  33. package/dist/cli/core/outputManager.d.ts +2 -2
  34. package/dist/cli/core/outputManager.js +7 -2
  35. package/dist/cli/types.d.ts +2 -1
  36. package/dist/webui/assets/index-XrEnkZiq.css +11 -0
  37. package/dist/webui/assets/index-mDs6HbKM.js +215 -0
  38. package/dist/webui/index.html +2 -2
  39. package/package.json +10 -10
  40. package/templates/agents/README.md +2 -1
  41. package/templates/agents/coding/agent.md +6 -13
  42. package/templates/agents/coding-v2/agent.md +6 -1
  43. package/templates/agents/game-dev/agent.md +8 -2
  44. package/templates/agents/game-dev/game-designer.md +4 -0
  45. package/templates/agents/game-dev/scene-engineer.md +4 -0
  46. package/templates/agents/main/agent.md +5 -0
  47. package/templates/agents/researcher/agent.md +11 -0
  48. package/templates/agents/stock-trader/agent.md +4 -0
  49. package/dist/agent/tests/agentConfig.test.cjs +0 -224
  50. package/dist/agent/tests/agentConfig.test.d.ts +0 -1
  51. package/dist/agent/tests/agentConfig.test.js +0 -218
  52. package/dist/agent/tests/agentLoader.test.cjs +0 -335
  53. package/dist/agent/tests/agentLoader.test.d.ts +0 -1
  54. package/dist/agent/tests/agentLoader.test.js +0 -329
  55. package/dist/agent/tests/backgroundTerminal.test.cjs +0 -70
  56. package/dist/agent/tests/backgroundTerminal.test.d.ts +0 -1
  57. package/dist/agent/tests/backgroundTerminal.test.js +0 -64
  58. package/dist/agent/tests/browserControlHelpers.test.cjs +0 -35
  59. package/dist/agent/tests/browserControlHelpers.test.d.ts +0 -1
  60. package/dist/agent/tests/browserControlHelpers.test.js +0 -29
  61. package/dist/agent/tests/browserControlTool.test.cjs +0 -2117
  62. package/dist/agent/tests/browserControlTool.test.d.ts +0 -1
  63. package/dist/agent/tests/browserControlTool.test.js +0 -2111
  64. package/dist/agent/tests/commandExecuteTool.test.cjs +0 -29
  65. package/dist/agent/tests/commandExecuteTool.test.d.ts +0 -1
  66. package/dist/agent/tests/commandExecuteTool.test.js +0 -23
  67. package/dist/agent/tests/internet_search.test.cjs +0 -107
  68. package/dist/agent/tests/internet_search.test.d.ts +0 -1
  69. package/dist/agent/tests/internet_search.test.js +0 -101
  70. package/dist/agent/tests/mcpClientManager.test.cjs +0 -290
  71. package/dist/agent/tests/mcpClientManager.test.d.ts +0 -1
  72. package/dist/agent/tests/mcpClientManager.test.js +0 -284
  73. package/dist/agent/tests/mcpResourceTools.test.cjs +0 -101
  74. package/dist/agent/tests/mcpResourceTools.test.d.ts +0 -1
  75. package/dist/agent/tests/mcpResourceTools.test.js +0 -95
  76. package/dist/agent/tests/modelFactory.test.cjs +0 -190
  77. package/dist/agent/tests/modelFactory.test.d.ts +0 -1
  78. package/dist/agent/tests/modelFactory.test.js +0 -184
  79. package/dist/agent/tests/terminalSessionManager.test.cjs +0 -121
  80. package/dist/agent/tests/terminalSessionManager.test.d.ts +0 -1
  81. package/dist/agent/tests/terminalSessionManager.test.js +0 -115
  82. package/dist/agent/tests/test-agent-loader.cjs +0 -33
  83. package/dist/agent/tests/test-agent-loader.d.ts +0 -1
  84. package/dist/agent/tests/test-agent-loader.js +0 -27
  85. package/dist/agent/tests/test-subagent-loading.cjs +0 -99
  86. package/dist/agent/tests/test-subagent-loading.d.ts +0 -1
  87. package/dist/agent/tests/test-subagent-loading.js +0 -93
  88. package/dist/agent/tests/toolRegistry.test.cjs +0 -147
  89. package/dist/agent/tests/toolRegistry.test.d.ts +0 -1
  90. package/dist/agent/tests/toolRegistry.test.js +0 -141
  91. package/dist/agent/tests/uiRegistryTools.test.cjs +0 -114
  92. package/dist/agent/tests/uiRegistryTools.test.d.ts +0 -1
  93. package/dist/agent/tests/uiRegistryTools.test.js +0 -105
  94. package/dist/agent/tests/xaiImageModel.test.cjs +0 -194
  95. package/dist/agent/tests/xaiImageModel.test.d.ts +0 -1
  96. package/dist/agent/tests/xaiImageModel.test.js +0 -188
  97. package/dist/tests/additionalMessageMiddleware.test.cjs +0 -216
  98. package/dist/tests/additionalMessageMiddleware.test.d.ts +0 -1
  99. package/dist/tests/additionalMessageMiddleware.test.js +0 -188
  100. package/dist/tests/agent-config-voice.test.cjs +0 -25
  101. package/dist/tests/agent-config-voice.test.d.ts +0 -1
  102. package/dist/tests/agent-config-voice.test.js +0 -19
  103. package/dist/tests/agentInvokerAttachments.test.cjs +0 -190
  104. package/dist/tests/agentInvokerAttachments.test.d.ts +0 -1
  105. package/dist/tests/agentInvokerAttachments.test.js +0 -184
  106. package/dist/tests/agentInvokerSummarization.test.cjs +0 -613
  107. package/dist/tests/agentInvokerSummarization.test.d.ts +0 -1
  108. package/dist/tests/agentInvokerSummarization.test.js +0 -607
  109. package/dist/tests/agentInvokerTokenUsage.test.cjs +0 -124
  110. package/dist/tests/agentInvokerTokenUsage.test.d.ts +0 -1
  111. package/dist/tests/agentInvokerTokenUsage.test.js +0 -118
  112. package/dist/tests/agentInvokerWorkdir.test.cjs +0 -150
  113. package/dist/tests/agentInvokerWorkdir.test.d.ts +0 -1
  114. package/dist/tests/agentInvokerWorkdir.test.js +0 -122
  115. package/dist/tests/agents-api.test.cjs +0 -324
  116. package/dist/tests/agents-api.test.d.ts +0 -1
  117. package/dist/tests/agents-api.test.js +0 -318
  118. package/dist/tests/attachments-utils.test.cjs +0 -46
  119. package/dist/tests/attachments-utils.test.d.ts +0 -1
  120. package/dist/tests/attachments-utils.test.js +0 -40
  121. package/dist/tests/browser-command.test.cjs +0 -264
  122. package/dist/tests/browser-command.test.d.ts +0 -1
  123. package/dist/tests/browser-command.test.js +0 -258
  124. package/dist/tests/browser-relay-server.test.cjs +0 -20
  125. package/dist/tests/browser-relay-server.test.d.ts +0 -1
  126. package/dist/tests/browser-relay-server.test.js +0 -14
  127. package/dist/tests/bunSqliteAdapter.test.cjs +0 -265
  128. package/dist/tests/bunSqliteAdapter.test.d.ts +0 -1
  129. package/dist/tests/bunSqliteAdapter.test.js +0 -259
  130. package/dist/tests/candleRange.test.cjs +0 -48
  131. package/dist/tests/candleRange.test.d.ts +0 -1
  132. package/dist/tests/candleRange.test.js +0 -42
  133. package/dist/tests/cli-config-loader.test.cjs +0 -532
  134. package/dist/tests/cli-config-loader.test.d.ts +0 -1
  135. package/dist/tests/cli-config-loader.test.js +0 -526
  136. package/dist/tests/cli-config-warnings.test.cjs +0 -94
  137. package/dist/tests/cli-config-warnings.test.d.ts +0 -1
  138. package/dist/tests/cli-config-warnings.test.js +0 -88
  139. package/dist/tests/cli-init.test.cjs +0 -225
  140. package/dist/tests/cli-init.test.d.ts +0 -1
  141. package/dist/tests/cli-init.test.js +0 -219
  142. package/dist/tests/cli-workspace-root.test.cjs +0 -114
  143. package/dist/tests/cli-workspace-root.test.d.ts +0 -1
  144. package/dist/tests/cli-workspace-root.test.js +0 -108
  145. package/dist/tests/codex-credentials-precedence.test.cjs +0 -94
  146. package/dist/tests/codex-credentials-precedence.test.d.ts +0 -1
  147. package/dist/tests/codex-credentials-precedence.test.js +0 -88
  148. package/dist/tests/codex-provider.test.cjs +0 -383
  149. package/dist/tests/codex-provider.test.d.ts +0 -1
  150. package/dist/tests/codex-provider.test.js +0 -377
  151. package/dist/tests/config-json-schema.test.cjs +0 -37
  152. package/dist/tests/config-json-schema.test.d.ts +0 -1
  153. package/dist/tests/config-json-schema.test.js +0 -31
  154. package/dist/tests/discord-adapter.test.cjs +0 -89
  155. package/dist/tests/discord-adapter.test.d.ts +0 -1
  156. package/dist/tests/discord-adapter.test.js +0 -83
  157. package/dist/tests/falRuntime.test.cjs +0 -78
  158. package/dist/tests/falRuntime.test.d.ts +0 -1
  159. package/dist/tests/falRuntime.test.js +0 -72
  160. package/dist/tests/falSummary.test.cjs +0 -51
  161. package/dist/tests/falSummary.test.d.ts +0 -1
  162. package/dist/tests/falSummary.test.js +0 -45
  163. package/dist/tests/fs-api.test.cjs +0 -138
  164. package/dist/tests/fs-api.test.d.ts +0 -1
  165. package/dist/tests/fs-api.test.js +0 -132
  166. package/dist/tests/gateway-command-workspace.test.cjs +0 -150
  167. package/dist/tests/gateway-command-workspace.test.d.ts +0 -1
  168. package/dist/tests/gateway-command-workspace.test.js +0 -144
  169. package/dist/tests/gateway-http-security.test.cjs +0 -318
  170. package/dist/tests/gateway-http-security.test.d.ts +0 -1
  171. package/dist/tests/gateway-http-security.test.js +0 -312
  172. package/dist/tests/gateway-node-mode.test.cjs +0 -174
  173. package/dist/tests/gateway-node-mode.test.d.ts +0 -1
  174. package/dist/tests/gateway-node-mode.test.js +0 -168
  175. package/dist/tests/gateway-origin-policy.test.cjs +0 -82
  176. package/dist/tests/gateway-origin-policy.test.d.ts +0 -1
  177. package/dist/tests/gateway-origin-policy.test.js +0 -76
  178. package/dist/tests/gateway-request-execution-overrides.test.cjs +0 -42
  179. package/dist/tests/gateway-request-execution-overrides.test.d.ts +0 -1
  180. package/dist/tests/gateway-request-execution-overrides.test.js +0 -36
  181. package/dist/tests/gateway.test.cjs +0 -700
  182. package/dist/tests/gateway.test.d.ts +0 -1
  183. package/dist/tests/gateway.test.js +0 -694
  184. package/dist/tests/hooks-matcher.test.cjs +0 -309
  185. package/dist/tests/hooks-matcher.test.d.ts +0 -1
  186. package/dist/tests/hooks-matcher.test.js +0 -303
  187. package/dist/tests/hooks-merger.test.cjs +0 -528
  188. package/dist/tests/hooks-merger.test.d.ts +0 -1
  189. package/dist/tests/hooks-merger.test.js +0 -522
  190. package/dist/tests/imagePersistence.test.cjs +0 -169
  191. package/dist/tests/imagePersistence.test.d.ts +0 -1
  192. package/dist/tests/imagePersistence.test.js +0 -163
  193. package/dist/tests/integration/agent-invocation.integration.test.cjs +0 -264
  194. package/dist/tests/integration/agent-invocation.integration.test.d.ts +0 -1
  195. package/dist/tests/integration/agent-invocation.integration.test.js +0 -258
  196. package/dist/tests/integration/finnhub-candles.integration.test.cjs +0 -98
  197. package/dist/tests/integration/finnhub-candles.integration.test.d.ts +0 -1
  198. package/dist/tests/integration/finnhub-candles.integration.test.js +0 -92
  199. package/dist/tests/integration/summarization-e2e.integration.test.cjs +0 -127
  200. package/dist/tests/integration/summarization-e2e.integration.test.d.ts +0 -1
  201. package/dist/tests/integration/summarization-e2e.integration.test.js +0 -121
  202. package/dist/tests/logger.test.cjs +0 -353
  203. package/dist/tests/logger.test.d.ts +0 -1
  204. package/dist/tests/logger.test.js +0 -347
  205. package/dist/tests/mediaCompatibilityMiddleware.test.cjs +0 -106
  206. package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +0 -1
  207. package/dist/tests/mediaCompatibilityMiddleware.test.js +0 -100
  208. package/dist/tests/node-tools.test.cjs +0 -77
  209. package/dist/tests/node-tools.test.d.ts +0 -1
  210. package/dist/tests/node-tools.test.js +0 -71
  211. package/dist/tests/nodes-api.test.cjs +0 -86
  212. package/dist/tests/nodes-api.test.d.ts +0 -1
  213. package/dist/tests/nodes-api.test.js +0 -80
  214. package/dist/tests/outputManagerContextSummarized.test.cjs +0 -43
  215. package/dist/tests/outputManagerContextSummarized.test.d.ts +0 -1
  216. package/dist/tests/outputManagerContextSummarized.test.js +0 -37
  217. package/dist/tests/provider-command-codex.test.cjs +0 -57
  218. package/dist/tests/provider-command-codex.test.d.ts +0 -1
  219. package/dist/tests/provider-command-codex.test.js +0 -51
  220. package/dist/tests/routines-api.test.cjs +0 -107
  221. package/dist/tests/routines-api.test.d.ts +0 -1
  222. package/dist/tests/routines-api.test.js +0 -101
  223. package/dist/tests/run-terminal-bench-official-script.test.cjs +0 -61
  224. package/dist/tests/run-terminal-bench-official-script.test.d.ts +0 -1
  225. package/dist/tests/run-terminal-bench-official-script.test.js +0 -55
  226. package/dist/tests/sessionManager-uionly.test.cjs +0 -50
  227. package/dist/tests/sessionManager-uionly.test.d.ts +0 -1
  228. package/dist/tests/sessionManager-uionly.test.js +0 -44
  229. package/dist/tests/sessionMessageAttachments.test.cjs +0 -197
  230. package/dist/tests/sessionMessageAttachments.test.d.ts +0 -1
  231. package/dist/tests/sessionMessageAttachments.test.js +0 -191
  232. package/dist/tests/sessionMessageRole.test.cjs +0 -44
  233. package/dist/tests/sessionMessageRole.test.d.ts +0 -1
  234. package/dist/tests/sessionMessageRole.test.js +0 -38
  235. package/dist/tests/sessionStateMessages.test.cjs +0 -236
  236. package/dist/tests/sessionStateMessages.test.d.ts +0 -1
  237. package/dist/tests/sessionStateMessages.test.js +0 -230
  238. package/dist/tests/sessions-api.test.cjs +0 -250
  239. package/dist/tests/sessions-api.test.d.ts +0 -1
  240. package/dist/tests/sessions-api.test.js +0 -244
  241. package/dist/tests/skill-activation.test.cjs +0 -86
  242. package/dist/tests/skill-activation.test.d.ts +0 -1
  243. package/dist/tests/skill-activation.test.js +0 -80
  244. package/dist/tests/skill-metadata.test.cjs +0 -119
  245. package/dist/tests/skill-metadata.test.d.ts +0 -1
  246. package/dist/tests/skill-metadata.test.js +0 -113
  247. package/dist/tests/skill-repository.test.cjs +0 -469
  248. package/dist/tests/skill-repository.test.d.ts +0 -1
  249. package/dist/tests/skill-repository.test.js +0 -463
  250. package/dist/tests/skill-security-scanner.test.cjs +0 -126
  251. package/dist/tests/skill-security-scanner.test.d.ts +0 -1
  252. package/dist/tests/skill-security-scanner.test.js +0 -120
  253. package/dist/tests/sms-api.test.cjs +0 -183
  254. package/dist/tests/sms-api.test.d.ts +0 -1
  255. package/dist/tests/sms-api.test.js +0 -177
  256. package/dist/tests/sms-commands.test.cjs +0 -90
  257. package/dist/tests/sms-commands.test.d.ts +0 -1
  258. package/dist/tests/sms-commands.test.js +0 -84
  259. package/dist/tests/sms-policy-store.test.cjs +0 -69
  260. package/dist/tests/sms-policy-store.test.d.ts +0 -1
  261. package/dist/tests/sms-policy-store.test.js +0 -63
  262. package/dist/tests/teams-adapter.test.cjs +0 -58
  263. package/dist/tests/teams-adapter.test.d.ts +0 -1
  264. package/dist/tests/teams-adapter.test.js +0 -52
  265. package/dist/tests/technicalIndicators.test.cjs +0 -82
  266. package/dist/tests/technicalIndicators.test.d.ts +0 -1
  267. package/dist/tests/technicalIndicators.test.js +0 -76
  268. package/dist/tests/terminal-bench-adapters-helpers.test.cjs +0 -64
  269. package/dist/tests/terminal-bench-adapters-helpers.test.d.ts +0 -1
  270. package/dist/tests/terminal-bench-adapters-helpers.test.js +0 -58
  271. package/dist/tests/terminal-bench-cleanup.test.cjs +0 -93
  272. package/dist/tests/terminal-bench-cleanup.test.d.ts +0 -1
  273. package/dist/tests/terminal-bench-cleanup.test.js +0 -87
  274. package/dist/tests/terminal-bench-config.test.cjs +0 -62
  275. package/dist/tests/terminal-bench-config.test.d.ts +0 -1
  276. package/dist/tests/terminal-bench-config.test.js +0 -56
  277. package/dist/tests/terminal-bench-official.test.cjs +0 -194
  278. package/dist/tests/terminal-bench-official.test.d.ts +0 -1
  279. package/dist/tests/terminal-bench-official.test.js +0 -188
  280. package/dist/tests/terminal-bench-runner.test.cjs +0 -82
  281. package/dist/tests/terminal-bench-runner.test.d.ts +0 -1
  282. package/dist/tests/terminal-bench-runner.test.js +0 -76
  283. package/dist/tests/terminal-bench-scoring.test.cjs +0 -128
  284. package/dist/tests/terminal-bench-scoring.test.d.ts +0 -1
  285. package/dist/tests/terminal-bench-scoring.test.js +0 -122
  286. package/dist/tests/terminalProbe.test.cjs +0 -45
  287. package/dist/tests/terminalProbe.test.d.ts +0 -1
  288. package/dist/tests/terminalProbe.test.js +0 -39
  289. package/dist/tests/terminalProbeAuth.test.cjs +0 -85
  290. package/dist/tests/terminalProbeAuth.test.d.ts +0 -1
  291. package/dist/tests/terminalProbeAuth.test.js +0 -79
  292. package/dist/tests/toolDisplayHelpers.test.cjs +0 -46
  293. package/dist/tests/toolDisplayHelpers.test.d.ts +0 -1
  294. package/dist/tests/toolDisplayHelpers.test.js +0 -40
  295. package/dist/tests/uv.test.cjs +0 -47
  296. package/dist/tests/uv.test.d.ts +0 -1
  297. package/dist/tests/uv.test.js +0 -41
  298. package/dist/tests/voice-config.test.cjs +0 -35
  299. package/dist/tests/voice-config.test.d.ts +0 -1
  300. package/dist/tests/voice-config.test.js +0 -29
  301. package/dist/tests/websocket-transport.test.cjs +0 -31
  302. package/dist/tests/websocket-transport.test.d.ts +0 -1
  303. package/dist/tests/websocket-transport.test.js +0 -25
  304. package/dist/tests/yahooCandles.test.cjs +0 -111
  305. package/dist/tests/yahooCandles.test.d.ts +0 -1
  306. package/dist/tests/yahooCandles.test.js +0 -105
  307. package/dist/tools/finance/optionsAnalytics.test.cjs +0 -128
  308. package/dist/tools/finance/optionsAnalytics.test.d.ts +0 -1
  309. package/dist/tools/finance/optionsAnalytics.test.js +0 -122
  310. package/dist/webui/assets/index-BMf95nv5.js +0 -215
  311. package/dist/webui/assets/index-DhJQ8Mbn.css +0 -11
@@ -1,309 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_vitest_namespaceObject = require("vitest");
4
- const matcher_cjs_namespaceObject = require("../agent/middleware/hooks/matcher.cjs");
5
- (0, external_vitest_namespaceObject.describe)("Hooks Pattern Matching", ()=>{
6
- (0, external_vitest_namespaceObject.describe)("matchesToolPattern", ()=>{
7
- (0, external_vitest_namespaceObject.describe)("Wildcard patterns", ()=>{
8
- (0, external_vitest_namespaceObject.it)("should match all tools with wildcard *", ()=>{
9
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", "*")).toBe(true);
10
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", "*")).toBe(true);
11
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("any_tool", "*")).toBe(true);
12
- });
13
- (0, external_vitest_namespaceObject.it)("should match all tools with empty string", ()=>{
14
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", "")).toBe(true);
15
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", "")).toBe(true);
16
- });
17
- (0, external_vitest_namespaceObject.it)("should match all tools with undefined pattern", ()=>{
18
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", void 0)).toBe(true);
19
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", void 0)).toBe(true);
20
- });
21
- });
22
- (0, external_vitest_namespaceObject.describe)("Exact match", ()=>{
23
- (0, external_vitest_namespaceObject.it)("should match exact tool name", ()=>{
24
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", "write_file")).toBe(true);
25
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", "read_file")).toBe(true);
26
- });
27
- (0, external_vitest_namespaceObject.it)("should not match different tool names", ()=>{
28
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", "read_file")).toBe(false);
29
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", "write_file")).toBe(false);
30
- });
31
- (0, external_vitest_namespaceObject.it)("should be case-sensitive", ()=>{
32
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", "WRITE_FILE")).toBe(false);
33
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("Write_File", "write_file")).toBe(false);
34
- });
35
- });
36
- (0, external_vitest_namespaceObject.describe)("Pipe-separated lists", ()=>{
37
- (0, external_vitest_namespaceObject.it)("should match any tool in pipe-separated list", ()=>{
38
- const pattern = "write_file|read_file|edit_file";
39
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", pattern)).toBe(true);
40
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", pattern)).toBe(true);
41
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("edit_file", pattern)).toBe(true);
42
- });
43
- (0, external_vitest_namespaceObject.it)("should not match tools not in the list", ()=>{
44
- const pattern = "write_file|read_file";
45
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("delete_file", pattern)).toBe(false);
46
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("search", pattern)).toBe(false);
47
- });
48
- (0, external_vitest_namespaceObject.it)("should handle whitespace around pipe separators", ()=>{
49
- const pattern = "write_file | read_file | edit_file";
50
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", pattern)).toBe(true);
51
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", pattern)).toBe(true);
52
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("edit_file", pattern)).toBe(true);
53
- });
54
- (0, external_vitest_namespaceObject.it)("should handle single item in pipe-separated list", ()=>{
55
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", "write_file|")).toBe(true);
56
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", "|write_file")).toBe(true);
57
- });
58
- });
59
- (0, external_vitest_namespaceObject.describe)("Regex patterns", ()=>{
60
- (0, external_vitest_namespaceObject.it)("should match regex patterns", ()=>{
61
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", ".*_file")).toBe(true);
62
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", ".*_file")).toBe(true);
63
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("delete_file", ".*_file")).toBe(true);
64
- });
65
- (0, external_vitest_namespaceObject.it)("should not match when regex doesn't match", ()=>{
66
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("search", ".*_file")).toBe(false);
67
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("internet_search", ".*_file")).toBe(false);
68
- });
69
- (0, external_vitest_namespaceObject.it)("should handle complex regex patterns", ()=>{
70
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file", "^write_.*")).toBe(true);
71
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_code", "^write_.*")).toBe(true);
72
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("read_file", "^write_.*")).toBe(false);
73
- });
74
- (0, external_vitest_namespaceObject.it)("should handle character classes in regex", ()=>{
75
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write1_file", "write[0-9]_file")).toBe(true);
76
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write2_file", "write[0-9]_file")).toBe(true);
77
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("writeA_file", "write[0-9]_file")).toBe(false);
78
- });
79
- (0, external_vitest_namespaceObject.it)("should fallback to exact match for invalid regex", ()=>{
80
- const invalidPattern = "[invalid(regex";
81
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)(invalidPattern, invalidPattern)).toBe(true);
82
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("other_tool", invalidPattern)).toBe(false);
83
- });
84
- });
85
- (0, external_vitest_namespaceObject.describe)("Edge cases", ()=>{
86
- (0, external_vitest_namespaceObject.it)("should handle empty tool name", ()=>{
87
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("", "*")).toBe(true);
88
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("", "")).toBe(true);
89
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("", "write_file")).toBe(false);
90
- });
91
- (0, external_vitest_namespaceObject.it)("should handle special characters in tool names", ()=>{
92
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write_file-v2", "write_file-v2")).toBe(true);
93
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write.file", "write.file")).toBe(true);
94
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.matchesToolPattern)("write$file", "write$file")).toBe(true);
95
- });
96
- });
97
- });
98
- (0, external_vitest_namespaceObject.describe)("findMatchingHooks", ()=>{
99
- const mockHook1 = {
100
- type: "command",
101
- command: "echo 'hook1'",
102
- timeout: 30
103
- };
104
- const mockHook2 = {
105
- type: "command",
106
- command: "echo 'hook2'",
107
- timeout: 60
108
- };
109
- const mockHook3 = {
110
- type: "command",
111
- command: "echo 'hook3'"
112
- };
113
- (0, external_vitest_namespaceObject.describe)("Basic matching", ()=>{
114
- (0, external_vitest_namespaceObject.it)("should return empty array when no matchers provided", ()=>{
115
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)(void 0, "write_file");
116
- (0, external_vitest_namespaceObject.expect)(result).toEqual([]);
117
- });
118
- (0, external_vitest_namespaceObject.it)("should return empty array when matchers array is empty", ()=>{
119
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)([], "write_file");
120
- (0, external_vitest_namespaceObject.expect)(result).toEqual([]);
121
- });
122
- (0, external_vitest_namespaceObject.it)("should return hooks that match the tool name", ()=>{
123
- const matchers = [
124
- {
125
- matcher: "write_file",
126
- hooks: [
127
- mockHook1
128
- ]
129
- }
130
- ];
131
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file");
132
- (0, external_vitest_namespaceObject.expect)(result).toHaveLength(1);
133
- (0, external_vitest_namespaceObject.expect)(result[0]).toBe(mockHook1);
134
- });
135
- (0, external_vitest_namespaceObject.it)("should return empty array when no matchers match", ()=>{
136
- const matchers = [
137
- {
138
- matcher: "write_file",
139
- hooks: [
140
- mockHook1
141
- ]
142
- },
143
- {
144
- matcher: "edit_file",
145
- hooks: [
146
- mockHook2
147
- ]
148
- }
149
- ];
150
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "read_file");
151
- (0, external_vitest_namespaceObject.expect)(result).toEqual([]);
152
- });
153
- });
154
- (0, external_vitest_namespaceObject.describe)("Multiple matches", ()=>{
155
- (0, external_vitest_namespaceObject.it)("should return hooks from multiple matchers", ()=>{
156
- const matchers = [
157
- {
158
- matcher: "write_file",
159
- hooks: [
160
- mockHook1
161
- ]
162
- },
163
- {
164
- matcher: "write_file",
165
- hooks: [
166
- mockHook2
167
- ]
168
- }
169
- ];
170
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file");
171
- (0, external_vitest_namespaceObject.expect)(result).toHaveLength(2);
172
- (0, external_vitest_namespaceObject.expect)(result).toContain(mockHook1);
173
- (0, external_vitest_namespaceObject.expect)(result).toContain(mockHook2);
174
- });
175
- (0, external_vitest_namespaceObject.it)("should return all hooks from a matcher with multiple hooks", ()=>{
176
- const matchers = [
177
- {
178
- matcher: "write_file",
179
- hooks: [
180
- mockHook1,
181
- mockHook2,
182
- mockHook3
183
- ]
184
- }
185
- ];
186
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file");
187
- (0, external_vitest_namespaceObject.expect)(result).toHaveLength(3);
188
- (0, external_vitest_namespaceObject.expect)(result).toContain(mockHook1);
189
- (0, external_vitest_namespaceObject.expect)(result).toContain(mockHook2);
190
- (0, external_vitest_namespaceObject.expect)(result).toContain(mockHook3);
191
- });
192
- (0, external_vitest_namespaceObject.it)("should flatten hooks from multiple matching matchers", ()=>{
193
- const matchers = [
194
- {
195
- matcher: ".*_file",
196
- hooks: [
197
- mockHook1
198
- ]
199
- },
200
- {
201
- matcher: "write_file|read_file",
202
- hooks: [
203
- mockHook2
204
- ]
205
- },
206
- {
207
- matcher: "*",
208
- hooks: [
209
- mockHook3
210
- ]
211
- }
212
- ];
213
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file");
214
- (0, external_vitest_namespaceObject.expect)(result).toHaveLength(3);
215
- (0, external_vitest_namespaceObject.expect)(result[0]).toBe(mockHook1);
216
- (0, external_vitest_namespaceObject.expect)(result[1]).toBe(mockHook2);
217
- (0, external_vitest_namespaceObject.expect)(result[2]).toBe(mockHook3);
218
- });
219
- });
220
- (0, external_vitest_namespaceObject.describe)("Pattern types", ()=>{
221
- (0, external_vitest_namespaceObject.it)("should match with wildcard pattern", ()=>{
222
- const matchers = [
223
- {
224
- matcher: "*",
225
- hooks: [
226
- mockHook1
227
- ]
228
- }
229
- ];
230
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file")).toHaveLength(1);
231
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "read_file")).toHaveLength(1);
232
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "any_tool")).toHaveLength(1);
233
- });
234
- (0, external_vitest_namespaceObject.it)("should match with pipe-separated list", ()=>{
235
- const matchers = [
236
- {
237
- matcher: "write_file|read_file|edit_file",
238
- hooks: [
239
- mockHook1
240
- ]
241
- }
242
- ];
243
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file")).toHaveLength(1);
244
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "read_file")).toHaveLength(1);
245
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "delete_file")).toHaveLength(0);
246
- });
247
- (0, external_vitest_namespaceObject.it)("should match with regex pattern", ()=>{
248
- const matchers = [
249
- {
250
- matcher: ".*_file",
251
- hooks: [
252
- mockHook1
253
- ]
254
- }
255
- ];
256
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file")).toHaveLength(1);
257
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "read_file")).toHaveLength(1);
258
- (0, external_vitest_namespaceObject.expect)((0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "search")).toHaveLength(0);
259
- });
260
- });
261
- (0, external_vitest_namespaceObject.describe)("Order preservation", ()=>{
262
- (0, external_vitest_namespaceObject.it)("should preserve order of hooks from matchers", ()=>{
263
- const matchers = [
264
- {
265
- matcher: "*",
266
- hooks: [
267
- mockHook1,
268
- mockHook2
269
- ]
270
- },
271
- {
272
- matcher: "write_file",
273
- hooks: [
274
- mockHook3
275
- ]
276
- }
277
- ];
278
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file");
279
- (0, external_vitest_namespaceObject.expect)(result).toHaveLength(3);
280
- (0, external_vitest_namespaceObject.expect)(result[0]).toBe(mockHook1);
281
- (0, external_vitest_namespaceObject.expect)(result[1]).toBe(mockHook2);
282
- (0, external_vitest_namespaceObject.expect)(result[2]).toBe(mockHook3);
283
- });
284
- });
285
- (0, external_vitest_namespaceObject.describe)("Empty hook arrays", ()=>{
286
- (0, external_vitest_namespaceObject.it)("should handle matchers with empty hook arrays", ()=>{
287
- const matchers = [
288
- {
289
- matcher: "write_file",
290
- hooks: []
291
- },
292
- {
293
- matcher: "write_file",
294
- hooks: [
295
- mockHook1
296
- ]
297
- }
298
- ];
299
- const result = (0, matcher_cjs_namespaceObject.findMatchingHooks)(matchers, "write_file");
300
- (0, external_vitest_namespaceObject.expect)(result).toHaveLength(1);
301
- (0, external_vitest_namespaceObject.expect)(result[0]).toBe(mockHook1);
302
- });
303
- });
304
- });
305
- });
306
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
307
- Object.defineProperty(exports, '__esModule', {
308
- value: true
309
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,303 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { findMatchingHooks, matchesToolPattern } from "../agent/middleware/hooks/matcher.js";
3
- describe("Hooks Pattern Matching", ()=>{
4
- describe("matchesToolPattern", ()=>{
5
- describe("Wildcard patterns", ()=>{
6
- it("should match all tools with wildcard *", ()=>{
7
- expect(matchesToolPattern("write_file", "*")).toBe(true);
8
- expect(matchesToolPattern("read_file", "*")).toBe(true);
9
- expect(matchesToolPattern("any_tool", "*")).toBe(true);
10
- });
11
- it("should match all tools with empty string", ()=>{
12
- expect(matchesToolPattern("write_file", "")).toBe(true);
13
- expect(matchesToolPattern("read_file", "")).toBe(true);
14
- });
15
- it("should match all tools with undefined pattern", ()=>{
16
- expect(matchesToolPattern("write_file", void 0)).toBe(true);
17
- expect(matchesToolPattern("read_file", void 0)).toBe(true);
18
- });
19
- });
20
- describe("Exact match", ()=>{
21
- it("should match exact tool name", ()=>{
22
- expect(matchesToolPattern("write_file", "write_file")).toBe(true);
23
- expect(matchesToolPattern("read_file", "read_file")).toBe(true);
24
- });
25
- it("should not match different tool names", ()=>{
26
- expect(matchesToolPattern("write_file", "read_file")).toBe(false);
27
- expect(matchesToolPattern("read_file", "write_file")).toBe(false);
28
- });
29
- it("should be case-sensitive", ()=>{
30
- expect(matchesToolPattern("write_file", "WRITE_FILE")).toBe(false);
31
- expect(matchesToolPattern("Write_File", "write_file")).toBe(false);
32
- });
33
- });
34
- describe("Pipe-separated lists", ()=>{
35
- it("should match any tool in pipe-separated list", ()=>{
36
- const pattern = "write_file|read_file|edit_file";
37
- expect(matchesToolPattern("write_file", pattern)).toBe(true);
38
- expect(matchesToolPattern("read_file", pattern)).toBe(true);
39
- expect(matchesToolPattern("edit_file", pattern)).toBe(true);
40
- });
41
- it("should not match tools not in the list", ()=>{
42
- const pattern = "write_file|read_file";
43
- expect(matchesToolPattern("delete_file", pattern)).toBe(false);
44
- expect(matchesToolPattern("search", pattern)).toBe(false);
45
- });
46
- it("should handle whitespace around pipe separators", ()=>{
47
- const pattern = "write_file | read_file | edit_file";
48
- expect(matchesToolPattern("write_file", pattern)).toBe(true);
49
- expect(matchesToolPattern("read_file", pattern)).toBe(true);
50
- expect(matchesToolPattern("edit_file", pattern)).toBe(true);
51
- });
52
- it("should handle single item in pipe-separated list", ()=>{
53
- expect(matchesToolPattern("write_file", "write_file|")).toBe(true);
54
- expect(matchesToolPattern("write_file", "|write_file")).toBe(true);
55
- });
56
- });
57
- describe("Regex patterns", ()=>{
58
- it("should match regex patterns", ()=>{
59
- expect(matchesToolPattern("write_file", ".*_file")).toBe(true);
60
- expect(matchesToolPattern("read_file", ".*_file")).toBe(true);
61
- expect(matchesToolPattern("delete_file", ".*_file")).toBe(true);
62
- });
63
- it("should not match when regex doesn't match", ()=>{
64
- expect(matchesToolPattern("search", ".*_file")).toBe(false);
65
- expect(matchesToolPattern("internet_search", ".*_file")).toBe(false);
66
- });
67
- it("should handle complex regex patterns", ()=>{
68
- expect(matchesToolPattern("write_file", "^write_.*")).toBe(true);
69
- expect(matchesToolPattern("write_code", "^write_.*")).toBe(true);
70
- expect(matchesToolPattern("read_file", "^write_.*")).toBe(false);
71
- });
72
- it("should handle character classes in regex", ()=>{
73
- expect(matchesToolPattern("write1_file", "write[0-9]_file")).toBe(true);
74
- expect(matchesToolPattern("write2_file", "write[0-9]_file")).toBe(true);
75
- expect(matchesToolPattern("writeA_file", "write[0-9]_file")).toBe(false);
76
- });
77
- it("should fallback to exact match for invalid regex", ()=>{
78
- const invalidPattern = "[invalid(regex";
79
- expect(matchesToolPattern(invalidPattern, invalidPattern)).toBe(true);
80
- expect(matchesToolPattern("other_tool", invalidPattern)).toBe(false);
81
- });
82
- });
83
- describe("Edge cases", ()=>{
84
- it("should handle empty tool name", ()=>{
85
- expect(matchesToolPattern("", "*")).toBe(true);
86
- expect(matchesToolPattern("", "")).toBe(true);
87
- expect(matchesToolPattern("", "write_file")).toBe(false);
88
- });
89
- it("should handle special characters in tool names", ()=>{
90
- expect(matchesToolPattern("write_file-v2", "write_file-v2")).toBe(true);
91
- expect(matchesToolPattern("write.file", "write.file")).toBe(true);
92
- expect(matchesToolPattern("write$file", "write$file")).toBe(true);
93
- });
94
- });
95
- });
96
- describe("findMatchingHooks", ()=>{
97
- const mockHook1 = {
98
- type: "command",
99
- command: "echo 'hook1'",
100
- timeout: 30
101
- };
102
- const mockHook2 = {
103
- type: "command",
104
- command: "echo 'hook2'",
105
- timeout: 60
106
- };
107
- const mockHook3 = {
108
- type: "command",
109
- command: "echo 'hook3'"
110
- };
111
- describe("Basic matching", ()=>{
112
- it("should return empty array when no matchers provided", ()=>{
113
- const result = findMatchingHooks(void 0, "write_file");
114
- expect(result).toEqual([]);
115
- });
116
- it("should return empty array when matchers array is empty", ()=>{
117
- const result = findMatchingHooks([], "write_file");
118
- expect(result).toEqual([]);
119
- });
120
- it("should return hooks that match the tool name", ()=>{
121
- const matchers = [
122
- {
123
- matcher: "write_file",
124
- hooks: [
125
- mockHook1
126
- ]
127
- }
128
- ];
129
- const result = findMatchingHooks(matchers, "write_file");
130
- expect(result).toHaveLength(1);
131
- expect(result[0]).toBe(mockHook1);
132
- });
133
- it("should return empty array when no matchers match", ()=>{
134
- const matchers = [
135
- {
136
- matcher: "write_file",
137
- hooks: [
138
- mockHook1
139
- ]
140
- },
141
- {
142
- matcher: "edit_file",
143
- hooks: [
144
- mockHook2
145
- ]
146
- }
147
- ];
148
- const result = findMatchingHooks(matchers, "read_file");
149
- expect(result).toEqual([]);
150
- });
151
- });
152
- describe("Multiple matches", ()=>{
153
- it("should return hooks from multiple matchers", ()=>{
154
- const matchers = [
155
- {
156
- matcher: "write_file",
157
- hooks: [
158
- mockHook1
159
- ]
160
- },
161
- {
162
- matcher: "write_file",
163
- hooks: [
164
- mockHook2
165
- ]
166
- }
167
- ];
168
- const result = findMatchingHooks(matchers, "write_file");
169
- expect(result).toHaveLength(2);
170
- expect(result).toContain(mockHook1);
171
- expect(result).toContain(mockHook2);
172
- });
173
- it("should return all hooks from a matcher with multiple hooks", ()=>{
174
- const matchers = [
175
- {
176
- matcher: "write_file",
177
- hooks: [
178
- mockHook1,
179
- mockHook2,
180
- mockHook3
181
- ]
182
- }
183
- ];
184
- const result = findMatchingHooks(matchers, "write_file");
185
- expect(result).toHaveLength(3);
186
- expect(result).toContain(mockHook1);
187
- expect(result).toContain(mockHook2);
188
- expect(result).toContain(mockHook3);
189
- });
190
- it("should flatten hooks from multiple matching matchers", ()=>{
191
- const matchers = [
192
- {
193
- matcher: ".*_file",
194
- hooks: [
195
- mockHook1
196
- ]
197
- },
198
- {
199
- matcher: "write_file|read_file",
200
- hooks: [
201
- mockHook2
202
- ]
203
- },
204
- {
205
- matcher: "*",
206
- hooks: [
207
- mockHook3
208
- ]
209
- }
210
- ];
211
- const result = findMatchingHooks(matchers, "write_file");
212
- expect(result).toHaveLength(3);
213
- expect(result[0]).toBe(mockHook1);
214
- expect(result[1]).toBe(mockHook2);
215
- expect(result[2]).toBe(mockHook3);
216
- });
217
- });
218
- describe("Pattern types", ()=>{
219
- it("should match with wildcard pattern", ()=>{
220
- const matchers = [
221
- {
222
- matcher: "*",
223
- hooks: [
224
- mockHook1
225
- ]
226
- }
227
- ];
228
- expect(findMatchingHooks(matchers, "write_file")).toHaveLength(1);
229
- expect(findMatchingHooks(matchers, "read_file")).toHaveLength(1);
230
- expect(findMatchingHooks(matchers, "any_tool")).toHaveLength(1);
231
- });
232
- it("should match with pipe-separated list", ()=>{
233
- const matchers = [
234
- {
235
- matcher: "write_file|read_file|edit_file",
236
- hooks: [
237
- mockHook1
238
- ]
239
- }
240
- ];
241
- expect(findMatchingHooks(matchers, "write_file")).toHaveLength(1);
242
- expect(findMatchingHooks(matchers, "read_file")).toHaveLength(1);
243
- expect(findMatchingHooks(matchers, "delete_file")).toHaveLength(0);
244
- });
245
- it("should match with regex pattern", ()=>{
246
- const matchers = [
247
- {
248
- matcher: ".*_file",
249
- hooks: [
250
- mockHook1
251
- ]
252
- }
253
- ];
254
- expect(findMatchingHooks(matchers, "write_file")).toHaveLength(1);
255
- expect(findMatchingHooks(matchers, "read_file")).toHaveLength(1);
256
- expect(findMatchingHooks(matchers, "search")).toHaveLength(0);
257
- });
258
- });
259
- describe("Order preservation", ()=>{
260
- it("should preserve order of hooks from matchers", ()=>{
261
- const matchers = [
262
- {
263
- matcher: "*",
264
- hooks: [
265
- mockHook1,
266
- mockHook2
267
- ]
268
- },
269
- {
270
- matcher: "write_file",
271
- hooks: [
272
- mockHook3
273
- ]
274
- }
275
- ];
276
- const result = findMatchingHooks(matchers, "write_file");
277
- expect(result).toHaveLength(3);
278
- expect(result[0]).toBe(mockHook1);
279
- expect(result[1]).toBe(mockHook2);
280
- expect(result[2]).toBe(mockHook3);
281
- });
282
- });
283
- describe("Empty hook arrays", ()=>{
284
- it("should handle matchers with empty hook arrays", ()=>{
285
- const matchers = [
286
- {
287
- matcher: "write_file",
288
- hooks: []
289
- },
290
- {
291
- matcher: "write_file",
292
- hooks: [
293
- mockHook1
294
- ]
295
- }
296
- ];
297
- const result = findMatchingHooks(matchers, "write_file");
298
- expect(result).toHaveLength(1);
299
- expect(result[0]).toBe(mockHook1);
300
- });
301
- });
302
- });
303
- });