@wingman-ai/gateway 0.5.2 → 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-D07GBGp0.js +0 -215
  311. package/dist/webui/assets/index-DV8IYeOw.css +0 -11
@@ -1,347 +0,0 @@
1
- import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
2
- import { EventLogger, SilentLogger, WingmanLogger, createEventLogger, createLogger, createLoggerFromConfig } from "../logger.js";
3
- function _define_property(obj, key, value) {
4
- if (key in obj) Object.defineProperty(obj, key, {
5
- value: value,
6
- enumerable: true,
7
- configurable: true,
8
- writable: true
9
- });
10
- else obj[key] = value;
11
- return obj;
12
- }
13
- class MockWriteStream {
14
- write(chunk) {
15
- this.data += chunk;
16
- }
17
- constructor(){
18
- _define_property(this, "data", "");
19
- }
20
- }
21
- describe("Logger System", ()=>{
22
- describe("WingmanLogger", ()=>{
23
- let mockStream;
24
- beforeEach(()=>{
25
- mockStream = new MockWriteStream();
26
- });
27
- describe("Log level filtering", ()=>{
28
- it("should only log messages at or above configured level", ()=>{
29
- const logger = new WingmanLogger("warn", mockStream);
30
- logger.debug("debug message");
31
- logger.info("info message");
32
- logger.warn("warn message");
33
- logger.error("error message");
34
- expect(mockStream.data).not.toContain("debug message");
35
- expect(mockStream.data).not.toContain("info message");
36
- expect(mockStream.data).toContain("warn message");
37
- expect(mockStream.data).toContain("error message");
38
- });
39
- it("should log all messages when level is debug", ()=>{
40
- const logger = new WingmanLogger("debug", mockStream);
41
- logger.debug("debug message");
42
- logger.info("info message");
43
- logger.warn("warn message");
44
- logger.error("error message");
45
- expect(mockStream.data).toContain("debug message");
46
- expect(mockStream.data).toContain("info message");
47
- expect(mockStream.data).toContain("warn message");
48
- expect(mockStream.data).toContain("error message");
49
- });
50
- it("should not log any messages when level is silent", ()=>{
51
- const logger = new WingmanLogger("silent", mockStream);
52
- logger.debug("debug message");
53
- logger.info("info message");
54
- logger.warn("warn message");
55
- logger.error("error message");
56
- expect(mockStream.data).toBe("");
57
- });
58
- });
59
- describe("Log formatting", ()=>{
60
- it("should include timestamp and level in log output", ()=>{
61
- const logger = new WingmanLogger("info", mockStream);
62
- logger.info("test message");
63
- expect(mockStream.data).toMatch(/\[\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/);
64
- expect(mockStream.data).toContain("[INFO]");
65
- expect(mockStream.data).toContain("test message");
66
- });
67
- it("should serialize additional arguments as JSON", ()=>{
68
- const logger = new WingmanLogger("info", mockStream);
69
- logger.info("test message", {
70
- key: "value"
71
- }, [
72
- 1,
73
- 2,
74
- 3
75
- ]);
76
- expect(mockStream.data).toContain("test message");
77
- expect(mockStream.data).toContain('"key"');
78
- expect(mockStream.data).toContain('"value"');
79
- });
80
- it("should serialize error arguments with message and stack", ()=>{
81
- const logger = new WingmanLogger("info", mockStream);
82
- const err = new Error("boom");
83
- logger.error("test error", err);
84
- expect(mockStream.data).toContain("test error");
85
- expect(mockStream.data).toContain('"message"');
86
- expect(mockStream.data).toContain("boom");
87
- });
88
- it("should not include args when none provided", ()=>{
89
- const logger = new WingmanLogger("info", mockStream);
90
- logger.info("test message");
91
- const lines = mockStream.data.split("\n");
92
- expect(lines.filter((l)=>l.trim()).length).toBe(1);
93
- });
94
- });
95
- describe("Log levels", ()=>{
96
- it("should have debug method", ()=>{
97
- const logger = new WingmanLogger("debug", mockStream);
98
- expect(logger.debug).toBeDefined();
99
- expect(typeof logger.debug).toBe("function");
100
- });
101
- it("should have info method", ()=>{
102
- const logger = new WingmanLogger("info", mockStream);
103
- expect(logger.info).toBeDefined();
104
- expect(typeof logger.info).toBe("function");
105
- });
106
- it("should have warn method", ()=>{
107
- const logger = new WingmanLogger("warn", mockStream);
108
- expect(logger.warn).toBeDefined();
109
- expect(typeof logger.warn).toBe("function");
110
- });
111
- it("should have error method", ()=>{
112
- const logger = new WingmanLogger("error", mockStream);
113
- expect(logger.error).toBeDefined();
114
- expect(typeof logger.error).toBe("function");
115
- });
116
- });
117
- });
118
- describe("SilentLogger", ()=>{
119
- it("should not log any messages", ()=>{
120
- const logger = new SilentLogger();
121
- const consoleSpy = vi.spyOn(console, "log");
122
- logger.debug();
123
- logger.info();
124
- logger.warn();
125
- logger.error();
126
- expect(consoleSpy).not.toHaveBeenCalled();
127
- consoleSpy.mockRestore();
128
- });
129
- it("should have all required logger methods", ()=>{
130
- const logger = new SilentLogger();
131
- expect(logger.debug).toBeDefined();
132
- expect(logger.info).toBeDefined();
133
- expect(logger.warn).toBeDefined();
134
- expect(logger.error).toBeDefined();
135
- });
136
- });
137
- describe("EventLogger", ()=>{
138
- let mockCallback;
139
- beforeEach(()=>{
140
- mockCallback = vi.fn();
141
- });
142
- describe("Event emission", ()=>{
143
- it("should emit log events with correct structure", ()=>{
144
- const logger = new EventLogger(mockCallback, "info");
145
- logger.info("test message");
146
- expect(mockCallback).toHaveBeenCalledTimes(1);
147
- expect(mockCallback).toHaveBeenCalledWith({
148
- level: "info",
149
- message: "test message",
150
- timestamp: expect.stringMatching(/\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/),
151
- args: void 0
152
- });
153
- });
154
- it("should include args in events when provided", ()=>{
155
- const logger = new EventLogger(mockCallback, "info");
156
- const testArgs = [
157
- {
158
- key: "value"
159
- },
160
- [
161
- 1,
162
- 2,
163
- 3
164
- ]
165
- ];
166
- logger.info("test message", ...testArgs);
167
- expect(mockCallback).toHaveBeenCalledWith({
168
- level: "info",
169
- message: "test message",
170
- timestamp: expect.any(String),
171
- args: testArgs
172
- });
173
- });
174
- });
175
- describe("Level filtering", ()=>{
176
- it("should respect log level filtering", ()=>{
177
- const logger = new EventLogger(mockCallback, "warn");
178
- logger.debug("debug");
179
- logger.info("info");
180
- logger.warn("warn");
181
- logger.error("error");
182
- expect(mockCallback).toHaveBeenCalledTimes(2);
183
- expect(mockCallback).toHaveBeenCalledWith(expect.objectContaining({
184
- level: "warn"
185
- }));
186
- expect(mockCallback).toHaveBeenCalledWith(expect.objectContaining({
187
- level: "error"
188
- }));
189
- });
190
- it("should not emit events when level is silent", ()=>{
191
- const logger = new EventLogger(mockCallback, "silent");
192
- logger.debug("debug");
193
- logger.info("info");
194
- logger.warn("warn");
195
- logger.error("error");
196
- expect(mockCallback).not.toHaveBeenCalled();
197
- });
198
- });
199
- describe("All log levels", ()=>{
200
- it("should handle debug level", ()=>{
201
- const logger = new EventLogger(mockCallback, "debug");
202
- logger.debug("debug message");
203
- expect(mockCallback).toHaveBeenCalledWith(expect.objectContaining({
204
- level: "debug",
205
- message: "debug message"
206
- }));
207
- });
208
- it("should handle info level", ()=>{
209
- const logger = new EventLogger(mockCallback, "info");
210
- logger.info("info message");
211
- expect(mockCallback).toHaveBeenCalledWith(expect.objectContaining({
212
- level: "info",
213
- message: "info message"
214
- }));
215
- });
216
- it("should handle warn level", ()=>{
217
- const logger = new EventLogger(mockCallback, "info");
218
- logger.warn("warn message");
219
- expect(mockCallback).toHaveBeenCalledWith(expect.objectContaining({
220
- level: "warn",
221
- message: "warn message"
222
- }));
223
- });
224
- it("should handle error level", ()=>{
225
- const logger = new EventLogger(mockCallback, "info");
226
- logger.error("error message");
227
- expect(mockCallback).toHaveBeenCalledWith(expect.objectContaining({
228
- level: "error",
229
- message: "error message"
230
- }));
231
- });
232
- });
233
- });
234
- describe("Factory functions", ()=>{
235
- describe("createLogger", ()=>{
236
- const originalEnv = process.env.WINGMAN_LOG_LEVEL;
237
- afterEach(()=>{
238
- process.env.WINGMAN_LOG_LEVEL = originalEnv;
239
- });
240
- it("should create WingmanLogger by default", ()=>{
241
- const logger = createLogger("info");
242
- expect(logger).toBeInstanceOf(WingmanLogger);
243
- });
244
- it("should create SilentLogger when level is silent", ()=>{
245
- const logger = createLogger("silent");
246
- expect(logger).toBeInstanceOf(SilentLogger);
247
- });
248
- it("should use WINGMAN_LOG_LEVEL env var when no level provided", ()=>{
249
- process.env.WINGMAN_LOG_LEVEL = "debug";
250
- const logger = createLogger();
251
- expect(logger).toBeInstanceOf(WingmanLogger);
252
- });
253
- it("should default to info level when env var not set", ()=>{
254
- delete process.env.WINGMAN_LOG_LEVEL;
255
- const logger = createLogger();
256
- expect(logger).toBeInstanceOf(WingmanLogger);
257
- });
258
- });
259
- describe("createEventLogger", ()=>{
260
- it("should create EventLogger with callback", ()=>{
261
- const callback = vi.fn();
262
- const logger = createEventLogger(callback, "info");
263
- expect(logger).toBeInstanceOf(EventLogger);
264
- });
265
- it("should create EventLogger with default info level", ()=>{
266
- const callback = vi.fn();
267
- const logger = createEventLogger(callback);
268
- logger.info("test");
269
- expect(callback).toHaveBeenCalledWith(expect.objectContaining({
270
- level: "info"
271
- }));
272
- });
273
- });
274
- describe("createLoggerFromConfig", ()=>{
275
- it("should create logger from serializable config", ()=>{
276
- const logger = createLoggerFromConfig({
277
- level: "debug"
278
- });
279
- expect(logger).toBeInstanceOf(WingmanLogger);
280
- });
281
- it("should create silent logger from silent config", ()=>{
282
- const logger = createLoggerFromConfig({
283
- level: "silent"
284
- });
285
- expect(logger).toBeInstanceOf(SilentLogger);
286
- });
287
- });
288
- });
289
- describe("Log level hierarchy", ()=>{
290
- it("should respect level hierarchy: debug < info < warn < error", ()=>{
291
- const testCases = [
292
- {
293
- level: "debug",
294
- shouldLog: {
295
- debug: true,
296
- info: true,
297
- warn: true,
298
- error: true
299
- }
300
- },
301
- {
302
- level: "info",
303
- shouldLog: {
304
- debug: false,
305
- info: true,
306
- warn: true,
307
- error: true
308
- }
309
- },
310
- {
311
- level: "warn",
312
- shouldLog: {
313
- debug: false,
314
- info: false,
315
- warn: true,
316
- error: true
317
- }
318
- },
319
- {
320
- level: "error",
321
- shouldLog: {
322
- debug: false,
323
- info: false,
324
- warn: false,
325
- error: true
326
- }
327
- }
328
- ];
329
- for (const testCase of testCases){
330
- const callback = vi.fn();
331
- const logger = new EventLogger(callback, testCase.level);
332
- logger.debug("debug");
333
- logger.info("info");
334
- logger.warn("warn");
335
- logger.error("error");
336
- const debugCalls = callback.mock.calls.filter(([event])=>"debug" === event.level).length;
337
- const infoCalls = callback.mock.calls.filter(([event])=>"info" === event.level).length;
338
- const warnCalls = callback.mock.calls.filter(([event])=>"warn" === event.level).length;
339
- const errorCalls = callback.mock.calls.filter(([event])=>"error" === event.level).length;
340
- expect(debugCalls).toBe(testCase.shouldLog.debug ? 1 : 0);
341
- expect(infoCalls).toBe(testCase.shouldLog.info ? 1 : 0);
342
- expect(warnCalls).toBe(testCase.shouldLog.warn ? 1 : 0);
343
- expect(errorCalls).toBe(testCase.shouldLog.error ? 1 : 0);
344
- }
345
- });
346
- });
347
- });
@@ -1,106 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_vitest_namespaceObject = require("vitest");
4
- const media_compat_cjs_namespaceObject = require("../agent/middleware/media-compat.cjs");
5
- async function runBeforeAgent(middleware, input) {
6
- const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
7
- if (!beforeAgent) throw new Error("beforeAgent hook not configured");
8
- return await beforeAgent(input, {});
9
- }
10
- (0, external_vitest_namespaceObject.describe)("mediaCompatibilityMiddleware", ()=>{
11
- (0, external_vitest_namespaceObject.it)("strips audio blocks for Anthropic models and preserves other blocks", async ()=>{
12
- const middleware = (0, media_compat_cjs_namespaceObject.mediaCompatibilityMiddleware)({
13
- model: {
14
- constructor: {
15
- name: "ChatAnthropic"
16
- }
17
- }
18
- });
19
- const input = {
20
- messages: [
21
- {
22
- content: [
23
- {
24
- type: "text",
25
- text: "Hello"
26
- },
27
- {
28
- type: "audio",
29
- source_type: "base64",
30
- data: "abc"
31
- }
32
- ]
33
- }
34
- ]
35
- };
36
- const result = await runBeforeAgent(middleware, input);
37
- const content = result.messages[0]?.content;
38
- (0, external_vitest_namespaceObject.expect)(Array.isArray(content)).toBe(true);
39
- (0, external_vitest_namespaceObject.expect)(content).toHaveLength(1);
40
- (0, external_vitest_namespaceObject.expect)(content[0]?.type).toBe("text");
41
- });
42
- (0, external_vitest_namespaceObject.it)("replaces content with a placeholder when only audio blocks remain", async ()=>{
43
- const middleware = (0, media_compat_cjs_namespaceObject.mediaCompatibilityMiddleware)({
44
- model: {
45
- constructor: {
46
- name: "ChatAnthropic"
47
- }
48
- }
49
- });
50
- const input = {
51
- messages: [
52
- {
53
- content: [
54
- {
55
- type: "audio_url",
56
- audio_url: {
57
- url: "https://x/y"
58
- }
59
- }
60
- ]
61
- }
62
- ]
63
- };
64
- const result = await runBeforeAgent(middleware, input);
65
- const content = result.messages[0]?.content;
66
- (0, external_vitest_namespaceObject.expect)(typeof content).toBe("string");
67
- (0, external_vitest_namespaceObject.expect)(content).toContain("Audio omitted");
68
- });
69
- (0, external_vitest_namespaceObject.it)("leaves audio blocks untouched for non-Anthropic models", async ()=>{
70
- const middleware = (0, media_compat_cjs_namespaceObject.mediaCompatibilityMiddleware)({
71
- model: {
72
- constructor: {
73
- name: "ChatOpenAI"
74
- }
75
- }
76
- });
77
- const input = {
78
- messages: [
79
- {
80
- content: [
81
- {
82
- type: "text",
83
- text: "Hello"
84
- },
85
- {
86
- type: "input_audio",
87
- input_audio: {
88
- data: "abc",
89
- format: "wav"
90
- }
91
- }
92
- ]
93
- }
94
- ]
95
- };
96
- const result = await runBeforeAgent(middleware, input);
97
- const content = result.messages[0]?.content;
98
- (0, external_vitest_namespaceObject.expect)(Array.isArray(content)).toBe(true);
99
- (0, external_vitest_namespaceObject.expect)(content).toHaveLength(2);
100
- (0, external_vitest_namespaceObject.expect)(content[1]?.type).toBe("input_audio");
101
- });
102
- });
103
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
104
- Object.defineProperty(exports, '__esModule', {
105
- value: true
106
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,100 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { mediaCompatibilityMiddleware } from "../agent/middleware/media-compat.js";
3
- async function runBeforeAgent(middleware, input) {
4
- const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
5
- if (!beforeAgent) throw new Error("beforeAgent hook not configured");
6
- return await beforeAgent(input, {});
7
- }
8
- describe("mediaCompatibilityMiddleware", ()=>{
9
- it("strips audio blocks for Anthropic models and preserves other blocks", async ()=>{
10
- const middleware = mediaCompatibilityMiddleware({
11
- model: {
12
- constructor: {
13
- name: "ChatAnthropic"
14
- }
15
- }
16
- });
17
- const input = {
18
- messages: [
19
- {
20
- content: [
21
- {
22
- type: "text",
23
- text: "Hello"
24
- },
25
- {
26
- type: "audio",
27
- source_type: "base64",
28
- data: "abc"
29
- }
30
- ]
31
- }
32
- ]
33
- };
34
- const result = await runBeforeAgent(middleware, input);
35
- const content = result.messages[0]?.content;
36
- expect(Array.isArray(content)).toBe(true);
37
- expect(content).toHaveLength(1);
38
- expect(content[0]?.type).toBe("text");
39
- });
40
- it("replaces content with a placeholder when only audio blocks remain", async ()=>{
41
- const middleware = mediaCompatibilityMiddleware({
42
- model: {
43
- constructor: {
44
- name: "ChatAnthropic"
45
- }
46
- }
47
- });
48
- const input = {
49
- messages: [
50
- {
51
- content: [
52
- {
53
- type: "audio_url",
54
- audio_url: {
55
- url: "https://x/y"
56
- }
57
- }
58
- ]
59
- }
60
- ]
61
- };
62
- const result = await runBeforeAgent(middleware, input);
63
- const content = result.messages[0]?.content;
64
- expect(typeof content).toBe("string");
65
- expect(content).toContain("Audio omitted");
66
- });
67
- it("leaves audio blocks untouched for non-Anthropic models", async ()=>{
68
- const middleware = mediaCompatibilityMiddleware({
69
- model: {
70
- constructor: {
71
- name: "ChatOpenAI"
72
- }
73
- }
74
- });
75
- const input = {
76
- messages: [
77
- {
78
- content: [
79
- {
80
- type: "text",
81
- text: "Hello"
82
- },
83
- {
84
- type: "input_audio",
85
- input_audio: {
86
- data: "abc",
87
- format: "wav"
88
- }
89
- }
90
- ]
91
- }
92
- ]
93
- };
94
- const result = await runBeforeAgent(middleware, input);
95
- const content = result.messages[0]?.content;
96
- expect(Array.isArray(content)).toBe(true);
97
- expect(content).toHaveLength(2);
98
- expect(content[1]?.type).toBe("input_audio");
99
- });
100
- });
@@ -1,77 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_vitest_namespaceObject = require("vitest");
4
- const toolRegistry_cjs_namespaceObject = require("../agent/config/toolRegistry.cjs");
5
- const node_invoke_cjs_namespaceObject = require("../agent/tools/node_invoke.cjs");
6
- (0, external_vitest_namespaceObject.describe)("node tools", ()=>{
7
- (0, external_vitest_namespaceObject.it)("exposes node tools in available tool names", ()=>{
8
- const tools = (0, toolRegistry_cjs_namespaceObject.getAvailableTools)();
9
- (0, external_vitest_namespaceObject.expect)(tools).toContain("node_notify");
10
- (0, external_vitest_namespaceObject.expect)(tools).toContain("node_run");
11
- });
12
- (0, external_vitest_namespaceObject.it)("routes node_notify through the injected node invoker", async ()=>{
13
- const nodeInvoker = external_vitest_namespaceObject.vi.fn(async ()=>({
14
- nodeId: "node-123",
15
- payload: {
16
- delivered: true
17
- }
18
- }));
19
- const tool = (0, node_invoke_cjs_namespaceObject.createNodeNotifyTool)({
20
- nodeInvoker,
21
- defaultTargetClientId: "desktop-abc"
22
- });
23
- const result = await tool.invoke({
24
- body: "Build finished"
25
- });
26
- (0, external_vitest_namespaceObject.expect)(result.ok).toBe(true);
27
- (0, external_vitest_namespaceObject.expect)(result.nodeId).toBe("node-123");
28
- (0, external_vitest_namespaceObject.expect)(result.delivered).toBe(true);
29
- (0, external_vitest_namespaceObject.expect)(nodeInvoker).toHaveBeenCalledWith(external_vitest_namespaceObject.expect.objectContaining({
30
- tool: "system.notify",
31
- targetClientId: "desktop-abc"
32
- }));
33
- });
34
- (0, external_vitest_namespaceObject.it)("returns command result fields from node_run", async ()=>{
35
- const nodeInvoker = external_vitest_namespaceObject.vi.fn(async ()=>({
36
- nodeId: "node-789",
37
- payload: {
38
- exitCode: 0,
39
- stdout: "ok",
40
- stderr: ""
41
- }
42
- }));
43
- const tool = (0, node_invoke_cjs_namespaceObject.createNodeRunTool)({
44
- nodeInvoker
45
- });
46
- const result = await tool.invoke({
47
- command: "/bin/echo",
48
- args: [
49
- "hello"
50
- ],
51
- target: {
52
- nodeId: "node-789"
53
- }
54
- });
55
- (0, external_vitest_namespaceObject.expect)(result.ok).toBe(true);
56
- (0, external_vitest_namespaceObject.expect)(result.nodeId).toBe("node-789");
57
- (0, external_vitest_namespaceObject.expect)(result.exitCode).toBe(0);
58
- (0, external_vitest_namespaceObject.expect)(result.stdout).toBe("ok");
59
- (0, external_vitest_namespaceObject.expect)(result.stderr).toBe("");
60
- (0, external_vitest_namespaceObject.expect)(nodeInvoker).toHaveBeenCalledWith(external_vitest_namespaceObject.expect.objectContaining({
61
- tool: "system.run",
62
- targetNodeId: "node-789"
63
- }));
64
- });
65
- (0, external_vitest_namespaceObject.it)("returns an availability error outside gateway runtime", async ()=>{
66
- const tool = (0, node_invoke_cjs_namespaceObject.createNodeRunTool)();
67
- const result = await tool.invoke({
68
- command: "pwd"
69
- });
70
- (0, external_vitest_namespaceObject.expect)(result.ok).toBe(false);
71
- (0, external_vitest_namespaceObject.expect)(result.error).toContain("only available");
72
- });
73
- });
74
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
75
- Object.defineProperty(exports, '__esModule', {
76
- value: true
77
- });
@@ -1 +0,0 @@
1
- export {};