onbuzz 4.9.13 → 4.10.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.
- package/node_modules/glob/README.md +31 -5
- package/node_modules/glob/dist/commonjs/glob.d.ts +8 -0
- package/node_modules/glob/dist/commonjs/glob.d.ts.map +1 -1
- package/node_modules/glob/dist/commonjs/glob.js +2 -1
- package/node_modules/glob/dist/commonjs/glob.js.map +1 -1
- package/node_modules/glob/dist/commonjs/index.min.js +3 -3
- package/node_modules/glob/dist/commonjs/index.min.js.map +4 -4
- package/node_modules/glob/dist/commonjs/pattern.d.ts +3 -0
- package/node_modules/glob/dist/commonjs/pattern.d.ts.map +1 -1
- package/node_modules/glob/dist/commonjs/pattern.js +4 -0
- package/node_modules/glob/dist/commonjs/pattern.js.map +1 -1
- package/node_modules/glob/dist/esm/glob.d.ts +8 -0
- package/node_modules/glob/dist/esm/glob.d.ts.map +1 -1
- package/node_modules/glob/dist/esm/glob.js +2 -1
- package/node_modules/glob/dist/esm/glob.js.map +1 -1
- package/node_modules/glob/dist/esm/index.min.js +3 -3
- package/node_modules/glob/dist/esm/index.min.js.map +4 -4
- package/node_modules/glob/dist/esm/pattern.d.ts +3 -0
- package/node_modules/glob/dist/esm/pattern.d.ts.map +1 -1
- package/node_modules/glob/dist/esm/pattern.js +4 -0
- package/node_modules/glob/dist/esm/pattern.js.map +1 -1
- package/node_modules/{@isaacs → glob/node_modules}/balanced-match/README.md +7 -10
- package/node_modules/{@isaacs → glob/node_modules}/balanced-match/package.json +7 -18
- package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/README.md +3 -6
- package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/dist/commonjs/index.js +6 -4
- package/node_modules/glob/node_modules/brace-expansion/dist/commonjs/index.js.map +1 -0
- package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/dist/esm/index.js +6 -4
- package/node_modules/glob/node_modules/brace-expansion/dist/esm/index.js.map +1 -0
- package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/package.json +11 -7
- package/node_modules/glob/node_modules/minimatch/README.md +76 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/ast.d.ts +4 -2
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/ast.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/ast.js +309 -55
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/ast.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/brace-expressions.js +2 -4
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/brace-expressions.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/escape.d.ts +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/escape.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/escape.js +4 -4
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/escape.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/index.d.ts +81 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/index.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/index.js +232 -134
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/index.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/unescape.d.ts +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/unescape.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/unescape.js +8 -8
- package/node_modules/glob/node_modules/minimatch/dist/commonjs/unescape.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/assert-valid-pattern.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/ast.d.ts +4 -2
- package/node_modules/glob/node_modules/minimatch/dist/esm/ast.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/ast.js +309 -55
- package/node_modules/glob/node_modules/minimatch/dist/esm/ast.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/brace-expressions.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/brace-expressions.js +2 -4
- package/node_modules/glob/node_modules/minimatch/dist/esm/brace-expressions.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/escape.d.ts +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/escape.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/escape.js +4 -4
- package/node_modules/glob/node_modules/minimatch/dist/esm/escape.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/index.d.ts +81 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/index.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/index.js +232 -134
- package/node_modules/glob/node_modules/minimatch/dist/esm/index.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/unescape.d.ts +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/unescape.d.ts.map +1 -1
- package/node_modules/glob/node_modules/minimatch/dist/esm/unescape.js +8 -8
- package/node_modules/glob/node_modules/minimatch/dist/esm/unescape.js.map +1 -1
- package/node_modules/glob/node_modules/minimatch/package.json +17 -11
- package/node_modules/glob/package.json +10 -13
- package/node_modules/minipass/LICENSE.md +55 -0
- package/node_modules/minipass/dist/commonjs/index.d.ts +12 -16
- package/node_modules/minipass/dist/commonjs/index.d.ts.map +1 -1
- package/node_modules/minipass/dist/commonjs/index.js +13 -3
- package/node_modules/minipass/dist/commonjs/index.js.map +1 -1
- package/node_modules/minipass/dist/esm/index.d.ts +12 -16
- package/node_modules/minipass/dist/esm/index.d.ts.map +1 -1
- package/node_modules/minipass/dist/esm/index.js +3 -1
- package/node_modules/minipass/dist/esm/index.js.map +1 -1
- package/node_modules/minipass/package.json +9 -14
- package/node_modules/path-scurry/node_modules/lru-cache/README.md +96 -10
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/diagnostics-channel-browser.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/diagnostics-channel-browser.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/diagnostics-channel.d.ts +5 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/diagnostics-channel.js +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/index.d.ts +1400 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/index.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/index.js +1726 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/index.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/index.min.js +2 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/index.min.js.map +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/perf.d.ts +12 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/perf.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/perf.js +10 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/browser/perf.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/diagnostics-channel-cjs.cjs.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/diagnostics-channel-cjs.d.cts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/diagnostics-channel.d.ts +5 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/diagnostics-channel.js +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.d.ts +109 -32
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.d.ts.map +1 -1
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.js +334 -197
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.js.map +1 -1
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.min.js +1 -1
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.min.js.map +4 -4
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/diagnostics-channel-node.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/diagnostics-channel-node.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/diagnostics-channel.d.ts +5 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/diagnostics-channel.js +9 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/index.d.ts +1400 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/index.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/index.js +1726 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/index.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/index.min.js +2 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/index.min.js.map +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/perf.d.ts +12 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/perf.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/perf.js +10 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/node/perf.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/perf.d.ts +12 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/perf.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/perf.js +10 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/perf.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/diagnostics-channel-browser.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/diagnostics-channel-browser.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/diagnostics-channel.d.ts +5 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/diagnostics-channel.js +4 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/index.d.ts +1400 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/index.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/index.js +1722 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/index.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/index.min.js +2 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/index.min.js.map +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/perf.d.ts +12 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/perf.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/perf.js +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/browser/perf.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/diagnostics-channel-esm.d.mts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/diagnostics-channel-esm.mjs.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/diagnostics-channel.d.ts +5 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/diagnostics-channel.js +19 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.d.ts +109 -32
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.d.ts.map +1 -1
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.js +333 -196
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.js.map +1 -1
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.min.js +1 -1
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.min.js.map +4 -4
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/diagnostics-channel-node.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/diagnostics-channel-node.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/diagnostics-channel.d.ts +5 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/diagnostics-channel.js +6 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/index.d.ts +1400 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/index.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/index.js +1722 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/index.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/index.min.js +2 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/index.min.js.map +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/perf.d.ts +12 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/perf.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/perf.js +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/node/perf.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/perf.d.ts +12 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/perf.d.ts.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/perf.js +7 -0
- package/node_modules/path-scurry/node_modules/lru-cache/dist/esm/perf.js.map +1 -0
- package/node_modules/path-scurry/node_modules/lru-cache/package.json +71 -18
- package/node_modules/path-scurry/package.json +8 -24
- package/package.json +1 -1
- package/scripts/debug-balance-probe.mjs +35 -35
- package/scripts/push-image.sh +43 -43
- package/scripts/setup-acr.sh +65 -65
- package/scripts/verify-optional-deps.js +96 -1
- package/src/__tests__/composioCliFlags.test.js +239 -239
- package/src/analyzers/CSSAnalyzer.js +298 -297
- package/src/analyzers/ConfigValidator.js +691 -690
- package/src/analyzers/ESLintAnalyzer.js +320 -320
- package/src/analyzers/JavaScriptAnalyzer.js +260 -261
- package/src/analyzers/PrettierFormatter.js +246 -247
- package/src/analyzers/PythonAnalyzer.js +283 -283
- package/src/analyzers/SecurityAnalyzer.js +729 -729
- package/src/analyzers/SparrowAnalyzer.js +341 -341
- package/src/analyzers/TypeScriptAnalyzer.js +247 -247
- package/src/analyzers/__tests__/CSSAnalyzer.test.js +41 -41
- package/src/analyzers/__tests__/ConfigValidator.test.js +362 -362
- package/src/analyzers/__tests__/JavaScriptAnalyzer.test.js +40 -40
- package/src/analyzers/__tests__/PythonAnalyzer.test.js +205 -208
- package/src/analyzers/__tests__/SecurityAnalyzer.test.js +303 -303
- package/src/analyzers/__tests__/TypeScriptAnalyzer.test.js +187 -187
- package/src/analyzers/codeCloneDetector/analyzer.js +344 -344
- package/src/analyzers/codeCloneDetector/detector.js +250 -250
- package/src/analyzers/codeCloneDetector/index.js +194 -192
- package/src/analyzers/codeCloneDetector/parser.js +199 -199
- package/src/core/__tests__/agentPool.test.js +866 -866
- package/src/core/__tests__/agentPoolAutoResume.test.js +209 -209
- package/src/core/__tests__/agentPoolWakeOnMessage.test.js +315 -315
- package/src/core/__tests__/agentScheduler.emptyResponseChatStall.test.js +213 -213
- package/src/core/__tests__/agentScheduler.errorCategorisation.test.js +246 -246
- package/src/core/__tests__/agentScheduler.firstChunkTimeout.test.js +138 -138
- package/src/core/__tests__/agentScheduler.modeTransitions.test.js +233 -233
- package/src/core/__tests__/agentScheduler.nativePromptPick.test.js +319 -319
- package/src/core/__tests__/agentScheduler.taskLifecycleInstruction.test.js +78 -78
- package/src/core/__tests__/agentScheduler.visualizer.test.js +258 -258
- package/src/core/__tests__/flowCheckpointStore.test.js +140 -140
- package/src/core/__tests__/flowEndToEnd.test.js +565 -565
- package/src/core/__tests__/flowFieldMapping.test.js +188 -189
- package/src/core/__tests__/flowLintClientMirror.test.js +96 -98
- package/src/core/__tests__/flowSavePayload.test.js +170 -169
- package/src/core/__tests__/flowTemplates.test.js +311 -311
- package/src/core/__tests__/flowVersionStore.test.js +123 -123
- package/src/core/__tests__/messageProcessor.test.js +669 -669
- package/src/core/__tests__/stateManager.test.js +0 -1
- package/src/core/agentPool.js +2474 -2475
- package/src/core/agentScheduler.js +1 -4
- package/src/core/contextManager.js +708 -708
- package/src/core/flowExecutor.js +1510 -1510
- package/src/core/flowFieldMapping.js +136 -138
- package/src/core/messageProcessor.js +953 -954
- package/src/core/orchestrator.js +593 -595
- package/src/core/stateManager.js +1765 -1752
- package/src/index.js +1221 -1221
- package/src/interfaces/__tests__/archivedAgentDelete.test.js +207 -207
- package/src/interfaces/__tests__/bulkAgentRoute.test.js +361 -361
- package/src/interfaces/__tests__/imageServing.test.js +228 -228
- package/src/interfaces/__tests__/remoteSessionAuth.test.js +308 -308
- package/src/interfaces/__tests__/videoJobsRoutes.test.js +178 -179
- package/src/interfaces/__tests__/webServer.marketplace.test.js +629 -629
- package/src/interfaces/schedulerRoutes.js +50 -50
- package/src/interfaces/terminal/__tests__/smoke/connection.test.js +341 -350
- package/src/interfaces/terminal/__tests__/smoke/enhancements.test.js +156 -156
- package/src/interfaces/terminal/__tests__/smoke/imports.test.js +325 -330
- package/src/interfaces/terminal/__tests__/smoke/tools.test.js +385 -388
- package/src/interfaces/terminal/api/session.js +265 -266
- package/src/interfaces/terminal/api/websocket.js +496 -497
- package/src/interfaces/terminal/components/AgentCreator.js +691 -705
- package/src/interfaces/terminal/components/AgentEditor.js +676 -678
- package/src/interfaces/terminal/components/AgentSwitcher.js +331 -330
- package/src/interfaces/terminal/components/ErrorPanel.js +263 -264
- package/src/interfaces/terminal/components/Header.js +28 -28
- package/src/interfaces/terminal/components/Layout.js +598 -603
- package/src/interfaces/terminal/components/MessageList.js +280 -281
- package/src/interfaces/terminal/components/SettingsPanel.js +410 -415
- package/src/interfaces/terminal/components/StatusBar.js +2 -0
- package/src/interfaces/terminal/index.js +168 -168
- package/src/interfaces/terminal/state/useAgentControl.js +496 -496
- package/src/interfaces/terminal/state/useAgents.js +537 -537
- package/src/interfaces/terminal/state/useMessages.js +629 -630
- package/src/interfaces/terminal/state/useTools.js +554 -554
- package/src/interfaces/terminal/utils/debugLogger.js +44 -44
- package/src/interfaces/terminal/utils/settingsStorage.js +232 -232
- package/src/interfaces/webServer.js +7578 -7579
- package/src/interfaces/webServer.js.bak +7046 -7046
- package/src/modules/fileExplorer/__tests__/zipDownload.test.js +237 -237
- package/src/modules/fileExplorer/controller.js +470 -469
- package/src/modules/fileExplorer/routes.js +285 -286
- package/src/modules/widget/__tests__/isDisabled.test.js +41 -41
- package/src/modules/widget/__tests__/routes.test.js +677 -678
- package/src/modules/widget/__tests__/runtime.test.js +401 -401
- package/src/modules/widget/__tests__/versioning.test.js +309 -309
- package/src/modules/widget/__tests__/webComponentRuntime.test.js +565 -565
- package/src/modules/widget/__tests__/widgetTool.test.js +316 -316
- package/src/modules/widget/routes.js +435 -435
- package/src/modules/widget/runtime/bundle.js +640 -640
- package/src/modules/widget/runtime/webComponentBundle.js +470 -470
- package/src/modules/widget/schema.js +182 -181
- package/src/modules/widget/widgetTool.js +1389 -1389
- package/src/services/__tests__/agentActivityService.test.js +401 -402
- package/src/services/__tests__/benchmarkService.test.js +184 -184
- package/src/services/__tests__/contextInjectionService.test.js +246 -246
- package/src/services/__tests__/conversationQuery.test.js +721 -723
- package/src/services/__tests__/credentialVault.test.js +469 -469
- package/src/services/__tests__/discordService.integration.test.js +638 -639
- package/src/services/__tests__/flowContextService.test.js +590 -590
- package/src/services/__tests__/memoryService.test.js +1 -1
- package/src/services/__tests__/messageSource.test.js +380 -380
- package/src/services/__tests__/modelRouterNaming.test.js +111 -111
- package/src/services/__tests__/projectDetector.test.js +34 -34
- package/src/services/__tests__/promptService.test.js +242 -242
- package/src/services/__tests__/telegramService.test.js +941 -941
- package/src/services/__tests__/tokenCountingService.test.js +48 -48
- package/src/services/agentActivityService.js +419 -420
- package/src/services/aiService.js +2997 -3001
- package/src/services/apiKeyManager.js +359 -359
- package/src/services/benchmarkService.js +196 -196
- package/src/services/codebaseKnowledgeService.js +2 -2
- package/src/services/composioService.js +738 -738
- package/src/services/conversationCompactionService.js +1258 -1257
- package/src/services/credentialVault.js +685 -685
- package/src/services/discordService.js +792 -793
- package/src/services/embeddings/__tests__/azureCustomProvider.test.js +232 -232
- package/src/services/embeddings/__tests__/embeddingService.test.js +417 -417
- package/src/services/embeddings/__tests__/localProvider.test.js +263 -263
- package/src/services/embeddings/autoRecall.js +218 -219
- package/src/services/embeddings/indexers/__tests__/agentIndexer.test.js +232 -232
- package/src/services/embeddings/indexers/__tests__/memoryIndexer.test.js +418 -418
- package/src/services/embeddings/indexers/__tests__/reminisceIndexer.test.js +356 -357
- package/src/services/embeddings/indexers/__tests__/skillsIndexer.test.js +145 -145
- package/src/services/embeddings/indexers/__tests__/taskIndexer.test.js +146 -146
- package/src/services/embeddings/indexers/composioIndexer.js +279 -279
- package/src/services/embeddings/providerInterface.js +206 -206
- package/src/services/embeddings/providers/localProvider.js +11 -7
- package/src/services/embeddings/providers/openaiProvider.js +101 -101
- package/src/services/embeddings/vectorStore/inMemoryJsonStore.js +356 -356
- package/src/services/errorHandler.js +809 -809
- package/src/services/flowContextService.js +586 -586
- package/src/services/grounding/MockAdapter.js +125 -125
- package/src/services/modelRouterService.js +26 -31
- package/src/services/modelsService.js +322 -322
- package/src/services/ollamaService.js +452 -452
- package/src/services/projectDetector.js +403 -404
- package/src/services/promptService.js +418 -418
- package/src/services/qualityInspector.js +795 -795
- package/src/services/scheduleService.js +726 -726
- package/src/services/serviceRegistry.js +386 -386
- package/src/services/telegrafBot.js +174 -174
- package/src/services/telegramService.js +1972 -1972
- package/src/services/visualEditorBridge.js +1033 -1033
- package/src/services/visualEditorServer.js +1769 -1774
- package/src/services/whatsappService.js +667 -668
- package/src/tools/__tests__/agentCommunicationTool.findAgent.test.js +226 -226
- package/src/tools/__tests__/agentCommunicationTool.test.js +3 -3
- package/src/tools/__tests__/agentDelayTool.test.js +342 -342
- package/src/tools/__tests__/baseTool.test.js +3 -3
- package/src/tools/__tests__/codeMapTool.test.js +915 -915
- package/src/tools/__tests__/fileContentReplaceTool.test.js +309 -309
- package/src/tools/__tests__/fileTreeTool.test.js +274 -274
- package/src/tools/__tests__/filesystemTool.test.js +815 -815
- package/src/tools/__tests__/foundryWebSearchTool.test.js +252 -252
- package/src/tools/__tests__/imageTool.validator.test.js +194 -194
- package/src/tools/__tests__/jobDoneTool.test.js +580 -581
- package/src/tools/__tests__/memoryTool.forgetStale.test.js +272 -272
- package/src/tools/__tests__/memoryTool.reminisce.test.js +2 -2
- package/src/tools/__tests__/memoryTool.reminisceSemanticSearch.test.js +301 -301
- package/src/tools/__tests__/memoryTool.semanticSearch.test.js +405 -405
- package/src/tools/__tests__/memoryTool.teamPool.test.js +293 -293
- package/src/tools/__tests__/memoryTool.test.js +1 -1
- package/src/tools/__tests__/seekTool.test.js +282 -282
- package/src/tools/__tests__/skillsTool.search.test.js +164 -164
- package/src/tools/__tests__/skillsTool.test.js +226 -226
- package/src/tools/__tests__/staticAnalysisTool.test.js +509 -509
- package/src/tools/__tests__/taskManagerTool.discipline.test.js +137 -137
- package/src/tools/__tests__/taskManagerTool.search.test.js +143 -143
- package/src/tools/__tests__/taskManagerTool.test.js +866 -866
- package/src/tools/__tests__/terminalTool.test.js +448 -448
- package/src/tools/__tests__/toolShapeForgiveness.test.js +259 -260
- package/src/tools/__tests__/userPromptTool.test.js +297 -297
- package/src/tools/__tests__/videoTool.jobs.test.js +147 -147
- package/src/tools/__tests__/webTool.e2e.test.js +609 -603
- package/src/tools/__tests__/webTool.unit.test.js +195 -195
- package/src/tools/__tests__/webTool.visionModel.test.js +75 -75
- package/src/tools/agentCommunicationTool.js +8 -10
- package/src/tools/agentDelayTool.js +496 -497
- package/src/tools/asyncToolManager.js +602 -603
- package/src/tools/baseTool.js +12 -11
- package/src/tools/cloneDetectionTool.js +576 -581
- package/src/tools/codeMapTool.js +0 -6
- package/src/tools/composioTool.js +617 -617
- package/src/tools/dependencyResolverTool.js +1211 -1212
- package/src/tools/desktop/DesktopTool.js +629 -638
- package/src/tools/desktop/__tests__/DesktopTool.e2e.test.js +306 -306
- package/src/tools/desktop/__tests__/DesktopTool.test.js +507 -507
- package/src/tools/desktop/__tests__/osController.test.js +364 -364
- package/src/tools/desktop/osController.js +491 -491
- package/src/tools/docxTool.js +623 -623
- package/src/tools/excelTool.js +636 -636
- package/src/tools/fileContentReplaceTool.js +5 -7
- package/src/tools/fileSystemTool.js +12 -19
- package/src/tools/fileTreeTool.js +840 -840
- package/src/tools/foundryWebSearchTool.js +273 -273
- package/src/tools/helpTool.js +198 -198
- package/src/tools/imageTool.js +1397 -1397
- package/src/tools/importAnalyzerTool.js +1056 -1056
- package/src/tools/jobDoneTool.js +495 -495
- package/src/tools/memoryTool.js +1 -1
- package/src/tools/office/pres/__tests__/presSystem.test.js +365 -365
- package/src/tools/office/pres/archetypes/agenda.js +61 -61
- package/src/tools/office/pres/archetypes/bentoGrid.js +218 -219
- package/src/tools/office/pres/archetypes/bigStat.js +140 -142
- package/src/tools/office/pres/archetypes/closing.js +70 -70
- package/src/tools/office/pres/archetypes/hero.js +70 -70
- package/src/tools/office/pres/archetypes/productHero.js +93 -94
- package/src/tools/office/pres/archetypes/table.js +73 -74
- package/src/tools/office/pres/backgrounds/orb.js +66 -66
- package/src/tools/office/pres/components.js +422 -423
- package/src/tools/officeTool.js +441 -441
- package/src/tools/pdfTool.js +625 -627
- package/src/tools/platformControlTool.js +1081 -1081
- package/src/tools/seekTool.js +917 -918
- package/src/tools/skillsTool.js +1 -1
- package/src/tools/staticAnalysisTool.js +2143 -2146
- package/src/tools/taskManagerTool.js +3324 -3324
- package/src/tools/terminalTool.js +2615 -2618
- package/src/tools/videoTool.js +1303 -1303
- package/src/tools/visionTool.js +508 -508
- package/src/tools/visualEditorTool.js +1289 -1290
- package/src/tools/webTool.js +3368 -3368
- package/src/tools/whatsappTool.js +464 -464
- package/src/types/__tests__/agent.test.js +499 -499
- package/src/types/__tests__/contextReference.test.js +606 -606
- package/src/types/__tests__/conversation.test.js +555 -555
- package/src/types/__tests__/toolCommand.test.js +584 -584
- package/src/types/contextReference.js +974 -971
- package/src/types/conversation.js +729 -729
- package/src/types/toolCommand.js +746 -746
- package/src/utilities/__tests__/attachmentValidator.test.js +80 -80
- package/src/utilities/__tests__/auditReport.test.js +328 -328
- package/src/utilities/__tests__/directoryAccessManager.test.js +388 -388
- package/src/utilities/__tests__/jsonRepair.test.js +103 -104
- package/src/utilities/__tests__/modeTransitionReasons.test.js +105 -105
- package/src/utilities/__tests__/platformUtils.test.js +80 -87
- package/src/utilities/__tests__/structuredFileValidator.test.js +261 -263
- package/src/utilities/__tests__/toolConstants.test.js +92 -94
- package/src/utilities/__tests__/useIsTouchDevice.detect.test.js +114 -114
- package/src/utilities/__tests__/webUiUtilSync.test.js +117 -117
- package/src/utilities/attachmentValidator.js +284 -288
- package/src/utilities/authCache.js.backup-1779570472481 +121 -121
- package/src/utilities/browserStealth.js +631 -630
- package/src/utilities/configManager.js +616 -617
- package/src/utilities/directoryAccessManager.js +564 -565
- package/src/utilities/fileProcessor.js +308 -307
- package/src/utilities/humanBehavior.js +454 -453
- package/src/utilities/logger.js +479 -479
- package/src/utilities/structuredFileValidator.js +696 -699
- package/src/utilities/tagParser.js +5 -10
- package/src/utilities/userDataDir.js +308 -308
- package/node_modules/@isaacs/brace-expansion/dist/commonjs/index.js.map +0 -1
- package/node_modules/@isaacs/brace-expansion/dist/esm/index.js.map +0 -1
- package/node_modules/minipass/LICENSE +0 -15
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/LICENSE.md +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/commonjs/index.d.ts +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/commonjs/index.d.ts.map +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/commonjs/index.js +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/commonjs/index.js.map +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/commonjs/package.json +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/esm/index.d.ts +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/esm/index.d.ts.map +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/esm/index.js +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/esm/index.js.map +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/balanced-match/dist/esm/package.json +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/LICENSE +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/dist/commonjs/index.d.ts +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/dist/commonjs/index.d.ts.map +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/dist/commonjs/package.json +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/dist/esm/index.d.ts +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/dist/esm/index.d.ts.map +0 -0
- /package/node_modules/{@isaacs → glob/node_modules}/brace-expansion/dist/esm/package.json +0 -0
|
@@ -1,195 +1,195 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* WebTool Unit Tests
|
|
3
|
-
*
|
|
4
|
-
* Tests the WebTool's error detection, validation, and feedback quality
|
|
5
|
-
* WITHOUT requiring a real browser. Uses mocked Puppeteer page objects.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { describe, test, expect, beforeEach
|
|
9
|
-
|
|
10
|
-
// We test the static helper and the core logic by importing WebTool
|
|
11
|
-
// and mocking the browser layer.
|
|
12
|
-
|
|
13
|
-
let WebTool;
|
|
14
|
-
|
|
15
|
-
beforeEach(async () => {
|
|
16
|
-
const mod = await import('../../tools/webTool.js');
|
|
17
|
-
WebTool = mod.default;
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
// ─── _dedupeErrors ───────────────────────────────────────────────────────────
|
|
21
|
-
|
|
22
|
-
describe('WebTool._dedupeErrors', () => {
|
|
23
|
-
test('returns empty array for empty input', () => {
|
|
24
|
-
expect(WebTool._dedupeErrors([])).toEqual([]);
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
test('returns empty array for null/undefined input', () => {
|
|
28
|
-
expect(WebTool._dedupeErrors(null)).toEqual([]);
|
|
29
|
-
expect(WebTool._dedupeErrors(undefined)).toEqual([]);
|
|
30
|
-
});
|
|
31
|
-
|
|
32
|
-
test('single unique error passes through unchanged', () => {
|
|
33
|
-
expect(WebTool._dedupeErrors(['Error A'])).toEqual(['Error A']);
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
test('deduplicates repeated errors with count', () => {
|
|
37
|
-
const input = ['Error A', 'Error A', 'Error A'];
|
|
38
|
-
expect(WebTool._dedupeErrors(input)).toEqual(['Error A (x3)']);
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
test('preserves order and mixes unique + repeated', () => {
|
|
42
|
-
const input = [
|
|
43
|
-
'Cannot read properties of undefined',
|
|
44
|
-
'Cannot read properties of undefined',
|
|
45
|
-
'Cannot read properties of undefined',
|
|
46
|
-
'Cannot read properties of undefined',
|
|
47
|
-
'Unique error: widget failed',
|
|
48
|
-
'GET https://api.bad.com/data → net::ERR_NAME_NOT_RESOLVED',
|
|
49
|
-
'GET https://api.bad.com/data → net::ERR_NAME_NOT_RESOLVED',
|
|
50
|
-
'GET https://api.bad.com/data → net::ERR_NAME_NOT_RESOLVED',
|
|
51
|
-
'GET https://api.other.com/v2 → net::ERR_NAME_NOT_RESOLVED',
|
|
52
|
-
];
|
|
53
|
-
const result = WebTool._dedupeErrors(input);
|
|
54
|
-
expect(result).toEqual([
|
|
55
|
-
'Cannot read properties of undefined (x4)',
|
|
56
|
-
'Unique error: widget failed',
|
|
57
|
-
'GET https://api.bad.com/data → net::ERR_NAME_NOT_RESOLVED (x3)',
|
|
58
|
-
'GET https://api.other.com/v2 → net::ERR_NAME_NOT_RESOLVED',
|
|
59
|
-
]);
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
test('does not add count suffix for single occurrences', () => {
|
|
63
|
-
const input = ['Error A', 'Error B', 'Error C'];
|
|
64
|
-
const result = WebTool._dedupeErrors(input);
|
|
65
|
-
expect(result).toEqual(['Error A', 'Error B', 'Error C']);
|
|
66
|
-
result.forEach(r => {
|
|
67
|
-
expect(r).not.toContain('(x');
|
|
68
|
-
});
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
test('handles two duplicates correctly', () => {
|
|
72
|
-
expect(WebTool._dedupeErrors(['X', 'X'])).toEqual(['X (x2)']);
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
// ─── URL Validation ──────────────────────────────────────────────────────────
|
|
77
|
-
|
|
78
|
-
describe('WebTool URL validation', () => {
|
|
79
|
-
let wt;
|
|
80
|
-
const silentLogger = { info() {}, warn() {}, error() {}, debug() {} };
|
|
81
|
-
|
|
82
|
-
beforeEach(() => {
|
|
83
|
-
wt = new WebTool({ logger: silentLogger });
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
test('fetch with no URL returns error', async () => {
|
|
87
|
-
const result = await wt.execute({ operation: 'fetch' }, { agentId: 'test', context: {} });
|
|
88
|
-
expect(result.success).toBe(false);
|
|
89
|
-
expect(result.error).toMatch(/URL is required/i);
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
test('fetch with empty string URL returns error', async () => {
|
|
93
|
-
const result = await wt.execute({ operation: 'fetch', url: '' }, { agentId: 'test', context: {} });
|
|
94
|
-
expect(result.success).toBe(false);
|
|
95
|
-
expect(result.error).toMatch(/URL is required/i);
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
test('fetch with invalid URL format returns error', async () => {
|
|
99
|
-
const result = await wt.execute({ operation: 'fetch', url: 'not-a-url' }, { agentId: 'test', context: {} });
|
|
100
|
-
expect(result.success).toBe(false);
|
|
101
|
-
expect(result.error).toMatch(/Invalid URL format/);
|
|
102
|
-
expect(result.error).toContain('not-a-url');
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
test('fetch with missing protocol returns error', async () => {
|
|
106
|
-
const result = await wt.execute({ operation: 'fetch', url: 'example.com' }, { agentId: 'test', context: {} });
|
|
107
|
-
expect(result.success).toBe(false);
|
|
108
|
-
expect(result.error).toMatch(/Invalid URL format/);
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
test('unknown operation returns error', async () => {
|
|
112
|
-
const result = await wt.execute({ operation: 'foobar' }, { agentId: 'test', context: {} });
|
|
113
|
-
expect(result.success).toBe(false);
|
|
114
|
-
expect(result.error).toMatch(/Unknown operation/);
|
|
115
|
-
});
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
// ─── Search validation ───────────────────────────────────────────────────────
|
|
119
|
-
|
|
120
|
-
describe('WebTool search validation', () => {
|
|
121
|
-
let wt;
|
|
122
|
-
const silentLogger = { info() {}, warn() {}, error() {}, debug() {} };
|
|
123
|
-
|
|
124
|
-
beforeEach(() => {
|
|
125
|
-
wt = new WebTool({ logger: silentLogger });
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
test('search with empty query returns error', async () => {
|
|
129
|
-
const result = await wt.execute({ operation: 'search', query: '' }, { agentId: 'test', context: {} });
|
|
130
|
-
expect(result.success).toBe(false);
|
|
131
|
-
expect(result.error).toMatch(/query is required/i);
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
test('search with unknown engine returns error', async () => {
|
|
135
|
-
const result = await wt.execute({ operation: 'search', query: 'hello', engine: 'fakesearch' }, { agentId: 'test', context: {} });
|
|
136
|
-
expect(result.success).toBe(false);
|
|
137
|
-
expect(result.error).toMatch(/Unknown search engine/i);
|
|
138
|
-
});
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
// ─── Execute wrapper ─────────────────────────────────────────────────────────
|
|
142
|
-
|
|
143
|
-
describe('WebTool execute wrapper', () => {
|
|
144
|
-
let wt;
|
|
145
|
-
const silentLogger = { info() {}, warn() {}, error() {}, debug() {} };
|
|
146
|
-
|
|
147
|
-
beforeEach(() => {
|
|
148
|
-
wt = new WebTool({ logger: silentLogger });
|
|
149
|
-
});
|
|
150
|
-
|
|
151
|
-
test('respects operation success=false flag', async () => {
|
|
152
|
-
// fetch with invalid URL should propagate success=false
|
|
153
|
-
const result = await wt.execute({ operation: 'fetch', url: 'invalid' }, { agentId: 'test', context: {} });
|
|
154
|
-
expect(result.success).toBe(false);
|
|
155
|
-
// Must NOT be overridden to true
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
test('includes operation name in result', async () => {
|
|
159
|
-
const result = await wt.execute({ operation: 'fetch', url: 'bad' }, { agentId: 'test', context: {} });
|
|
160
|
-
expect(result.operation).toBe('fetch');
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
test('includes toolUsed in result', async () => {
|
|
164
|
-
const result = await wt.execute({ operation: 'fetch', url: 'bad' }, { agentId: 'test', context: {} });
|
|
165
|
-
expect(result.toolUsed).toBe('web');
|
|
166
|
-
});
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
// ─── Parameter parsing ───────────────────────────────────────────────────────
|
|
170
|
-
|
|
171
|
-
describe('WebTool parameter parsing', () => {
|
|
172
|
-
let wt;
|
|
173
|
-
const silentLogger = { info() {}, warn() {}, error() {}, debug() {} };
|
|
174
|
-
|
|
175
|
-
beforeEach(() => {
|
|
176
|
-
wt = new WebTool({ logger: silentLogger });
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
test('missing operation returns error', async () => {
|
|
180
|
-
const result = await wt.execute({}, { agentId: 'test', context: {} });
|
|
181
|
-
expect(result.success).toBe(false);
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
test('authenticate with no siteId returns error', async () => {
|
|
185
|
-
const result = await wt.execute({ operation: 'authenticate' }, { agentId: 'test', context: {} });
|
|
186
|
-
expect(result.success).toBe(false);
|
|
187
|
-
expect(result.error).toMatch(/site.*required/i);
|
|
188
|
-
});
|
|
189
|
-
|
|
190
|
-
test('interactive with empty actions array succeeds vacuously', async () => {
|
|
191
|
-
const result = await wt.execute({ operation: 'interactive', actions: [] }, { agentId: 'test', context: {} });
|
|
192
|
-
expect(result.success).toBe(true);
|
|
193
|
-
expect(result.data.actionsExecuted).toBe(0);
|
|
194
|
-
});
|
|
195
|
-
});
|
|
1
|
+
/**
|
|
2
|
+
* WebTool Unit Tests
|
|
3
|
+
*
|
|
4
|
+
* Tests the WebTool's error detection, validation, and feedback quality
|
|
5
|
+
* WITHOUT requiring a real browser. Uses mocked Puppeteer page objects.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { describe, test, expect, beforeEach } from '@jest/globals';
|
|
9
|
+
|
|
10
|
+
// We test the static helper and the core logic by importing WebTool
|
|
11
|
+
// and mocking the browser layer.
|
|
12
|
+
|
|
13
|
+
let WebTool;
|
|
14
|
+
|
|
15
|
+
beforeEach(async () => {
|
|
16
|
+
const mod = await import('../../tools/webTool.js');
|
|
17
|
+
WebTool = mod.default;
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
// ─── _dedupeErrors ───────────────────────────────────────────────────────────
|
|
21
|
+
|
|
22
|
+
describe('WebTool._dedupeErrors', () => {
|
|
23
|
+
test('returns empty array for empty input', () => {
|
|
24
|
+
expect(WebTool._dedupeErrors([])).toEqual([]);
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
test('returns empty array for null/undefined input', () => {
|
|
28
|
+
expect(WebTool._dedupeErrors(null)).toEqual([]);
|
|
29
|
+
expect(WebTool._dedupeErrors(undefined)).toEqual([]);
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
test('single unique error passes through unchanged', () => {
|
|
33
|
+
expect(WebTool._dedupeErrors(['Error A'])).toEqual(['Error A']);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
test('deduplicates repeated errors with count', () => {
|
|
37
|
+
const input = ['Error A', 'Error A', 'Error A'];
|
|
38
|
+
expect(WebTool._dedupeErrors(input)).toEqual(['Error A (x3)']);
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
test('preserves order and mixes unique + repeated', () => {
|
|
42
|
+
const input = [
|
|
43
|
+
'Cannot read properties of undefined',
|
|
44
|
+
'Cannot read properties of undefined',
|
|
45
|
+
'Cannot read properties of undefined',
|
|
46
|
+
'Cannot read properties of undefined',
|
|
47
|
+
'Unique error: widget failed',
|
|
48
|
+
'GET https://api.bad.com/data → net::ERR_NAME_NOT_RESOLVED',
|
|
49
|
+
'GET https://api.bad.com/data → net::ERR_NAME_NOT_RESOLVED',
|
|
50
|
+
'GET https://api.bad.com/data → net::ERR_NAME_NOT_RESOLVED',
|
|
51
|
+
'GET https://api.other.com/v2 → net::ERR_NAME_NOT_RESOLVED',
|
|
52
|
+
];
|
|
53
|
+
const result = WebTool._dedupeErrors(input);
|
|
54
|
+
expect(result).toEqual([
|
|
55
|
+
'Cannot read properties of undefined (x4)',
|
|
56
|
+
'Unique error: widget failed',
|
|
57
|
+
'GET https://api.bad.com/data → net::ERR_NAME_NOT_RESOLVED (x3)',
|
|
58
|
+
'GET https://api.other.com/v2 → net::ERR_NAME_NOT_RESOLVED',
|
|
59
|
+
]);
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
test('does not add count suffix for single occurrences', () => {
|
|
63
|
+
const input = ['Error A', 'Error B', 'Error C'];
|
|
64
|
+
const result = WebTool._dedupeErrors(input);
|
|
65
|
+
expect(result).toEqual(['Error A', 'Error B', 'Error C']);
|
|
66
|
+
result.forEach(r => {
|
|
67
|
+
expect(r).not.toContain('(x');
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
test('handles two duplicates correctly', () => {
|
|
72
|
+
expect(WebTool._dedupeErrors(['X', 'X'])).toEqual(['X (x2)']);
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
// ─── URL Validation ──────────────────────────────────────────────────────────
|
|
77
|
+
|
|
78
|
+
describe('WebTool URL validation', () => {
|
|
79
|
+
let wt;
|
|
80
|
+
const silentLogger = { info() {}, warn() {}, error() {}, debug() {} };
|
|
81
|
+
|
|
82
|
+
beforeEach(() => {
|
|
83
|
+
wt = new WebTool({ logger: silentLogger });
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
test('fetch with no URL returns error', async () => {
|
|
87
|
+
const result = await wt.execute({ operation: 'fetch' }, { agentId: 'test', context: {} });
|
|
88
|
+
expect(result.success).toBe(false);
|
|
89
|
+
expect(result.error).toMatch(/URL is required/i);
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
test('fetch with empty string URL returns error', async () => {
|
|
93
|
+
const result = await wt.execute({ operation: 'fetch', url: '' }, { agentId: 'test', context: {} });
|
|
94
|
+
expect(result.success).toBe(false);
|
|
95
|
+
expect(result.error).toMatch(/URL is required/i);
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
test('fetch with invalid URL format returns error', async () => {
|
|
99
|
+
const result = await wt.execute({ operation: 'fetch', url: 'not-a-url' }, { agentId: 'test', context: {} });
|
|
100
|
+
expect(result.success).toBe(false);
|
|
101
|
+
expect(result.error).toMatch(/Invalid URL format/);
|
|
102
|
+
expect(result.error).toContain('not-a-url');
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
test('fetch with missing protocol returns error', async () => {
|
|
106
|
+
const result = await wt.execute({ operation: 'fetch', url: 'example.com' }, { agentId: 'test', context: {} });
|
|
107
|
+
expect(result.success).toBe(false);
|
|
108
|
+
expect(result.error).toMatch(/Invalid URL format/);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
test('unknown operation returns error', async () => {
|
|
112
|
+
const result = await wt.execute({ operation: 'foobar' }, { agentId: 'test', context: {} });
|
|
113
|
+
expect(result.success).toBe(false);
|
|
114
|
+
expect(result.error).toMatch(/Unknown operation/);
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
// ─── Search validation ───────────────────────────────────────────────────────
|
|
119
|
+
|
|
120
|
+
describe('WebTool search validation', () => {
|
|
121
|
+
let wt;
|
|
122
|
+
const silentLogger = { info() {}, warn() {}, error() {}, debug() {} };
|
|
123
|
+
|
|
124
|
+
beforeEach(() => {
|
|
125
|
+
wt = new WebTool({ logger: silentLogger });
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
test('search with empty query returns error', async () => {
|
|
129
|
+
const result = await wt.execute({ operation: 'search', query: '' }, { agentId: 'test', context: {} });
|
|
130
|
+
expect(result.success).toBe(false);
|
|
131
|
+
expect(result.error).toMatch(/query is required/i);
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
test('search with unknown engine returns error', async () => {
|
|
135
|
+
const result = await wt.execute({ operation: 'search', query: 'hello', engine: 'fakesearch' }, { agentId: 'test', context: {} });
|
|
136
|
+
expect(result.success).toBe(false);
|
|
137
|
+
expect(result.error).toMatch(/Unknown search engine/i);
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
// ─── Execute wrapper ─────────────────────────────────────────────────────────
|
|
142
|
+
|
|
143
|
+
describe('WebTool execute wrapper', () => {
|
|
144
|
+
let wt;
|
|
145
|
+
const silentLogger = { info() {}, warn() {}, error() {}, debug() {} };
|
|
146
|
+
|
|
147
|
+
beforeEach(() => {
|
|
148
|
+
wt = new WebTool({ logger: silentLogger });
|
|
149
|
+
});
|
|
150
|
+
|
|
151
|
+
test('respects operation success=false flag', async () => {
|
|
152
|
+
// fetch with invalid URL should propagate success=false
|
|
153
|
+
const result = await wt.execute({ operation: 'fetch', url: 'invalid' }, { agentId: 'test', context: {} });
|
|
154
|
+
expect(result.success).toBe(false);
|
|
155
|
+
// Must NOT be overridden to true
|
|
156
|
+
});
|
|
157
|
+
|
|
158
|
+
test('includes operation name in result', async () => {
|
|
159
|
+
const result = await wt.execute({ operation: 'fetch', url: 'bad' }, { agentId: 'test', context: {} });
|
|
160
|
+
expect(result.operation).toBe('fetch');
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
test('includes toolUsed in result', async () => {
|
|
164
|
+
const result = await wt.execute({ operation: 'fetch', url: 'bad' }, { agentId: 'test', context: {} });
|
|
165
|
+
expect(result.toolUsed).toBe('web');
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
|
|
169
|
+
// ─── Parameter parsing ───────────────────────────────────────────────────────
|
|
170
|
+
|
|
171
|
+
describe('WebTool parameter parsing', () => {
|
|
172
|
+
let wt;
|
|
173
|
+
const silentLogger = { info() {}, warn() {}, error() {}, debug() {} };
|
|
174
|
+
|
|
175
|
+
beforeEach(() => {
|
|
176
|
+
wt = new WebTool({ logger: silentLogger });
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
test('missing operation returns error', async () => {
|
|
180
|
+
const result = await wt.execute({}, { agentId: 'test', context: {} });
|
|
181
|
+
expect(result.success).toBe(false);
|
|
182
|
+
});
|
|
183
|
+
|
|
184
|
+
test('authenticate with no siteId returns error', async () => {
|
|
185
|
+
const result = await wt.execute({ operation: 'authenticate' }, { agentId: 'test', context: {} });
|
|
186
|
+
expect(result.success).toBe(false);
|
|
187
|
+
expect(result.error).toMatch(/site.*required/i);
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
test('interactive with empty actions array succeeds vacuously', async () => {
|
|
191
|
+
const result = await wt.execute({ operation: 'interactive', actions: [] }, { agentId: 'test', context: {} });
|
|
192
|
+
expect(result.success).toBe(true);
|
|
193
|
+
expect(result.data.actionsExecuted).toBe(0);
|
|
194
|
+
});
|
|
195
|
+
});
|
|
@@ -1,75 +1,75 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tests for WebTool._selectVisionModel() — catalog-driven.
|
|
3
|
-
* Uses recommended_for and tier instead of hardcoded name lists.
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
function selectVisionModel(context) {
|
|
9
|
-
const modelsService = context.aiService?.modelsService;
|
|
10
|
-
if (!modelsService) return null;
|
|
11
|
-
|
|
12
|
-
const allModels = modelsService.getModels?.() || [];
|
|
13
|
-
const visionModels = allModels.filter(m => m.supportsVision === true);
|
|
14
|
-
if (visionModels.length === 0) return null;
|
|
15
|
-
|
|
16
|
-
const recommended = visionModels.find(m => m.recommended_for?.includes('vision'));
|
|
17
|
-
if (recommended) return recommended.name;
|
|
18
|
-
|
|
19
|
-
const budget = visionModels.find(m => m.tier === 'budget');
|
|
20
|
-
if (budget) return budget.name;
|
|
21
|
-
|
|
22
|
-
return visionModels[0].name;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
function makeContext(models) {
|
|
26
|
-
return { aiService: { modelsService: { getModels: () => models } } };
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
describe('WebTool._selectVisionModel (catalog-driven)', () => {
|
|
30
|
-
|
|
31
|
-
test('selects model recommended for vision', () => {
|
|
32
|
-
const models = [
|
|
33
|
-
{ name: 'vision-model', supportsVision: true, recommended_for: ['vision'], tier: 'budget' },
|
|
34
|
-
{ name: 'other', supportsVision: true, recommended_for: [], tier: 'standard' },
|
|
35
|
-
];
|
|
36
|
-
expect(selectVisionModel(makeContext(models))).toBe('vision-model');
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
test('selects budget vision model as fallback', () => {
|
|
40
|
-
const models = [
|
|
41
|
-
{ name: 'premium', supportsVision: true, recommended_for: [], tier: 'premium' },
|
|
42
|
-
{ name: 'cheap', supportsVision: true, recommended_for: [], tier: 'budget' },
|
|
43
|
-
];
|
|
44
|
-
expect(selectVisionModel(makeContext(models))).toBe('cheap');
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
test('returns first available when no tags match', () => {
|
|
48
|
-
const models = [
|
|
49
|
-
{ name: 'only-one', supportsVision: true, recommended_for: [], tier: 'premium' },
|
|
50
|
-
];
|
|
51
|
-
expect(selectVisionModel(makeContext(models))).toBe('only-one');
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
test('skips non-vision models', () => {
|
|
55
|
-
const models = [
|
|
56
|
-
{ name: 'text-only', supportsVision: false, recommended_for: ['vision'], tier: 'budget' },
|
|
57
|
-
{ name: 'actual-vision', supportsVision: true, recommended_for: [], tier: 'standard' },
|
|
58
|
-
];
|
|
59
|
-
expect(selectVisionModel(makeContext(models))).toBe('actual-vision');
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
test('returns null when no models available', () => {
|
|
63
|
-
expect(selectVisionModel(makeContext([]))).toBeNull();
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
test('returns null when no aiService', () => {
|
|
67
|
-
expect(selectVisionModel({})).toBeNull();
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
test('falls back to o4-mini when _selectVisionModel returns null', () => {
|
|
71
|
-
// The actual code does: this._selectVisionModel(context) || 'o4-mini'
|
|
72
|
-
const result = selectVisionModel({}) || 'o4-mini';
|
|
73
|
-
expect(result).toBe('o4-mini');
|
|
74
|
-
});
|
|
75
|
-
});
|
|
1
|
+
/**
|
|
2
|
+
* Tests for WebTool._selectVisionModel() — catalog-driven.
|
|
3
|
+
* Uses recommended_for and tier instead of hardcoded name lists.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { describe, test, expect } from '@jest/globals';
|
|
7
|
+
|
|
8
|
+
function selectVisionModel(context) {
|
|
9
|
+
const modelsService = context.aiService?.modelsService;
|
|
10
|
+
if (!modelsService) return null;
|
|
11
|
+
|
|
12
|
+
const allModels = modelsService.getModels?.() || [];
|
|
13
|
+
const visionModels = allModels.filter(m => m.supportsVision === true);
|
|
14
|
+
if (visionModels.length === 0) return null;
|
|
15
|
+
|
|
16
|
+
const recommended = visionModels.find(m => m.recommended_for?.includes('vision'));
|
|
17
|
+
if (recommended) return recommended.name;
|
|
18
|
+
|
|
19
|
+
const budget = visionModels.find(m => m.tier === 'budget');
|
|
20
|
+
if (budget) return budget.name;
|
|
21
|
+
|
|
22
|
+
return visionModels[0].name;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
function makeContext(models) {
|
|
26
|
+
return { aiService: { modelsService: { getModels: () => models } } };
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
describe('WebTool._selectVisionModel (catalog-driven)', () => {
|
|
30
|
+
|
|
31
|
+
test('selects model recommended for vision', () => {
|
|
32
|
+
const models = [
|
|
33
|
+
{ name: 'vision-model', supportsVision: true, recommended_for: ['vision'], tier: 'budget' },
|
|
34
|
+
{ name: 'other', supportsVision: true, recommended_for: [], tier: 'standard' },
|
|
35
|
+
];
|
|
36
|
+
expect(selectVisionModel(makeContext(models))).toBe('vision-model');
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
test('selects budget vision model as fallback', () => {
|
|
40
|
+
const models = [
|
|
41
|
+
{ name: 'premium', supportsVision: true, recommended_for: [], tier: 'premium' },
|
|
42
|
+
{ name: 'cheap', supportsVision: true, recommended_for: [], tier: 'budget' },
|
|
43
|
+
];
|
|
44
|
+
expect(selectVisionModel(makeContext(models))).toBe('cheap');
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
test('returns first available when no tags match', () => {
|
|
48
|
+
const models = [
|
|
49
|
+
{ name: 'only-one', supportsVision: true, recommended_for: [], tier: 'premium' },
|
|
50
|
+
];
|
|
51
|
+
expect(selectVisionModel(makeContext(models))).toBe('only-one');
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
test('skips non-vision models', () => {
|
|
55
|
+
const models = [
|
|
56
|
+
{ name: 'text-only', supportsVision: false, recommended_for: ['vision'], tier: 'budget' },
|
|
57
|
+
{ name: 'actual-vision', supportsVision: true, recommended_for: [], tier: 'standard' },
|
|
58
|
+
];
|
|
59
|
+
expect(selectVisionModel(makeContext(models))).toBe('actual-vision');
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
test('returns null when no models available', () => {
|
|
63
|
+
expect(selectVisionModel(makeContext([]))).toBeNull();
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
test('returns null when no aiService', () => {
|
|
67
|
+
expect(selectVisionModel({})).toBeNull();
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
test('falls back to o4-mini when _selectVisionModel returns null', () => {
|
|
71
|
+
// The actual code does: this._selectVisionModel(context) || 'o4-mini'
|
|
72
|
+
const result = selectVisionModel({}) || 'o4-mini';
|
|
73
|
+
expect(result).toBe('o4-mini');
|
|
74
|
+
});
|
|
75
|
+
});
|
|
@@ -157,7 +157,7 @@ LIMITS:
|
|
|
157
157
|
try {
|
|
158
158
|
const parsed = JSON.parse(content);
|
|
159
159
|
return this.parseParameters(parsed); // Recursive call to handle the parsed object
|
|
160
|
-
} catch
|
|
160
|
+
} catch {
|
|
161
161
|
// Not valid JSON, continue to XML parsing
|
|
162
162
|
}
|
|
163
163
|
}
|
|
@@ -829,7 +829,7 @@ LIMITS:
|
|
|
829
829
|
/**
|
|
830
830
|
* Get unreplied messages for an agent
|
|
831
831
|
*/
|
|
832
|
-
async getUnrepliedMessages(agentId, parameters
|
|
832
|
+
async getUnrepliedMessages(agentId, parameters) {
|
|
833
833
|
try {
|
|
834
834
|
const {
|
|
835
835
|
'include-low-priority': includeLowPriority = false,
|
|
@@ -900,7 +900,7 @@ LIMITS:
|
|
|
900
900
|
/**
|
|
901
901
|
* Mark a conversation as ended
|
|
902
902
|
*/
|
|
903
|
-
async markConversationEnded(agentId, parameters
|
|
903
|
+
async markConversationEnded(agentId, parameters) {
|
|
904
904
|
try {
|
|
905
905
|
const {
|
|
906
906
|
'conversation-id': conversationId,
|
|
@@ -1000,7 +1000,7 @@ LIMITS:
|
|
|
1000
1000
|
async _processAttachments(attachments, agentId, context = {}) {
|
|
1001
1001
|
if (!attachments) return [];
|
|
1002
1002
|
|
|
1003
|
-
let attachmentList
|
|
1003
|
+
let attachmentList;
|
|
1004
1004
|
if (typeof attachments === 'string') {
|
|
1005
1005
|
try {
|
|
1006
1006
|
attachmentList = JSON.parse(attachments);
|
|
@@ -1278,13 +1278,13 @@ ${message.attachments.length > 0 ? `**Attachments:** ${message.attachments.lengt
|
|
|
1278
1278
|
for (const attachment of message.attachments) {
|
|
1279
1279
|
try {
|
|
1280
1280
|
await fs.unlink(attachment.storagePath);
|
|
1281
|
-
} catch
|
|
1281
|
+
} catch {
|
|
1282
1282
|
// Ignore errors for missing files
|
|
1283
1283
|
}
|
|
1284
1284
|
}
|
|
1285
1285
|
|
|
1286
1286
|
// Remove from inboxes
|
|
1287
|
-
for (const [
|
|
1287
|
+
for (const [, inbox] of this.agentInboxes.entries()) {
|
|
1288
1288
|
inbox.delete(messageId);
|
|
1289
1289
|
}
|
|
1290
1290
|
|
|
@@ -1297,7 +1297,7 @@ ${message.attachments.length > 0 ? `**Attachments:** ${message.attachments.lengt
|
|
|
1297
1297
|
const lastActivity = new Date(conversation.lastActivity).getTime();
|
|
1298
1298
|
if (lastActivity < retentionCutoff || conversation.status === 'ended') {
|
|
1299
1299
|
// Remove from agent conversations
|
|
1300
|
-
for (const [
|
|
1300
|
+
for (const [, convs] of this.agentConversations.entries()) {
|
|
1301
1301
|
convs.delete(conversationId);
|
|
1302
1302
|
}
|
|
1303
1303
|
|
|
@@ -1379,9 +1379,7 @@ ${message.attachments.length > 0 ? `**Attachments:** ${message.attachments.lengt
|
|
|
1379
1379
|
* Check if sender can send message to recipient
|
|
1380
1380
|
* @private
|
|
1381
1381
|
*/
|
|
1382
|
-
async _canSendMessage(senderAgent, recipientId
|
|
1383
|
-
const agentPool = context.agentPool;
|
|
1384
|
-
|
|
1382
|
+
async _canSendMessage(senderAgent, recipientId) {
|
|
1385
1383
|
// Ensure interAgentTracking is a Map (defensive - may be plain object from JSON)
|
|
1386
1384
|
if (!senderAgent.interAgentTracking || !(senderAgent.interAgentTracking instanceof Map)) {
|
|
1387
1385
|
if (senderAgent.interAgentTracking && typeof senderAgent.interAgentTracking === 'object') {
|