@wingman-ai/gateway 0.5.3 → 0.6.0

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 (327) hide show
  1. package/dist/agent/backend/filtered-backend.cjs +130 -0
  2. package/dist/agent/backend/filtered-backend.d.ts +10 -0
  3. package/dist/agent/backend/filtered-backend.js +87 -0
  4. package/dist/agent/config/agentConfig.cjs +4 -0
  5. package/dist/agent/config/agentConfig.d.ts +12 -0
  6. package/dist/agent/config/agentConfig.js +4 -0
  7. package/dist/agent/config/toolRegistry.cjs +75 -1
  8. package/dist/agent/config/toolRegistry.d.ts +3 -0
  9. package/dist/agent/config/toolRegistry.js +75 -1
  10. package/dist/agent/middleware/additional-messages.cjs +4 -1
  11. package/dist/agent/middleware/additional-messages.js +4 -1
  12. package/dist/agent/middleware/large-tool-results.cjs +207 -0
  13. package/dist/agent/middleware/large-tool-results.d.ts +16 -0
  14. package/dist/agent/middleware/large-tool-results.js +173 -0
  15. package/dist/agent/tools/browser_control.cjs +9 -1231
  16. package/dist/agent/tools/browser_control.d.ts +126 -234
  17. package/dist/agent/tools/browser_control.js +7 -1226
  18. package/dist/agent/tools/browser_runtime.cjs +1358 -0
  19. package/dist/agent/tools/browser_runtime.d.ts +617 -0
  20. package/dist/agent/tools/browser_runtime.js +1288 -0
  21. package/dist/agent/tools/browser_session.cjs +189 -0
  22. package/dist/agent/tools/browser_session.d.ts +686 -0
  23. package/dist/agent/tools/browser_session.js +146 -0
  24. package/dist/agent/tools/browser_session_manager.cjs +213 -0
  25. package/dist/agent/tools/browser_session_manager.d.ts +70 -0
  26. package/dist/agent/tools/browser_session_manager.js +176 -0
  27. package/dist/cli/commands/init.cjs +80 -98
  28. package/dist/cli/commands/init.js +80 -98
  29. package/dist/cli/config/loader.cjs +0 -5
  30. package/dist/cli/config/loader.js +0 -5
  31. package/dist/cli/config/schema.cjs +3 -7
  32. package/dist/cli/config/schema.d.ts +6 -6
  33. package/dist/cli/config/schema.js +3 -7
  34. package/dist/cli/core/agentInvoker.cjs +88 -22
  35. package/dist/cli/core/agentInvoker.d.ts +10 -3
  36. package/dist/cli/core/agentInvoker.js +88 -25
  37. package/dist/cli/core/outputManager.cjs +7 -2
  38. package/dist/cli/core/outputManager.d.ts +2 -2
  39. package/dist/cli/core/outputManager.js +7 -2
  40. package/dist/cli/core/sessionManager.cjs +208 -41
  41. package/dist/cli/core/sessionManager.d.ts +20 -0
  42. package/dist/cli/core/sessionManager.js +208 -41
  43. package/dist/cli/index.cjs +16 -1
  44. package/dist/cli/index.js +16 -1
  45. package/dist/cli/services/updateCheck.cjs +212 -0
  46. package/dist/cli/services/updateCheck.d.ts +26 -0
  47. package/dist/cli/services/updateCheck.js +166 -0
  48. package/dist/cli/types.d.ts +2 -1
  49. package/dist/gateway/server.cjs +7 -0
  50. package/dist/gateway/server.js +7 -0
  51. package/dist/webui/assets/index-D3x3G75t.css +11 -0
  52. package/dist/webui/assets/index-UpMmcU1f.js +215 -0
  53. package/dist/webui/index.html +2 -2
  54. package/package.json +12 -12
  55. package/templates/agents/README.md +3 -1
  56. package/templates/agents/coding/agent.md +6 -13
  57. package/templates/agents/coding-v2/agent.md +6 -1
  58. package/templates/agents/game-dev/agent.md +9 -2
  59. package/templates/agents/game-dev/game-designer.md +4 -0
  60. package/templates/agents/game-dev/scene-engineer.md +4 -0
  61. package/templates/agents/main/agent.md +7 -2
  62. package/templates/agents/researcher/agent.md +14 -3
  63. package/templates/agents/stock-trader/agent.md +4 -0
  64. package/dist/agent/tests/agentConfig.test.cjs +0 -224
  65. package/dist/agent/tests/agentConfig.test.d.ts +0 -1
  66. package/dist/agent/tests/agentConfig.test.js +0 -218
  67. package/dist/agent/tests/agentLoader.test.cjs +0 -335
  68. package/dist/agent/tests/agentLoader.test.d.ts +0 -1
  69. package/dist/agent/tests/agentLoader.test.js +0 -329
  70. package/dist/agent/tests/backgroundTerminal.test.cjs +0 -70
  71. package/dist/agent/tests/backgroundTerminal.test.d.ts +0 -1
  72. package/dist/agent/tests/backgroundTerminal.test.js +0 -64
  73. package/dist/agent/tests/browserControlHelpers.test.cjs +0 -35
  74. package/dist/agent/tests/browserControlHelpers.test.d.ts +0 -1
  75. package/dist/agent/tests/browserControlHelpers.test.js +0 -29
  76. package/dist/agent/tests/browserControlTool.test.cjs +0 -2117
  77. package/dist/agent/tests/browserControlTool.test.d.ts +0 -1
  78. package/dist/agent/tests/browserControlTool.test.js +0 -2111
  79. package/dist/agent/tests/commandExecuteTool.test.cjs +0 -29
  80. package/dist/agent/tests/commandExecuteTool.test.d.ts +0 -1
  81. package/dist/agent/tests/commandExecuteTool.test.js +0 -23
  82. package/dist/agent/tests/internet_search.test.cjs +0 -107
  83. package/dist/agent/tests/internet_search.test.d.ts +0 -1
  84. package/dist/agent/tests/internet_search.test.js +0 -101
  85. package/dist/agent/tests/mcpClientManager.test.cjs +0 -290
  86. package/dist/agent/tests/mcpClientManager.test.d.ts +0 -1
  87. package/dist/agent/tests/mcpClientManager.test.js +0 -284
  88. package/dist/agent/tests/mcpResourceTools.test.cjs +0 -101
  89. package/dist/agent/tests/mcpResourceTools.test.d.ts +0 -1
  90. package/dist/agent/tests/mcpResourceTools.test.js +0 -95
  91. package/dist/agent/tests/modelFactory.test.cjs +0 -190
  92. package/dist/agent/tests/modelFactory.test.d.ts +0 -1
  93. package/dist/agent/tests/modelFactory.test.js +0 -184
  94. package/dist/agent/tests/terminalSessionManager.test.cjs +0 -121
  95. package/dist/agent/tests/terminalSessionManager.test.d.ts +0 -1
  96. package/dist/agent/tests/terminalSessionManager.test.js +0 -115
  97. package/dist/agent/tests/test-agent-loader.cjs +0 -33
  98. package/dist/agent/tests/test-agent-loader.d.ts +0 -1
  99. package/dist/agent/tests/test-agent-loader.js +0 -27
  100. package/dist/agent/tests/test-subagent-loading.cjs +0 -99
  101. package/dist/agent/tests/test-subagent-loading.d.ts +0 -1
  102. package/dist/agent/tests/test-subagent-loading.js +0 -93
  103. package/dist/agent/tests/toolRegistry.test.cjs +0 -147
  104. package/dist/agent/tests/toolRegistry.test.d.ts +0 -1
  105. package/dist/agent/tests/toolRegistry.test.js +0 -141
  106. package/dist/agent/tests/uiRegistryTools.test.cjs +0 -114
  107. package/dist/agent/tests/uiRegistryTools.test.d.ts +0 -1
  108. package/dist/agent/tests/uiRegistryTools.test.js +0 -105
  109. package/dist/agent/tests/xaiImageModel.test.cjs +0 -194
  110. package/dist/agent/tests/xaiImageModel.test.d.ts +0 -1
  111. package/dist/agent/tests/xaiImageModel.test.js +0 -188
  112. package/dist/tests/additionalMessageMiddleware.test.cjs +0 -216
  113. package/dist/tests/additionalMessageMiddleware.test.d.ts +0 -1
  114. package/dist/tests/additionalMessageMiddleware.test.js +0 -188
  115. package/dist/tests/agent-config-voice.test.cjs +0 -25
  116. package/dist/tests/agent-config-voice.test.d.ts +0 -1
  117. package/dist/tests/agent-config-voice.test.js +0 -19
  118. package/dist/tests/agentInvokerAttachments.test.cjs +0 -190
  119. package/dist/tests/agentInvokerAttachments.test.d.ts +0 -1
  120. package/dist/tests/agentInvokerAttachments.test.js +0 -184
  121. package/dist/tests/agentInvokerSummarization.test.cjs +0 -613
  122. package/dist/tests/agentInvokerSummarization.test.d.ts +0 -1
  123. package/dist/tests/agentInvokerSummarization.test.js +0 -607
  124. package/dist/tests/agentInvokerTokenUsage.test.cjs +0 -124
  125. package/dist/tests/agentInvokerTokenUsage.test.d.ts +0 -1
  126. package/dist/tests/agentInvokerTokenUsage.test.js +0 -118
  127. package/dist/tests/agentInvokerWorkdir.test.cjs +0 -150
  128. package/dist/tests/agentInvokerWorkdir.test.d.ts +0 -1
  129. package/dist/tests/agentInvokerWorkdir.test.js +0 -122
  130. package/dist/tests/agents-api.test.cjs +0 -324
  131. package/dist/tests/agents-api.test.d.ts +0 -1
  132. package/dist/tests/agents-api.test.js +0 -318
  133. package/dist/tests/attachments-utils.test.cjs +0 -46
  134. package/dist/tests/attachments-utils.test.d.ts +0 -1
  135. package/dist/tests/attachments-utils.test.js +0 -40
  136. package/dist/tests/browser-command.test.cjs +0 -264
  137. package/dist/tests/browser-command.test.d.ts +0 -1
  138. package/dist/tests/browser-command.test.js +0 -258
  139. package/dist/tests/browser-relay-server.test.cjs +0 -20
  140. package/dist/tests/browser-relay-server.test.d.ts +0 -1
  141. package/dist/tests/browser-relay-server.test.js +0 -14
  142. package/dist/tests/bunSqliteAdapter.test.cjs +0 -265
  143. package/dist/tests/bunSqliteAdapter.test.d.ts +0 -1
  144. package/dist/tests/bunSqliteAdapter.test.js +0 -259
  145. package/dist/tests/candleRange.test.cjs +0 -48
  146. package/dist/tests/candleRange.test.d.ts +0 -1
  147. package/dist/tests/candleRange.test.js +0 -42
  148. package/dist/tests/cli-config-loader.test.cjs +0 -532
  149. package/dist/tests/cli-config-loader.test.d.ts +0 -1
  150. package/dist/tests/cli-config-loader.test.js +0 -526
  151. package/dist/tests/cli-config-warnings.test.cjs +0 -94
  152. package/dist/tests/cli-config-warnings.test.d.ts +0 -1
  153. package/dist/tests/cli-config-warnings.test.js +0 -88
  154. package/dist/tests/cli-init.test.cjs +0 -225
  155. package/dist/tests/cli-init.test.d.ts +0 -1
  156. package/dist/tests/cli-init.test.js +0 -219
  157. package/dist/tests/cli-workspace-root.test.cjs +0 -114
  158. package/dist/tests/cli-workspace-root.test.d.ts +0 -1
  159. package/dist/tests/cli-workspace-root.test.js +0 -108
  160. package/dist/tests/codex-credentials-precedence.test.cjs +0 -94
  161. package/dist/tests/codex-credentials-precedence.test.d.ts +0 -1
  162. package/dist/tests/codex-credentials-precedence.test.js +0 -88
  163. package/dist/tests/codex-provider.test.cjs +0 -383
  164. package/dist/tests/codex-provider.test.d.ts +0 -1
  165. package/dist/tests/codex-provider.test.js +0 -377
  166. package/dist/tests/config-json-schema.test.cjs +0 -37
  167. package/dist/tests/config-json-schema.test.d.ts +0 -1
  168. package/dist/tests/config-json-schema.test.js +0 -31
  169. package/dist/tests/discord-adapter.test.cjs +0 -89
  170. package/dist/tests/discord-adapter.test.d.ts +0 -1
  171. package/dist/tests/discord-adapter.test.js +0 -83
  172. package/dist/tests/falRuntime.test.cjs +0 -78
  173. package/dist/tests/falRuntime.test.d.ts +0 -1
  174. package/dist/tests/falRuntime.test.js +0 -72
  175. package/dist/tests/falSummary.test.cjs +0 -51
  176. package/dist/tests/falSummary.test.d.ts +0 -1
  177. package/dist/tests/falSummary.test.js +0 -45
  178. package/dist/tests/fs-api.test.cjs +0 -138
  179. package/dist/tests/fs-api.test.d.ts +0 -1
  180. package/dist/tests/fs-api.test.js +0 -132
  181. package/dist/tests/gateway-command-workspace.test.cjs +0 -150
  182. package/dist/tests/gateway-command-workspace.test.d.ts +0 -1
  183. package/dist/tests/gateway-command-workspace.test.js +0 -144
  184. package/dist/tests/gateway-http-security.test.cjs +0 -318
  185. package/dist/tests/gateway-http-security.test.d.ts +0 -1
  186. package/dist/tests/gateway-http-security.test.js +0 -312
  187. package/dist/tests/gateway-node-mode.test.cjs +0 -174
  188. package/dist/tests/gateway-node-mode.test.d.ts +0 -1
  189. package/dist/tests/gateway-node-mode.test.js +0 -168
  190. package/dist/tests/gateway-origin-policy.test.cjs +0 -82
  191. package/dist/tests/gateway-origin-policy.test.d.ts +0 -1
  192. package/dist/tests/gateway-origin-policy.test.js +0 -76
  193. package/dist/tests/gateway-request-execution-overrides.test.cjs +0 -42
  194. package/dist/tests/gateway-request-execution-overrides.test.d.ts +0 -1
  195. package/dist/tests/gateway-request-execution-overrides.test.js +0 -36
  196. package/dist/tests/gateway.test.cjs +0 -700
  197. package/dist/tests/gateway.test.d.ts +0 -1
  198. package/dist/tests/gateway.test.js +0 -694
  199. package/dist/tests/hooks-matcher.test.cjs +0 -309
  200. package/dist/tests/hooks-matcher.test.d.ts +0 -1
  201. package/dist/tests/hooks-matcher.test.js +0 -303
  202. package/dist/tests/hooks-merger.test.cjs +0 -528
  203. package/dist/tests/hooks-merger.test.d.ts +0 -1
  204. package/dist/tests/hooks-merger.test.js +0 -522
  205. package/dist/tests/imagePersistence.test.cjs +0 -169
  206. package/dist/tests/imagePersistence.test.d.ts +0 -1
  207. package/dist/tests/imagePersistence.test.js +0 -163
  208. package/dist/tests/integration/agent-invocation.integration.test.cjs +0 -264
  209. package/dist/tests/integration/agent-invocation.integration.test.d.ts +0 -1
  210. package/dist/tests/integration/agent-invocation.integration.test.js +0 -258
  211. package/dist/tests/integration/finnhub-candles.integration.test.cjs +0 -98
  212. package/dist/tests/integration/finnhub-candles.integration.test.d.ts +0 -1
  213. package/dist/tests/integration/finnhub-candles.integration.test.js +0 -92
  214. package/dist/tests/integration/summarization-e2e.integration.test.cjs +0 -127
  215. package/dist/tests/integration/summarization-e2e.integration.test.d.ts +0 -1
  216. package/dist/tests/integration/summarization-e2e.integration.test.js +0 -121
  217. package/dist/tests/logger.test.cjs +0 -353
  218. package/dist/tests/logger.test.d.ts +0 -1
  219. package/dist/tests/logger.test.js +0 -347
  220. package/dist/tests/mediaCompatibilityMiddleware.test.cjs +0 -106
  221. package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +0 -1
  222. package/dist/tests/mediaCompatibilityMiddleware.test.js +0 -100
  223. package/dist/tests/node-tools.test.cjs +0 -77
  224. package/dist/tests/node-tools.test.d.ts +0 -1
  225. package/dist/tests/node-tools.test.js +0 -71
  226. package/dist/tests/nodes-api.test.cjs +0 -86
  227. package/dist/tests/nodes-api.test.d.ts +0 -1
  228. package/dist/tests/nodes-api.test.js +0 -80
  229. package/dist/tests/outputManagerContextSummarized.test.cjs +0 -43
  230. package/dist/tests/outputManagerContextSummarized.test.d.ts +0 -1
  231. package/dist/tests/outputManagerContextSummarized.test.js +0 -37
  232. package/dist/tests/provider-command-codex.test.cjs +0 -57
  233. package/dist/tests/provider-command-codex.test.d.ts +0 -1
  234. package/dist/tests/provider-command-codex.test.js +0 -51
  235. package/dist/tests/routines-api.test.cjs +0 -107
  236. package/dist/tests/routines-api.test.d.ts +0 -1
  237. package/dist/tests/routines-api.test.js +0 -101
  238. package/dist/tests/run-terminal-bench-official-script.test.cjs +0 -61
  239. package/dist/tests/run-terminal-bench-official-script.test.d.ts +0 -1
  240. package/dist/tests/run-terminal-bench-official-script.test.js +0 -55
  241. package/dist/tests/sessionManager-uionly.test.cjs +0 -50
  242. package/dist/tests/sessionManager-uionly.test.d.ts +0 -1
  243. package/dist/tests/sessionManager-uionly.test.js +0 -44
  244. package/dist/tests/sessionMessageAttachments.test.cjs +0 -197
  245. package/dist/tests/sessionMessageAttachments.test.d.ts +0 -1
  246. package/dist/tests/sessionMessageAttachments.test.js +0 -191
  247. package/dist/tests/sessionMessageRole.test.cjs +0 -44
  248. package/dist/tests/sessionMessageRole.test.d.ts +0 -1
  249. package/dist/tests/sessionMessageRole.test.js +0 -38
  250. package/dist/tests/sessionStateMessages.test.cjs +0 -236
  251. package/dist/tests/sessionStateMessages.test.d.ts +0 -1
  252. package/dist/tests/sessionStateMessages.test.js +0 -230
  253. package/dist/tests/sessions-api.test.cjs +0 -250
  254. package/dist/tests/sessions-api.test.d.ts +0 -1
  255. package/dist/tests/sessions-api.test.js +0 -244
  256. package/dist/tests/skill-activation.test.cjs +0 -86
  257. package/dist/tests/skill-activation.test.d.ts +0 -1
  258. package/dist/tests/skill-activation.test.js +0 -80
  259. package/dist/tests/skill-metadata.test.cjs +0 -119
  260. package/dist/tests/skill-metadata.test.d.ts +0 -1
  261. package/dist/tests/skill-metadata.test.js +0 -113
  262. package/dist/tests/skill-repository.test.cjs +0 -469
  263. package/dist/tests/skill-repository.test.d.ts +0 -1
  264. package/dist/tests/skill-repository.test.js +0 -463
  265. package/dist/tests/skill-security-scanner.test.cjs +0 -126
  266. package/dist/tests/skill-security-scanner.test.d.ts +0 -1
  267. package/dist/tests/skill-security-scanner.test.js +0 -120
  268. package/dist/tests/sms-api.test.cjs +0 -183
  269. package/dist/tests/sms-api.test.d.ts +0 -1
  270. package/dist/tests/sms-api.test.js +0 -177
  271. package/dist/tests/sms-commands.test.cjs +0 -90
  272. package/dist/tests/sms-commands.test.d.ts +0 -1
  273. package/dist/tests/sms-commands.test.js +0 -84
  274. package/dist/tests/sms-policy-store.test.cjs +0 -69
  275. package/dist/tests/sms-policy-store.test.d.ts +0 -1
  276. package/dist/tests/sms-policy-store.test.js +0 -63
  277. package/dist/tests/teams-adapter.test.cjs +0 -58
  278. package/dist/tests/teams-adapter.test.d.ts +0 -1
  279. package/dist/tests/teams-adapter.test.js +0 -52
  280. package/dist/tests/technicalIndicators.test.cjs +0 -82
  281. package/dist/tests/technicalIndicators.test.d.ts +0 -1
  282. package/dist/tests/technicalIndicators.test.js +0 -76
  283. package/dist/tests/terminal-bench-adapters-helpers.test.cjs +0 -64
  284. package/dist/tests/terminal-bench-adapters-helpers.test.d.ts +0 -1
  285. package/dist/tests/terminal-bench-adapters-helpers.test.js +0 -58
  286. package/dist/tests/terminal-bench-cleanup.test.cjs +0 -93
  287. package/dist/tests/terminal-bench-cleanup.test.d.ts +0 -1
  288. package/dist/tests/terminal-bench-cleanup.test.js +0 -87
  289. package/dist/tests/terminal-bench-config.test.cjs +0 -62
  290. package/dist/tests/terminal-bench-config.test.d.ts +0 -1
  291. package/dist/tests/terminal-bench-config.test.js +0 -56
  292. package/dist/tests/terminal-bench-official.test.cjs +0 -194
  293. package/dist/tests/terminal-bench-official.test.d.ts +0 -1
  294. package/dist/tests/terminal-bench-official.test.js +0 -188
  295. package/dist/tests/terminal-bench-runner.test.cjs +0 -82
  296. package/dist/tests/terminal-bench-runner.test.d.ts +0 -1
  297. package/dist/tests/terminal-bench-runner.test.js +0 -76
  298. package/dist/tests/terminal-bench-scoring.test.cjs +0 -128
  299. package/dist/tests/terminal-bench-scoring.test.d.ts +0 -1
  300. package/dist/tests/terminal-bench-scoring.test.js +0 -122
  301. package/dist/tests/terminalProbe.test.cjs +0 -45
  302. package/dist/tests/terminalProbe.test.d.ts +0 -1
  303. package/dist/tests/terminalProbe.test.js +0 -39
  304. package/dist/tests/terminalProbeAuth.test.cjs +0 -85
  305. package/dist/tests/terminalProbeAuth.test.d.ts +0 -1
  306. package/dist/tests/terminalProbeAuth.test.js +0 -79
  307. package/dist/tests/toolDisplayHelpers.test.cjs +0 -46
  308. package/dist/tests/toolDisplayHelpers.test.d.ts +0 -1
  309. package/dist/tests/toolDisplayHelpers.test.js +0 -40
  310. package/dist/tests/uv.test.cjs +0 -47
  311. package/dist/tests/uv.test.d.ts +0 -1
  312. package/dist/tests/uv.test.js +0 -41
  313. package/dist/tests/voice-config.test.cjs +0 -35
  314. package/dist/tests/voice-config.test.d.ts +0 -1
  315. package/dist/tests/voice-config.test.js +0 -29
  316. package/dist/tests/websocket-transport.test.cjs +0 -31
  317. package/dist/tests/websocket-transport.test.d.ts +0 -1
  318. package/dist/tests/websocket-transport.test.js +0 -25
  319. package/dist/tests/yahooCandles.test.cjs +0 -111
  320. package/dist/tests/yahooCandles.test.d.ts +0 -1
  321. package/dist/tests/yahooCandles.test.js +0 -105
  322. package/dist/tools/finance/optionsAnalytics.test.cjs +0 -128
  323. package/dist/tools/finance/optionsAnalytics.test.d.ts +0 -1
  324. package/dist/tools/finance/optionsAnalytics.test.js +0 -122
  325. package/dist/webui/assets/index-BMf95nv5.js +0 -215
  326. package/dist/webui/assets/index-DhJQ8Mbn.css +0 -11
  327. package/dist/webui/assets/wingman_logo-Cogyt3qm.webp +0 -0
@@ -1,265 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_vitest_namespaceObject = require("vitest");
4
- const promises_namespaceObject = require("node:fs/promises");
5
- const isBun = void 0 !== globalThis.Bun;
6
- const describeIfBun = isBun ? external_vitest_namespaceObject.describe : external_vitest_namespaceObject.describe.skip;
7
- describeIfBun("BunSqliteAdapter", ()=>{
8
- const testDbPath = "./test-adapter.db";
9
- let BunSqliteAdapter;
10
- let Database;
11
- let adapter;
12
- (0, external_vitest_namespaceObject.beforeAll)(async ()=>{
13
- const module = await import("../cli/core/database/bunSqliteAdapter.cjs");
14
- BunSqliteAdapter = module.BunSqliteAdapter;
15
- const sqliteModule = await import("bun:sqlite");
16
- Database = sqliteModule.Database;
17
- });
18
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
19
- adapter = new BunSqliteAdapter(testDbPath);
20
- });
21
- (0, external_vitest_namespaceObject.afterEach)(async ()=>{
22
- try {
23
- adapter.close();
24
- await (0, promises_namespaceObject.unlink)(testDbPath);
25
- } catch {}
26
- });
27
- (0, external_vitest_namespaceObject.describe)("constructor", ()=>{
28
- (0, external_vitest_namespaceObject.it)("should create adapter from file path", ()=>{
29
- (0, external_vitest_namespaceObject.expect)(adapter).toBeDefined();
30
- });
31
- (0, external_vitest_namespaceObject.it)("should create adapter from existing Database instance", ()=>{
32
- const db = new Database(":memory:");
33
- const memAdapter = new BunSqliteAdapter(db);
34
- (0, external_vitest_namespaceObject.expect)(memAdapter).toBeDefined();
35
- memAdapter.close();
36
- });
37
- });
38
- (0, external_vitest_namespaceObject.describe)("exec and run", ()=>{
39
- (0, external_vitest_namespaceObject.it)("should execute SQL statements to create tables via exec", ()=>{
40
- const result = adapter.exec(`
41
- CREATE TABLE users (
42
- id INTEGER PRIMARY KEY,
43
- name TEXT NOT NULL
44
- );
45
- `);
46
- (0, external_vitest_namespaceObject.expect)(result).toBeDefined();
47
- });
48
- (0, external_vitest_namespaceObject.it)("should execute SQL statements to create tables via run", ()=>{
49
- const result = adapter.run(`
50
- CREATE TABLE posts (
51
- id INTEGER PRIMARY KEY,
52
- content TEXT NOT NULL
53
- );
54
- `);
55
- (0, external_vitest_namespaceObject.expect)(result).toBeDefined();
56
- });
57
- (0, external_vitest_namespaceObject.it)("should create multiple tables in one exec call", ()=>{
58
- adapter.exec(`
59
- CREATE TABLE accounts (id INTEGER PRIMARY KEY, name TEXT);
60
- CREATE TABLE transactions (id INTEGER PRIMARY KEY, account_id INTEGER);
61
- `);
62
- const stmt = adapter.prepare("INSERT INTO accounts (name) VALUES (?)");
63
- const result = stmt.run("Alice");
64
- (0, external_vitest_namespaceObject.expect)(result).toBeDefined();
65
- });
66
- });
67
- (0, external_vitest_namespaceObject.describe)("prepare and run", ()=>{
68
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
69
- adapter.exec(`
70
- CREATE TABLE users (
71
- id INTEGER PRIMARY KEY AUTOINCREMENT,
72
- name TEXT NOT NULL,
73
- email TEXT
74
- );
75
- `);
76
- });
77
- (0, external_vitest_namespaceObject.it)("should prepare and execute INSERT statement", ()=>{
78
- const stmt = adapter.prepare("INSERT INTO users (name, email) VALUES (?, ?)");
79
- const result = stmt.run("John Doe", "john@example.com");
80
- (0, external_vitest_namespaceObject.expect)(result).toBeDefined();
81
- (0, external_vitest_namespaceObject.expect)(result.changes).toBe(1);
82
- });
83
- (0, external_vitest_namespaceObject.it)("should prepare and execute UPDATE statement", ()=>{
84
- const insertStmt = adapter.prepare("INSERT INTO users (name) VALUES (?)");
85
- insertStmt.run("Jane");
86
- const updateStmt = adapter.prepare("UPDATE users SET name = ? WHERE name = ?");
87
- const result = updateStmt.run("Jane Doe", "Jane");
88
- (0, external_vitest_namespaceObject.expect)(result.changes).toBe(1);
89
- });
90
- (0, external_vitest_namespaceObject.it)("should prepare and execute DELETE statement", ()=>{
91
- const insertStmt = adapter.prepare("INSERT INTO users (name) VALUES (?)");
92
- insertStmt.run("User1");
93
- insertStmt.run("User2");
94
- const deleteStmt = adapter.prepare("DELETE FROM users WHERE name = ?");
95
- const result = deleteStmt.run("User1");
96
- (0, external_vitest_namespaceObject.expect)(result.changes).toBe(1);
97
- });
98
- });
99
- (0, external_vitest_namespaceObject.describe)("prepare and get", ()=>{
100
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
101
- adapter.exec(`
102
- CREATE TABLE users (
103
- id INTEGER PRIMARY KEY AUTOINCREMENT,
104
- name TEXT NOT NULL,
105
- age INTEGER
106
- );
107
- `);
108
- const stmt = adapter.prepare("INSERT INTO users (name, age) VALUES (?, ?)");
109
- stmt.run("Alice", 30);
110
- stmt.run("Bob", 25);
111
- });
112
- (0, external_vitest_namespaceObject.it)("should get a single row", ()=>{
113
- const stmt = adapter.prepare("SELECT * FROM users WHERE name = ?");
114
- const row = stmt.get("Alice");
115
- (0, external_vitest_namespaceObject.expect)(row).toBeDefined();
116
- (0, external_vitest_namespaceObject.expect)(row.name).toBe("Alice");
117
- (0, external_vitest_namespaceObject.expect)(row.age).toBe(30);
118
- });
119
- (0, external_vitest_namespaceObject.it)("should return undefined for non-existent row", ()=>{
120
- const stmt = adapter.prepare("SELECT * FROM users WHERE name = ?");
121
- const row = stmt.get("NonExistent");
122
- (0, external_vitest_namespaceObject.expect)(row).toBeUndefined();
123
- });
124
- });
125
- (0, external_vitest_namespaceObject.describe)("prepare and all", ()=>{
126
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
127
- adapter.exec(`
128
- CREATE TABLE users (
129
- id INTEGER PRIMARY KEY AUTOINCREMENT,
130
- name TEXT NOT NULL,
131
- active INTEGER DEFAULT 1
132
- );
133
- `);
134
- const stmt = adapter.prepare("INSERT INTO users (name, active) VALUES (?, ?)");
135
- stmt.run("Alice", 1);
136
- stmt.run("Bob", 1);
137
- stmt.run("Charlie", 0);
138
- });
139
- (0, external_vitest_namespaceObject.it)("should get all matching rows", ()=>{
140
- const stmt = adapter.prepare("SELECT * FROM users WHERE active = ?");
141
- const rows = stmt.all(1);
142
- (0, external_vitest_namespaceObject.expect)(rows).toHaveLength(2);
143
- (0, external_vitest_namespaceObject.expect)(rows[0].name).toBe("Alice");
144
- (0, external_vitest_namespaceObject.expect)(rows[1].name).toBe("Bob");
145
- });
146
- (0, external_vitest_namespaceObject.it)("should return empty array when no matches", ()=>{
147
- const stmt = adapter.prepare("SELECT * FROM users WHERE name = ?");
148
- const rows = stmt.all("Nobody");
149
- (0, external_vitest_namespaceObject.expect)(rows).toHaveLength(0);
150
- });
151
- (0, external_vitest_namespaceObject.it)("should get all rows without parameters", ()=>{
152
- const stmt = adapter.prepare("SELECT * FROM users");
153
- const rows = stmt.all();
154
- (0, external_vitest_namespaceObject.expect)(rows).toHaveLength(3);
155
- });
156
- });
157
- (0, external_vitest_namespaceObject.describe)("transaction", ()=>{
158
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
159
- adapter.exec(`
160
- CREATE TABLE accounts (
161
- id INTEGER PRIMARY KEY AUTOINCREMENT,
162
- name TEXT NOT NULL,
163
- balance INTEGER DEFAULT 0
164
- );
165
- `);
166
- });
167
- (0, external_vitest_namespaceObject.it)("should execute transaction successfully", ()=>{
168
- const insertMany = adapter.transaction((names)=>{
169
- const stmt = adapter.prepare("INSERT INTO accounts (name, balance) VALUES (?, ?)");
170
- for (const name of names)stmt.run(name, 100);
171
- });
172
- insertMany([
173
- "Alice",
174
- "Bob",
175
- "Charlie"
176
- ]);
177
- const stmt = adapter.prepare("SELECT COUNT(*) as count FROM accounts");
178
- const result = stmt.get();
179
- (0, external_vitest_namespaceObject.expect)(result.count).toBe(3);
180
- });
181
- (0, external_vitest_namespaceObject.it)("should rollback transaction on error", ()=>{
182
- const failedTransaction = adapter.transaction(()=>{
183
- const stmt = adapter.prepare("INSERT INTO accounts (name, balance) VALUES (?, ?)");
184
- stmt.run("Alice", 100);
185
- throw new Error("Transaction failed");
186
- });
187
- (0, external_vitest_namespaceObject.expect)(()=>failedTransaction()).toThrow("Transaction failed");
188
- const stmt = adapter.prepare("SELECT COUNT(*) as count FROM accounts");
189
- const result = stmt.get();
190
- (0, external_vitest_namespaceObject.expect)(result.count).toBe(0);
191
- });
192
- });
193
- (0, external_vitest_namespaceObject.describe)("pragma", ()=>{
194
- (0, external_vitest_namespaceObject.it)("should execute pragma statements", ()=>{
195
- const result = adapter.pragma("journal_mode", true);
196
- (0, external_vitest_namespaceObject.expect)(result).toBeDefined();
197
- });
198
- (0, external_vitest_namespaceObject.it)("should return pragma result without simplify", ()=>{
199
- const result = adapter.pragma("journal_mode", false);
200
- (0, external_vitest_namespaceObject.expect)(result).toBeDefined();
201
- (0, external_vitest_namespaceObject.expect)(typeof result).toBe("object");
202
- });
203
- });
204
- (0, external_vitest_namespaceObject.describe)("close", ()=>{
205
- (0, external_vitest_namespaceObject.it)("should close database connection", ()=>{
206
- const tempDb = new BunSqliteAdapter(":memory:");
207
- (0, external_vitest_namespaceObject.expect)(()=>tempDb.close()).not.toThrow();
208
- });
209
- });
210
- (0, external_vitest_namespaceObject.describe)("inTransaction", ()=>{
211
- (0, external_vitest_namespaceObject.it)("should return false by default", ()=>{
212
- (0, external_vitest_namespaceObject.expect)(adapter.inTransaction).toBe(false);
213
- });
214
- });
215
- (0, external_vitest_namespaceObject.describe)("SqliteSaver compatibility", ()=>{
216
- (0, external_vitest_namespaceObject.it)("should be compatible with LangGraph checkpoint operations", ()=>{
217
- adapter.exec(`
218
- CREATE TABLE checkpoints (
219
- thread_id TEXT NOT NULL,
220
- checkpoint_ns TEXT NOT NULL DEFAULT '',
221
- checkpoint_id TEXT NOT NULL,
222
- parent_checkpoint_id TEXT,
223
- type TEXT,
224
- checkpoint BLOB NOT NULL,
225
- metadata BLOB NOT NULL,
226
- PRIMARY KEY (thread_id, checkpoint_ns, checkpoint_id)
227
- );
228
-
229
- CREATE TABLE checkpoint_writes (
230
- thread_id TEXT NOT NULL,
231
- checkpoint_ns TEXT NOT NULL DEFAULT '',
232
- checkpoint_id TEXT NOT NULL,
233
- task_id TEXT NOT NULL,
234
- idx INTEGER NOT NULL,
235
- channel TEXT NOT NULL,
236
- type TEXT,
237
- value BLOB,
238
- PRIMARY KEY (thread_id, checkpoint_ns, checkpoint_id, task_id, idx)
239
- );
240
- `);
241
- const insertStmt = adapter.prepare(`
242
- INSERT INTO checkpoints (thread_id, checkpoint_id, checkpoint, metadata)
243
- VALUES (?, ?, ?, ?)
244
- `);
245
- const result = insertStmt.run("thread-1", "checkpoint-1", JSON.stringify({
246
- data: "test"
247
- }), JSON.stringify({
248
- version: 1
249
- }));
250
- (0, external_vitest_namespaceObject.expect)(result.changes).toBe(1);
251
- const selectStmt = adapter.prepare("SELECT * FROM checkpoints WHERE thread_id = ?");
252
- const row = selectStmt.get("thread-1");
253
- (0, external_vitest_namespaceObject.expect)(row).toBeDefined();
254
- (0, external_vitest_namespaceObject.expect)(row.thread_id).toBe("thread-1");
255
- (0, external_vitest_namespaceObject.expect)(row.checkpoint_id).toBe("checkpoint-1");
256
- const deleteStmt = adapter.prepare("DELETE FROM checkpoints WHERE thread_id = ?");
257
- const deleteResult = deleteStmt.run("thread-1");
258
- (0, external_vitest_namespaceObject.expect)(deleteResult.changes).toBe(1);
259
- });
260
- });
261
- });
262
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
263
- Object.defineProperty(exports, '__esModule', {
264
- value: true
265
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,259 +0,0 @@
1
- import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest";
2
- import { unlink } from "node:fs/promises";
3
- const isBun = void 0 !== globalThis.Bun;
4
- const describeIfBun = isBun ? describe : describe.skip;
5
- describeIfBun("BunSqliteAdapter", ()=>{
6
- const testDbPath = "./test-adapter.db";
7
- let BunSqliteAdapter;
8
- let Database;
9
- let adapter;
10
- beforeAll(async ()=>{
11
- const module = await import("../cli/core/database/bunSqliteAdapter.js");
12
- BunSqliteAdapter = module.BunSqliteAdapter;
13
- const sqliteModule = await import("bun:sqlite");
14
- Database = sqliteModule.Database;
15
- });
16
- beforeEach(()=>{
17
- adapter = new BunSqliteAdapter(testDbPath);
18
- });
19
- afterEach(async ()=>{
20
- try {
21
- adapter.close();
22
- await unlink(testDbPath);
23
- } catch {}
24
- });
25
- describe("constructor", ()=>{
26
- it("should create adapter from file path", ()=>{
27
- expect(adapter).toBeDefined();
28
- });
29
- it("should create adapter from existing Database instance", ()=>{
30
- const db = new Database(":memory:");
31
- const memAdapter = new BunSqliteAdapter(db);
32
- expect(memAdapter).toBeDefined();
33
- memAdapter.close();
34
- });
35
- });
36
- describe("exec and run", ()=>{
37
- it("should execute SQL statements to create tables via exec", ()=>{
38
- const result = adapter.exec(`
39
- CREATE TABLE users (
40
- id INTEGER PRIMARY KEY,
41
- name TEXT NOT NULL
42
- );
43
- `);
44
- expect(result).toBeDefined();
45
- });
46
- it("should execute SQL statements to create tables via run", ()=>{
47
- const result = adapter.run(`
48
- CREATE TABLE posts (
49
- id INTEGER PRIMARY KEY,
50
- content TEXT NOT NULL
51
- );
52
- `);
53
- expect(result).toBeDefined();
54
- });
55
- it("should create multiple tables in one exec call", ()=>{
56
- adapter.exec(`
57
- CREATE TABLE accounts (id INTEGER PRIMARY KEY, name TEXT);
58
- CREATE TABLE transactions (id INTEGER PRIMARY KEY, account_id INTEGER);
59
- `);
60
- const stmt = adapter.prepare("INSERT INTO accounts (name) VALUES (?)");
61
- const result = stmt.run("Alice");
62
- expect(result).toBeDefined();
63
- });
64
- });
65
- describe("prepare and run", ()=>{
66
- beforeEach(()=>{
67
- adapter.exec(`
68
- CREATE TABLE users (
69
- id INTEGER PRIMARY KEY AUTOINCREMENT,
70
- name TEXT NOT NULL,
71
- email TEXT
72
- );
73
- `);
74
- });
75
- it("should prepare and execute INSERT statement", ()=>{
76
- const stmt = adapter.prepare("INSERT INTO users (name, email) VALUES (?, ?)");
77
- const result = stmt.run("John Doe", "john@example.com");
78
- expect(result).toBeDefined();
79
- expect(result.changes).toBe(1);
80
- });
81
- it("should prepare and execute UPDATE statement", ()=>{
82
- const insertStmt = adapter.prepare("INSERT INTO users (name) VALUES (?)");
83
- insertStmt.run("Jane");
84
- const updateStmt = adapter.prepare("UPDATE users SET name = ? WHERE name = ?");
85
- const result = updateStmt.run("Jane Doe", "Jane");
86
- expect(result.changes).toBe(1);
87
- });
88
- it("should prepare and execute DELETE statement", ()=>{
89
- const insertStmt = adapter.prepare("INSERT INTO users (name) VALUES (?)");
90
- insertStmt.run("User1");
91
- insertStmt.run("User2");
92
- const deleteStmt = adapter.prepare("DELETE FROM users WHERE name = ?");
93
- const result = deleteStmt.run("User1");
94
- expect(result.changes).toBe(1);
95
- });
96
- });
97
- describe("prepare and get", ()=>{
98
- beforeEach(()=>{
99
- adapter.exec(`
100
- CREATE TABLE users (
101
- id INTEGER PRIMARY KEY AUTOINCREMENT,
102
- name TEXT NOT NULL,
103
- age INTEGER
104
- );
105
- `);
106
- const stmt = adapter.prepare("INSERT INTO users (name, age) VALUES (?, ?)");
107
- stmt.run("Alice", 30);
108
- stmt.run("Bob", 25);
109
- });
110
- it("should get a single row", ()=>{
111
- const stmt = adapter.prepare("SELECT * FROM users WHERE name = ?");
112
- const row = stmt.get("Alice");
113
- expect(row).toBeDefined();
114
- expect(row.name).toBe("Alice");
115
- expect(row.age).toBe(30);
116
- });
117
- it("should return undefined for non-existent row", ()=>{
118
- const stmt = adapter.prepare("SELECT * FROM users WHERE name = ?");
119
- const row = stmt.get("NonExistent");
120
- expect(row).toBeUndefined();
121
- });
122
- });
123
- describe("prepare and all", ()=>{
124
- beforeEach(()=>{
125
- adapter.exec(`
126
- CREATE TABLE users (
127
- id INTEGER PRIMARY KEY AUTOINCREMENT,
128
- name TEXT NOT NULL,
129
- active INTEGER DEFAULT 1
130
- );
131
- `);
132
- const stmt = adapter.prepare("INSERT INTO users (name, active) VALUES (?, ?)");
133
- stmt.run("Alice", 1);
134
- stmt.run("Bob", 1);
135
- stmt.run("Charlie", 0);
136
- });
137
- it("should get all matching rows", ()=>{
138
- const stmt = adapter.prepare("SELECT * FROM users WHERE active = ?");
139
- const rows = stmt.all(1);
140
- expect(rows).toHaveLength(2);
141
- expect(rows[0].name).toBe("Alice");
142
- expect(rows[1].name).toBe("Bob");
143
- });
144
- it("should return empty array when no matches", ()=>{
145
- const stmt = adapter.prepare("SELECT * FROM users WHERE name = ?");
146
- const rows = stmt.all("Nobody");
147
- expect(rows).toHaveLength(0);
148
- });
149
- it("should get all rows without parameters", ()=>{
150
- const stmt = adapter.prepare("SELECT * FROM users");
151
- const rows = stmt.all();
152
- expect(rows).toHaveLength(3);
153
- });
154
- });
155
- describe("transaction", ()=>{
156
- beforeEach(()=>{
157
- adapter.exec(`
158
- CREATE TABLE accounts (
159
- id INTEGER PRIMARY KEY AUTOINCREMENT,
160
- name TEXT NOT NULL,
161
- balance INTEGER DEFAULT 0
162
- );
163
- `);
164
- });
165
- it("should execute transaction successfully", ()=>{
166
- const insertMany = adapter.transaction((names)=>{
167
- const stmt = adapter.prepare("INSERT INTO accounts (name, balance) VALUES (?, ?)");
168
- for (const name of names)stmt.run(name, 100);
169
- });
170
- insertMany([
171
- "Alice",
172
- "Bob",
173
- "Charlie"
174
- ]);
175
- const stmt = adapter.prepare("SELECT COUNT(*) as count FROM accounts");
176
- const result = stmt.get();
177
- expect(result.count).toBe(3);
178
- });
179
- it("should rollback transaction on error", ()=>{
180
- const failedTransaction = adapter.transaction(()=>{
181
- const stmt = adapter.prepare("INSERT INTO accounts (name, balance) VALUES (?, ?)");
182
- stmt.run("Alice", 100);
183
- throw new Error("Transaction failed");
184
- });
185
- expect(()=>failedTransaction()).toThrow("Transaction failed");
186
- const stmt = adapter.prepare("SELECT COUNT(*) as count FROM accounts");
187
- const result = stmt.get();
188
- expect(result.count).toBe(0);
189
- });
190
- });
191
- describe("pragma", ()=>{
192
- it("should execute pragma statements", ()=>{
193
- const result = adapter.pragma("journal_mode", true);
194
- expect(result).toBeDefined();
195
- });
196
- it("should return pragma result without simplify", ()=>{
197
- const result = adapter.pragma("journal_mode", false);
198
- expect(result).toBeDefined();
199
- expect(typeof result).toBe("object");
200
- });
201
- });
202
- describe("close", ()=>{
203
- it("should close database connection", ()=>{
204
- const tempDb = new BunSqliteAdapter(":memory:");
205
- expect(()=>tempDb.close()).not.toThrow();
206
- });
207
- });
208
- describe("inTransaction", ()=>{
209
- it("should return false by default", ()=>{
210
- expect(adapter.inTransaction).toBe(false);
211
- });
212
- });
213
- describe("SqliteSaver compatibility", ()=>{
214
- it("should be compatible with LangGraph checkpoint operations", ()=>{
215
- adapter.exec(`
216
- CREATE TABLE checkpoints (
217
- thread_id TEXT NOT NULL,
218
- checkpoint_ns TEXT NOT NULL DEFAULT '',
219
- checkpoint_id TEXT NOT NULL,
220
- parent_checkpoint_id TEXT,
221
- type TEXT,
222
- checkpoint BLOB NOT NULL,
223
- metadata BLOB NOT NULL,
224
- PRIMARY KEY (thread_id, checkpoint_ns, checkpoint_id)
225
- );
226
-
227
- CREATE TABLE checkpoint_writes (
228
- thread_id TEXT NOT NULL,
229
- checkpoint_ns TEXT NOT NULL DEFAULT '',
230
- checkpoint_id TEXT NOT NULL,
231
- task_id TEXT NOT NULL,
232
- idx INTEGER NOT NULL,
233
- channel TEXT NOT NULL,
234
- type TEXT,
235
- value BLOB,
236
- PRIMARY KEY (thread_id, checkpoint_ns, checkpoint_id, task_id, idx)
237
- );
238
- `);
239
- const insertStmt = adapter.prepare(`
240
- INSERT INTO checkpoints (thread_id, checkpoint_id, checkpoint, metadata)
241
- VALUES (?, ?, ?, ?)
242
- `);
243
- const result = insertStmt.run("thread-1", "checkpoint-1", JSON.stringify({
244
- data: "test"
245
- }), JSON.stringify({
246
- version: 1
247
- }));
248
- expect(result.changes).toBe(1);
249
- const selectStmt = adapter.prepare("SELECT * FROM checkpoints WHERE thread_id = ?");
250
- const row = selectStmt.get("thread-1");
251
- expect(row).toBeDefined();
252
- expect(row.thread_id).toBe("thread-1");
253
- expect(row.checkpoint_id).toBe("checkpoint-1");
254
- const deleteStmt = adapter.prepare("DELETE FROM checkpoints WHERE thread_id = ?");
255
- const deleteResult = deleteStmt.run("thread-1");
256
- expect(deleteResult.changes).toBe(1);
257
- });
258
- });
259
- });
@@ -1,48 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_vitest_namespaceObject = require("vitest");
4
- const candleRange_cjs_namespaceObject = require("../tools/finance/candleRange.cjs");
5
- const secondsPerDay = 86400;
6
- const fixedNow = new Date("2026-01-01T00:00:00Z");
7
- const fixedEnd = Math.floor(fixedNow.getTime() / 1000);
8
- (0, external_vitest_namespaceObject.describe)("candle range caps", ()=>{
9
- (0, external_vitest_namespaceObject.it)("defaults intraday lookback to the cap", ()=>{
10
- const range = (0, candleRange_cjs_namespaceObject.resolveCandleRange)({
11
- resolution: "60",
12
- now: fixedNow
13
- });
14
- (0, external_vitest_namespaceObject.expect)(range.maxLookbackDays).toBe(candleRange_cjs_namespaceObject.DEFAULT_CANDLE_MAX_DAYS_INTRADAY);
15
- (0, external_vitest_namespaceObject.expect)(range.from).toBe(fixedEnd - candleRange_cjs_namespaceObject.DEFAULT_CANDLE_MAX_DAYS_INTRADAY * secondsPerDay);
16
- (0, external_vitest_namespaceObject.expect)(range.capped).toBe(false);
17
- });
18
- (0, external_vitest_namespaceObject.it)("defaults daily lookback to the cap", ()=>{
19
- const range = (0, candleRange_cjs_namespaceObject.resolveCandleRange)({
20
- resolution: "D",
21
- now: fixedNow
22
- });
23
- (0, external_vitest_namespaceObject.expect)(range.maxLookbackDays).toBe(candleRange_cjs_namespaceObject.DEFAULT_CANDLE_MAX_DAYS_DAILY);
24
- (0, external_vitest_namespaceObject.expect)(range.from).toBe(fixedEnd - candleRange_cjs_namespaceObject.DEFAULT_CANDLE_MAX_DAYS_DAILY * secondsPerDay);
25
- });
26
- (0, external_vitest_namespaceObject.it)("clamps intraday ranges that exceed the cap", ()=>{
27
- const range = (0, candleRange_cjs_namespaceObject.resolveCandleRange)({
28
- resolution: "15",
29
- now: fixedNow,
30
- from: fixedEnd - (candleRange_cjs_namespaceObject.DEFAULT_CANDLE_MAX_DAYS_INTRADAY + 10) * secondsPerDay
31
- });
32
- (0, external_vitest_namespaceObject.expect)(range.from).toBe(fixedEnd - candleRange_cjs_namespaceObject.DEFAULT_CANDLE_MAX_DAYS_INTRADAY * secondsPerDay);
33
- (0, external_vitest_namespaceObject.expect)(range.capped).toBe(true);
34
- });
35
- (0, external_vitest_namespaceObject.it)("respects lookback days within the cap", ()=>{
36
- const range = (0, candleRange_cjs_namespaceObject.resolveCandleRange)({
37
- resolution: "1",
38
- now: fixedNow,
39
- lookbackDays: 30
40
- });
41
- (0, external_vitest_namespaceObject.expect)(range.from).toBe(fixedEnd - 30 * secondsPerDay);
42
- (0, external_vitest_namespaceObject.expect)(range.capped).toBe(false);
43
- });
44
- });
45
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
46
- Object.defineProperty(exports, '__esModule', {
47
- value: true
48
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,42 +0,0 @@
1
- import { describe, expect, it } from "vitest";
2
- import { DEFAULT_CANDLE_MAX_DAYS_DAILY, DEFAULT_CANDLE_MAX_DAYS_INTRADAY, resolveCandleRange } from "../tools/finance/candleRange.js";
3
- const secondsPerDay = 86400;
4
- const fixedNow = new Date("2026-01-01T00:00:00Z");
5
- const fixedEnd = Math.floor(fixedNow.getTime() / 1000);
6
- describe("candle range caps", ()=>{
7
- it("defaults intraday lookback to the cap", ()=>{
8
- const range = resolveCandleRange({
9
- resolution: "60",
10
- now: fixedNow
11
- });
12
- expect(range.maxLookbackDays).toBe(DEFAULT_CANDLE_MAX_DAYS_INTRADAY);
13
- expect(range.from).toBe(fixedEnd - DEFAULT_CANDLE_MAX_DAYS_INTRADAY * secondsPerDay);
14
- expect(range.capped).toBe(false);
15
- });
16
- it("defaults daily lookback to the cap", ()=>{
17
- const range = resolveCandleRange({
18
- resolution: "D",
19
- now: fixedNow
20
- });
21
- expect(range.maxLookbackDays).toBe(DEFAULT_CANDLE_MAX_DAYS_DAILY);
22
- expect(range.from).toBe(fixedEnd - DEFAULT_CANDLE_MAX_DAYS_DAILY * secondsPerDay);
23
- });
24
- it("clamps intraday ranges that exceed the cap", ()=>{
25
- const range = resolveCandleRange({
26
- resolution: "15",
27
- now: fixedNow,
28
- from: fixedEnd - (DEFAULT_CANDLE_MAX_DAYS_INTRADAY + 10) * secondsPerDay
29
- });
30
- expect(range.from).toBe(fixedEnd - DEFAULT_CANDLE_MAX_DAYS_INTRADAY * secondsPerDay);
31
- expect(range.capped).toBe(true);
32
- });
33
- it("respects lookback days within the cap", ()=>{
34
- const range = resolveCandleRange({
35
- resolution: "1",
36
- now: fixedNow,
37
- lookbackDays: 30
38
- });
39
- expect(range.from).toBe(fixedEnd - 30 * secondsPerDay);
40
- expect(range.capped).toBe(false);
41
- });
42
- });