@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 +0,0 @@
1
- export {};
@@ -1,377 +0,0 @@
1
- import { existsSync, mkdirSync, mkdtempSync, readFileSync, rmSync, writeFileSync } from "node:fs";
2
- import { tmpdir } from "node:os";
3
- import { dirname, join } from "node:path";
4
- import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
5
- import { createCodexFetch, getCodexAuthPath, resolveCodexAuthFromFile } from "../providers/codex.js";
6
- describe("codex provider", ()=>{
7
- let codexHome;
8
- const originalCodexHome = process.env.CODEX_HOME;
9
- beforeEach(()=>{
10
- codexHome = mkdtempSync(join(tmpdir(), "wingman-codex-"));
11
- process.env.CODEX_HOME = codexHome;
12
- delete process.env.CODEX_ACCESS_TOKEN;
13
- delete process.env.CHATGPT_ACCESS_TOKEN;
14
- });
15
- afterEach(()=>{
16
- if (void 0 === originalCodexHome) delete process.env.CODEX_HOME;
17
- else process.env.CODEX_HOME = originalCodexHome;
18
- if (existsSync(codexHome)) rmSync(codexHome, {
19
- recursive: true,
20
- force: true
21
- });
22
- });
23
- it("reads access token and account id from codex auth file", ()=>{
24
- writeCodexAuth({
25
- tokens: {
26
- access_token: "codex-access-token",
27
- account_id: "acct_123"
28
- }
29
- });
30
- const resolved = resolveCodexAuthFromFile();
31
- expect(resolved.accessToken).toBe("codex-access-token");
32
- expect(resolved.accountId).toBe("acct_123");
33
- expect(resolved.authPath).toBe(join(codexHome, "auth.json"));
34
- });
35
- it("applies codex auth headers and forces store=false", async ()=>{
36
- writeCodexAuth({
37
- tokens: {
38
- access_token: "file-token",
39
- account_id: "acct_file"
40
- }
41
- });
42
- const baseFetch = vi.fn(async (_input, _init)=>new Response("{}", {
43
- status: 200
44
- }));
45
- const codexFetch = createCodexFetch({
46
- baseFetch
47
- });
48
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
49
- method: "POST",
50
- headers: {
51
- "x-api-key": "placeholder"
52
- },
53
- body: JSON.stringify({
54
- model: "codex-mini-latest",
55
- input: "hello",
56
- temperature: 1
57
- })
58
- });
59
- expect(baseFetch).toHaveBeenCalledTimes(1);
60
- const requestInit = baseFetch.mock.calls[0]?.[1];
61
- expect(requestInit).toBeDefined();
62
- const headers = new Headers(requestInit?.headers);
63
- const payload = JSON.parse(String(requestInit?.body));
64
- expect(headers.get("authorization")).toBe("Bearer file-token");
65
- expect(headers.get("chatgpt-account-id")).toBe("acct_file");
66
- expect(headers.get("x-api-key")).toBeNull();
67
- expect(payload.store).toBe(false);
68
- expect(payload.temperature).toBeUndefined();
69
- expect(typeof payload.instructions).toBe("string");
70
- expect(payload.instructions.length).toBeGreaterThan(0);
71
- });
72
- it("derives instructions from system/developer input when missing", async ()=>{
73
- writeCodexAuth({
74
- tokens: {
75
- access_token: "file-token"
76
- }
77
- });
78
- const baseFetch = vi.fn(async (_input, _init)=>new Response("{}", {
79
- status: 200
80
- }));
81
- const codexFetch = createCodexFetch({
82
- baseFetch
83
- });
84
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
85
- method: "POST",
86
- body: JSON.stringify({
87
- model: "gpt-5.3-codex",
88
- input: [
89
- {
90
- role: "developer",
91
- content: [
92
- {
93
- type: "input_text",
94
- text: "Always run tests first."
95
- }
96
- ]
97
- },
98
- {
99
- role: "user",
100
- content: [
101
- {
102
- type: "input_text",
103
- text: "Fix the bug."
104
- }
105
- ]
106
- }
107
- ]
108
- })
109
- });
110
- const requestInit = baseFetch.mock.calls[0]?.[1];
111
- const payload = JSON.parse(String(requestInit?.body));
112
- expect(payload.instructions).toBe("Always run tests first.");
113
- });
114
- it("preserves explicit instructions when provided", async ()=>{
115
- writeCodexAuth({
116
- tokens: {
117
- access_token: "file-token"
118
- }
119
- });
120
- const baseFetch = vi.fn(async (_input, _init)=>new Response("{}", {
121
- status: 200
122
- }));
123
- const codexFetch = createCodexFetch({
124
- baseFetch
125
- });
126
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
127
- method: "POST",
128
- body: JSON.stringify({
129
- model: "gpt-5.3-codex",
130
- instructions: "Use concise answers.",
131
- input: "hello"
132
- })
133
- });
134
- const requestInit = baseFetch.mock.calls[0]?.[1];
135
- const payload = JSON.parse(String(requestInit?.body));
136
- expect(payload.instructions).toBe("Use concise answers.");
137
- });
138
- it("overrides explicit store values to false when provided", async ()=>{
139
- writeCodexAuth({
140
- tokens: {
141
- access_token: "file-token"
142
- }
143
- });
144
- const baseFetch = vi.fn(async (_input, _init)=>new Response("{}", {
145
- status: 200
146
- }));
147
- const codexFetch = createCodexFetch({
148
- baseFetch
149
- });
150
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
151
- method: "POST",
152
- body: JSON.stringify({
153
- model: "gpt-5.3-codex",
154
- store: true,
155
- input: "hello"
156
- })
157
- });
158
- const requestInit = baseFetch.mock.calls[0]?.[1];
159
- const payload = JSON.parse(String(requestInit?.body));
160
- expect(payload.store).toBe(false);
161
- });
162
- it("refreshes tokens when the codex access token is expiring", async ()=>{
163
- const expiringAccessToken = createJwt({
164
- exp: Math.floor((Date.now() + 30000) / 1000),
165
- client_id: "app_client_123"
166
- });
167
- const refreshedAccessToken = createJwt({
168
- exp: Math.floor((Date.now() + 86400000) / 1000),
169
- client_id: "app_client_123"
170
- });
171
- const staleIdToken = createJwt({
172
- aud: [
173
- "app_client_123"
174
- ],
175
- "https://api.openai.com/auth": {
176
- chatgpt_account_id: "acct_old"
177
- }
178
- });
179
- const refreshedIdToken = createJwt({
180
- aud: [
181
- "app_client_123"
182
- ],
183
- "https://api.openai.com/auth": {
184
- chatgpt_account_id: "acct_refreshed"
185
- }
186
- });
187
- writeCodexAuth({
188
- tokens: {
189
- access_token: expiringAccessToken,
190
- refresh_token: "refresh-old",
191
- id_token: staleIdToken,
192
- account_id: "acct_old"
193
- }
194
- });
195
- const baseFetch = vi.fn(async (input, init)=>{
196
- const url = "string" == typeof input ? input : input instanceof URL ? input.toString() : input.url;
197
- if ("https://auth.openai.com/oauth/token" === url) {
198
- const params = new URLSearchParams(String(init?.body ?? ""));
199
- expect(params.get("grant_type")).toBe("refresh_token");
200
- expect(params.get("refresh_token")).toBe("refresh-old");
201
- expect(params.get("client_id")).toBe("app_client_123");
202
- return new Response(JSON.stringify({
203
- access_token: refreshedAccessToken,
204
- refresh_token: "refresh-new",
205
- id_token: refreshedIdToken,
206
- token_type: "bearer",
207
- expires_in: 864000
208
- }), {
209
- status: 200,
210
- headers: {
211
- "content-type": "application/json"
212
- }
213
- });
214
- }
215
- expect(url).toBe("https://chatgpt.com/backend-api/codex/responses");
216
- const headers = new Headers(init?.headers);
217
- expect(headers.get("authorization")).toBe(`Bearer ${refreshedAccessToken}`);
218
- expect(headers.get("chatgpt-account-id")).toBe("acct_refreshed");
219
- return new Response("{}", {
220
- status: 200
221
- });
222
- });
223
- const codexFetch = createCodexFetch({
224
- baseFetch
225
- });
226
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
227
- method: "POST",
228
- body: JSON.stringify({
229
- model: "codex-mini-latest",
230
- input: "hello"
231
- })
232
- });
233
- expect(baseFetch).toHaveBeenCalledTimes(2);
234
- const persisted = JSON.parse(readFileSync(getCodexAuthPath(), "utf-8"));
235
- expect(persisted.tokens?.access_token).toBe(refreshedAccessToken);
236
- expect(persisted.tokens?.refresh_token).toBe("refresh-new");
237
- expect(persisted.tokens?.id_token).toBe(refreshedIdToken);
238
- expect(persisted.tokens?.account_id).toBe("acct_refreshed");
239
- expect(typeof persisted.last_refresh).toBe("string");
240
- });
241
- it("retries once after auth failure by refreshing codex token", async ()=>{
242
- const initialAccessToken = createJwt({
243
- exp: Math.floor((Date.now() + 86400000) / 1000),
244
- client_id: "app_client_retry"
245
- });
246
- const refreshedAccessToken = createJwt({
247
- exp: Math.floor((Date.now() + 172800000) / 1000),
248
- client_id: "app_client_retry"
249
- });
250
- const idToken = createJwt({
251
- aud: [
252
- "app_client_retry"
253
- ],
254
- "https://api.openai.com/auth": {
255
- chatgpt_account_id: "acct_retry"
256
- }
257
- });
258
- const refreshedIdToken = createJwt({
259
- aud: [
260
- "app_client_retry"
261
- ],
262
- "https://api.openai.com/auth": {
263
- chatgpt_account_id: "acct_retry_new"
264
- }
265
- });
266
- writeCodexAuth({
267
- tokens: {
268
- access_token: initialAccessToken,
269
- refresh_token: "refresh-retry",
270
- id_token: idToken,
271
- account_id: "acct_retry"
272
- }
273
- });
274
- let codexCallCount = 0;
275
- const baseFetch = vi.fn(async (input, init)=>{
276
- const url = "string" == typeof input ? input : input instanceof URL ? input.toString() : input.url;
277
- if ("https://auth.openai.com/oauth/token" === url) {
278
- const params = new URLSearchParams(String(init?.body ?? ""));
279
- expect(params.get("grant_type")).toBe("refresh_token");
280
- expect(params.get("refresh_token")).toBe("refresh-retry");
281
- expect(params.get("client_id")).toBe("app_client_retry");
282
- return new Response(JSON.stringify({
283
- access_token: refreshedAccessToken,
284
- refresh_token: "refresh-retry-new",
285
- id_token: refreshedIdToken,
286
- token_type: "bearer",
287
- expires_in: 864000
288
- }), {
289
- status: 200,
290
- headers: {
291
- "content-type": "application/json"
292
- }
293
- });
294
- }
295
- codexCallCount += 1;
296
- const headers = new Headers(init?.headers);
297
- if (1 === codexCallCount) {
298
- expect(headers.get("authorization")).toBe(`Bearer ${initialAccessToken}`);
299
- return new Response("unauthorized", {
300
- status: 401
301
- });
302
- }
303
- expect(codexCallCount).toBe(2);
304
- expect(headers.get("authorization")).toBe(`Bearer ${refreshedAccessToken}`);
305
- expect(headers.get("chatgpt-account-id")).toBe("acct_retry_new");
306
- return new Response("{}", {
307
- status: 200
308
- });
309
- });
310
- const codexFetch = createCodexFetch({
311
- baseFetch
312
- });
313
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
314
- method: "POST",
315
- body: JSON.stringify({
316
- model: "codex-mini-latest",
317
- input: "hello"
318
- })
319
- });
320
- expect(codexCallCount).toBe(2);
321
- expect(baseFetch).toHaveBeenCalledTimes(3);
322
- const persisted = JSON.parse(readFileSync(getCodexAuthPath(), "utf-8"));
323
- expect(persisted.tokens?.access_token).toBe(refreshedAccessToken);
324
- expect(persisted.tokens?.refresh_token).toBe("refresh-retry-new");
325
- expect(persisted.tokens?.account_id).toBe("acct_retry_new");
326
- });
327
- it("uses fallback token when codex auth file is unavailable", async ()=>{
328
- const baseFetch = vi.fn(async (_input, _init)=>new Response("{}", {
329
- status: 200
330
- }));
331
- const codexFetch = createCodexFetch({
332
- baseFetch,
333
- fallbackToken: "fallback-token"
334
- });
335
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
336
- method: "POST",
337
- body: JSON.stringify({
338
- model: "codex-mini-latest",
339
- input: "hello"
340
- })
341
- });
342
- const requestInit = baseFetch.mock.calls[0]?.[1];
343
- expect(requestInit).toBeDefined();
344
- const headers = new Headers(requestInit?.headers);
345
- expect(headers.get("authorization")).toBe("Bearer fallback-token");
346
- });
347
- it("throws when no codex token is available", async ()=>{
348
- const baseFetch = vi.fn(async (_input, _init)=>new Response("{}", {
349
- status: 200
350
- }));
351
- const codexFetch = createCodexFetch({
352
- baseFetch
353
- });
354
- await expect(codexFetch("https://chatgpt.com/backend-api/codex/responses", {
355
- method: "POST",
356
- body: JSON.stringify({
357
- model: "codex-mini-latest",
358
- input: "hello"
359
- })
360
- })).rejects.toThrow(/Codex credentials missing/);
361
- });
362
- });
363
- function writeCodexAuth(payload) {
364
- const authPath = getCodexAuthPath();
365
- mkdirSync(dirname(authPath), {
366
- recursive: true
367
- });
368
- writeFileSync(authPath, JSON.stringify(payload, null, 2));
369
- }
370
- function createJwt(payload) {
371
- const header = Buffer.from(JSON.stringify({
372
- alg: "HS256",
373
- typ: "JWT"
374
- })).toString("base64url");
375
- const body = Buffer.from(JSON.stringify(payload)).toString("base64url");
376
- return `${header}.${body}.signature`;
377
- }
@@ -1,37 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_vitest_namespaceObject = require("vitest");
4
- const jsonSchema_cjs_namespaceObject = require("../cli/config/jsonSchema.cjs");
5
- (0, external_vitest_namespaceObject.describe)("wingman config json schema", ()=>{
6
- (0, external_vitest_namespaceObject.it)("includes metadata and top-level sections", ()=>{
7
- const schema = (0, jsonSchema_cjs_namespaceObject.buildWingmanConfigJsonSchema)();
8
- (0, external_vitest_namespaceObject.expect)(schema.$schema).toBe("https://json-schema.org/draft/2020-12/schema");
9
- (0, external_vitest_namespaceObject.expect)(schema.$id).toBe(jsonSchema_cjs_namespaceObject.WINGMAN_CONFIG_JSON_SCHEMA_ID);
10
- (0, external_vitest_namespaceObject.expect)(schema.title).toBe("Wingman Config");
11
- (0, external_vitest_namespaceObject.expect)(schema.type).toBe("object");
12
- (0, external_vitest_namespaceObject.expect)(schema.properties).toBeDefined();
13
- (0, external_vitest_namespaceObject.expect)(schema.properties.gateway).toBeDefined();
14
- (0, external_vitest_namespaceObject.expect)(schema.properties.skills).toBeDefined();
15
- });
16
- (0, external_vitest_namespaceObject.it)("exposes resilient default scanner args", ()=>{
17
- const schema = (0, jsonSchema_cjs_namespaceObject.buildWingmanConfigJsonSchema)();
18
- const scannerArgsDefault = schema.properties.skills.properties.security.properties.scannerArgs.default;
19
- (0, external_vitest_namespaceObject.expect)(scannerArgsDefault).toContain("mcp-scan>=0.4,<0.5");
20
- });
21
- (0, external_vitest_namespaceObject.it)("exposes hybrid defaults for skill sources", ()=>{
22
- const schema = (0, jsonSchema_cjs_namespaceObject.buildWingmanConfigJsonSchema)();
23
- const repositoriesDefault = schema.properties.skills.properties.repositories.default;
24
- const providerDefault = schema.properties.skills.properties.provider.default;
25
- (0, external_vitest_namespaceObject.expect)(providerDefault).toBe("hybrid");
26
- (0, external_vitest_namespaceObject.expect)(repositoriesDefault).toEqual([
27
- {
28
- owner: "RussellCanfield",
29
- name: "wingman-ai"
30
- }
31
- ]);
32
- });
33
- });
34
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
35
- Object.defineProperty(exports, '__esModule', {
36
- value: true
37
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,31 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { WINGMAN_CONFIG_JSON_SCHEMA_ID, buildWingmanConfigJsonSchema } from "../cli/config/jsonSchema.js";
3
- describe("wingman config json schema", ()=>{
4
- it("includes metadata and top-level sections", ()=>{
5
- const schema = buildWingmanConfigJsonSchema();
6
- expect(schema.$schema).toBe("https://json-schema.org/draft/2020-12/schema");
7
- expect(schema.$id).toBe(WINGMAN_CONFIG_JSON_SCHEMA_ID);
8
- expect(schema.title).toBe("Wingman Config");
9
- expect(schema.type).toBe("object");
10
- expect(schema.properties).toBeDefined();
11
- expect(schema.properties.gateway).toBeDefined();
12
- expect(schema.properties.skills).toBeDefined();
13
- });
14
- it("exposes resilient default scanner args", ()=>{
15
- const schema = buildWingmanConfigJsonSchema();
16
- const scannerArgsDefault = schema.properties.skills.properties.security.properties.scannerArgs.default;
17
- expect(scannerArgsDefault).toContain("mcp-scan>=0.4,<0.5");
18
- });
19
- it("exposes hybrid defaults for skill sources", ()=>{
20
- const schema = buildWingmanConfigJsonSchema();
21
- const repositoriesDefault = schema.properties.skills.properties.repositories.default;
22
- const providerDefault = schema.properties.skills.properties.provider.default;
23
- expect(providerDefault).toBe("hybrid");
24
- expect(repositoriesDefault).toEqual([
25
- {
26
- owner: "RussellCanfield",
27
- name: "wingman-ai"
28
- }
29
- ]);
30
- });
31
- });
@@ -1,89 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_vitest_namespaceObject = require("vitest");
4
- const discord_cjs_namespaceObject = require("../gateway/adapters/discord.cjs");
5
- (0, external_vitest_namespaceObject.describe)("discord adapter helpers", ()=>{
6
- (0, external_vitest_namespaceObject.it)("extracts session override when command matches", ()=>{
7
- const result = (0, discord_cjs_namespaceObject.extractSessionOverride)("!session agent:main:cli hello", "!session");
8
- (0, external_vitest_namespaceObject.expect)(result.matched).toBe(true);
9
- (0, external_vitest_namespaceObject.expect)(result.sessionKey).toBe("agent:main:cli");
10
- (0, external_vitest_namespaceObject.expect)(result.content).toBe("hello");
11
- });
12
- (0, external_vitest_namespaceObject.it)("returns no match when command does not match", ()=>{
13
- const result = (0, discord_cjs_namespaceObject.extractSessionOverride)("hello there", "!session");
14
- (0, external_vitest_namespaceObject.expect)(result.matched).toBe(false);
15
- (0, external_vitest_namespaceObject.expect)(result.sessionKey).toBeUndefined();
16
- (0, external_vitest_namespaceObject.expect)(result.content).toBe("hello there");
17
- });
18
- (0, external_vitest_namespaceObject.it)("handles session command without key", ()=>{
19
- const result = (0, discord_cjs_namespaceObject.extractSessionOverride)("!session", "!session");
20
- (0, external_vitest_namespaceObject.expect)(result.matched).toBe(true);
21
- (0, external_vitest_namespaceObject.expect)(result.sessionKey).toBeUndefined();
22
- (0, external_vitest_namespaceObject.expect)(result.content).toBe("");
23
- });
24
- (0, external_vitest_namespaceObject.it)("resolves channel session mapping with thread fallback", ()=>{
25
- const map = {
26
- 123: "session-a",
27
- "parent-1": "session-parent"
28
- };
29
- (0, external_vitest_namespaceObject.expect)((0, discord_cjs_namespaceObject.resolveDiscordChannelSessionKey)("123", map)).toBe("session-a");
30
- (0, external_vitest_namespaceObject.expect)((0, discord_cjs_namespaceObject.resolveDiscordChannelSessionKey)("missing", map, "parent-1")).toBe("session-parent");
31
- (0, external_vitest_namespaceObject.expect)((0, discord_cjs_namespaceObject.resolveDiscordChannelSessionKey)("missing", map)).toBeUndefined();
32
- });
33
- (0, external_vitest_namespaceObject.it)("parses agent id from session key", ()=>{
34
- (0, external_vitest_namespaceObject.expect)((0, discord_cjs_namespaceObject.parseAgentIdFromSessionKey)("agent:main:webui:thread:abc")).toBe("main");
35
- (0, external_vitest_namespaceObject.expect)((0, discord_cjs_namespaceObject.parseAgentIdFromSessionKey)("agent:stock-trader:discord:channel:1")).toBe("stock-trader");
36
- (0, external_vitest_namespaceObject.expect)((0, discord_cjs_namespaceObject.parseAgentIdFromSessionKey)("session-plain")).toBeUndefined();
37
- (0, external_vitest_namespaceObject.expect)((0, discord_cjs_namespaceObject.parseAgentIdFromSessionKey)(void 0)).toBeUndefined();
38
- });
39
- (0, external_vitest_namespaceObject.it)("strips bot mention variants", ()=>{
40
- const content = "<@123> hello <@!123>";
41
- (0, external_vitest_namespaceObject.expect)((0, discord_cjs_namespaceObject.stripDiscordBotMention)(content, "123")).toBe("hello");
42
- });
43
- (0, external_vitest_namespaceObject.it)("splits long responses into chunks", ()=>{
44
- const input = "a".repeat(4500);
45
- const chunks = (0, discord_cjs_namespaceObject.splitDiscordMessage)(input, 1900);
46
- (0, external_vitest_namespaceObject.expect)(chunks.length).toBeGreaterThan(1);
47
- for (const chunk of chunks)(0, external_vitest_namespaceObject.expect)(chunk.length).toBeLessThanOrEqual(1900);
48
- const rebuilt = chunks.join("");
49
- (0, external_vitest_namespaceObject.expect)(rebuilt).toBe(input);
50
- });
51
- (0, external_vitest_namespaceObject.it)("extracts uiOnly and textFallback from plain object", ()=>{
52
- const meta = (0, discord_cjs_namespaceObject.extractUiMeta)({
53
- uiOnly: true,
54
- textFallback: "Hello"
55
- });
56
- (0, external_vitest_namespaceObject.expect)(meta).toEqual({
57
- uiOnly: true,
58
- textFallback: "Hello"
59
- });
60
- });
61
- (0, external_vitest_namespaceObject.it)("extracts uiOnly and textFallback from stringified payload", ()=>{
62
- const meta = (0, discord_cjs_namespaceObject.extractUiMeta)(JSON.stringify({
63
- uiOnly: true,
64
- textFallback: "Fallback"
65
- }));
66
- (0, external_vitest_namespaceObject.expect)(meta).toEqual({
67
- uiOnly: true,
68
- textFallback: "Fallback"
69
- });
70
- });
71
- (0, external_vitest_namespaceObject.it)("extracts uiOnly and textFallback from kwargs.content", ()=>{
72
- const meta = (0, discord_cjs_namespaceObject.extractUiMeta)({
73
- kwargs: {
74
- content: JSON.stringify({
75
- uiOnly: true,
76
- textFallback: "OK"
77
- })
78
- }
79
- });
80
- (0, external_vitest_namespaceObject.expect)(meta).toEqual({
81
- uiOnly: true,
82
- textFallback: "OK"
83
- });
84
- });
85
- });
86
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
87
- Object.defineProperty(exports, '__esModule', {
88
- value: true
89
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,83 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { extractSessionOverride, extractUiMeta, parseAgentIdFromSessionKey, resolveDiscordChannelSessionKey, splitDiscordMessage, stripDiscordBotMention } from "../gateway/adapters/discord.js";
3
- describe("discord adapter helpers", ()=>{
4
- it("extracts session override when command matches", ()=>{
5
- const result = extractSessionOverride("!session agent:main:cli hello", "!session");
6
- expect(result.matched).toBe(true);
7
- expect(result.sessionKey).toBe("agent:main:cli");
8
- expect(result.content).toBe("hello");
9
- });
10
- it("returns no match when command does not match", ()=>{
11
- const result = extractSessionOverride("hello there", "!session");
12
- expect(result.matched).toBe(false);
13
- expect(result.sessionKey).toBeUndefined();
14
- expect(result.content).toBe("hello there");
15
- });
16
- it("handles session command without key", ()=>{
17
- const result = extractSessionOverride("!session", "!session");
18
- expect(result.matched).toBe(true);
19
- expect(result.sessionKey).toBeUndefined();
20
- expect(result.content).toBe("");
21
- });
22
- it("resolves channel session mapping with thread fallback", ()=>{
23
- const map = {
24
- 123: "session-a",
25
- "parent-1": "session-parent"
26
- };
27
- expect(resolveDiscordChannelSessionKey("123", map)).toBe("session-a");
28
- expect(resolveDiscordChannelSessionKey("missing", map, "parent-1")).toBe("session-parent");
29
- expect(resolveDiscordChannelSessionKey("missing", map)).toBeUndefined();
30
- });
31
- it("parses agent id from session key", ()=>{
32
- expect(parseAgentIdFromSessionKey("agent:main:webui:thread:abc")).toBe("main");
33
- expect(parseAgentIdFromSessionKey("agent:stock-trader:discord:channel:1")).toBe("stock-trader");
34
- expect(parseAgentIdFromSessionKey("session-plain")).toBeUndefined();
35
- expect(parseAgentIdFromSessionKey(void 0)).toBeUndefined();
36
- });
37
- it("strips bot mention variants", ()=>{
38
- const content = "<@123> hello <@!123>";
39
- expect(stripDiscordBotMention(content, "123")).toBe("hello");
40
- });
41
- it("splits long responses into chunks", ()=>{
42
- const input = "a".repeat(4500);
43
- const chunks = splitDiscordMessage(input, 1900);
44
- expect(chunks.length).toBeGreaterThan(1);
45
- for (const chunk of chunks)expect(chunk.length).toBeLessThanOrEqual(1900);
46
- const rebuilt = chunks.join("");
47
- expect(rebuilt).toBe(input);
48
- });
49
- it("extracts uiOnly and textFallback from plain object", ()=>{
50
- const meta = extractUiMeta({
51
- uiOnly: true,
52
- textFallback: "Hello"
53
- });
54
- expect(meta).toEqual({
55
- uiOnly: true,
56
- textFallback: "Hello"
57
- });
58
- });
59
- it("extracts uiOnly and textFallback from stringified payload", ()=>{
60
- const meta = extractUiMeta(JSON.stringify({
61
- uiOnly: true,
62
- textFallback: "Fallback"
63
- }));
64
- expect(meta).toEqual({
65
- uiOnly: true,
66
- textFallback: "Fallback"
67
- });
68
- });
69
- it("extracts uiOnly and textFallback from kwargs.content", ()=>{
70
- const meta = extractUiMeta({
71
- kwargs: {
72
- content: JSON.stringify({
73
- uiOnly: true,
74
- textFallback: "OK"
75
- })
76
- }
77
- });
78
- expect(meta).toEqual({
79
- uiOnly: true,
80
- textFallback: "OK"
81
- });
82
- });
83
- });