@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.
- package/dist/agent/backend/filtered-backend.cjs +130 -0
- package/dist/agent/backend/filtered-backend.d.ts +10 -0
- package/dist/agent/backend/filtered-backend.js +87 -0
- package/dist/agent/config/agentConfig.cjs +4 -0
- package/dist/agent/config/agentConfig.d.ts +12 -0
- package/dist/agent/config/agentConfig.js +4 -0
- package/dist/agent/config/toolRegistry.cjs +75 -1
- package/dist/agent/config/toolRegistry.d.ts +3 -0
- package/dist/agent/config/toolRegistry.js +75 -1
- package/dist/agent/middleware/additional-messages.cjs +4 -1
- package/dist/agent/middleware/additional-messages.js +4 -1
- package/dist/agent/middleware/large-tool-results.cjs +207 -0
- package/dist/agent/middleware/large-tool-results.d.ts +16 -0
- package/dist/agent/middleware/large-tool-results.js +173 -0
- package/dist/agent/tools/browser_control.cjs +9 -1231
- package/dist/agent/tools/browser_control.d.ts +126 -234
- package/dist/agent/tools/browser_control.js +7 -1226
- package/dist/agent/tools/browser_runtime.cjs +1358 -0
- package/dist/agent/tools/browser_runtime.d.ts +617 -0
- package/dist/agent/tools/browser_runtime.js +1288 -0
- package/dist/agent/tools/browser_session.cjs +189 -0
- package/dist/agent/tools/browser_session.d.ts +686 -0
- package/dist/agent/tools/browser_session.js +146 -0
- package/dist/agent/tools/browser_session_manager.cjs +213 -0
- package/dist/agent/tools/browser_session_manager.d.ts +70 -0
- package/dist/agent/tools/browser_session_manager.js +176 -0
- package/dist/cli/commands/init.cjs +80 -98
- package/dist/cli/commands/init.js +80 -98
- package/dist/cli/config/loader.cjs +0 -5
- package/dist/cli/config/loader.js +0 -5
- package/dist/cli/config/schema.cjs +3 -7
- package/dist/cli/config/schema.d.ts +6 -6
- package/dist/cli/config/schema.js +3 -7
- package/dist/cli/core/agentInvoker.cjs +88 -22
- package/dist/cli/core/agentInvoker.d.ts +10 -3
- package/dist/cli/core/agentInvoker.js +88 -25
- package/dist/cli/core/outputManager.cjs +7 -2
- package/dist/cli/core/outputManager.d.ts +2 -2
- package/dist/cli/core/outputManager.js +7 -2
- package/dist/cli/core/sessionManager.cjs +208 -41
- package/dist/cli/core/sessionManager.d.ts +20 -0
- package/dist/cli/core/sessionManager.js +208 -41
- package/dist/cli/index.cjs +16 -1
- package/dist/cli/index.js +16 -1
- package/dist/cli/services/updateCheck.cjs +212 -0
- package/dist/cli/services/updateCheck.d.ts +26 -0
- package/dist/cli/services/updateCheck.js +166 -0
- package/dist/cli/types.d.ts +2 -1
- package/dist/gateway/server.cjs +7 -0
- package/dist/gateway/server.js +7 -0
- package/dist/webui/assets/index-D3x3G75t.css +11 -0
- package/dist/webui/assets/index-UpMmcU1f.js +215 -0
- package/dist/webui/index.html +2 -2
- package/package.json +12 -12
- package/templates/agents/README.md +3 -1
- package/templates/agents/coding/agent.md +6 -13
- package/templates/agents/coding-v2/agent.md +6 -1
- package/templates/agents/game-dev/agent.md +9 -2
- package/templates/agents/game-dev/game-designer.md +4 -0
- package/templates/agents/game-dev/scene-engineer.md +4 -0
- package/templates/agents/main/agent.md +7 -2
- package/templates/agents/researcher/agent.md +14 -3
- package/templates/agents/stock-trader/agent.md +4 -0
- package/dist/agent/tests/agentConfig.test.cjs +0 -224
- package/dist/agent/tests/agentConfig.test.d.ts +0 -1
- package/dist/agent/tests/agentConfig.test.js +0 -218
- package/dist/agent/tests/agentLoader.test.cjs +0 -335
- package/dist/agent/tests/agentLoader.test.d.ts +0 -1
- package/dist/agent/tests/agentLoader.test.js +0 -329
- package/dist/agent/tests/backgroundTerminal.test.cjs +0 -70
- package/dist/agent/tests/backgroundTerminal.test.d.ts +0 -1
- package/dist/agent/tests/backgroundTerminal.test.js +0 -64
- package/dist/agent/tests/browserControlHelpers.test.cjs +0 -35
- package/dist/agent/tests/browserControlHelpers.test.d.ts +0 -1
- package/dist/agent/tests/browserControlHelpers.test.js +0 -29
- package/dist/agent/tests/browserControlTool.test.cjs +0 -2117
- package/dist/agent/tests/browserControlTool.test.d.ts +0 -1
- package/dist/agent/tests/browserControlTool.test.js +0 -2111
- package/dist/agent/tests/commandExecuteTool.test.cjs +0 -29
- package/dist/agent/tests/commandExecuteTool.test.d.ts +0 -1
- package/dist/agent/tests/commandExecuteTool.test.js +0 -23
- package/dist/agent/tests/internet_search.test.cjs +0 -107
- package/dist/agent/tests/internet_search.test.d.ts +0 -1
- package/dist/agent/tests/internet_search.test.js +0 -101
- package/dist/agent/tests/mcpClientManager.test.cjs +0 -290
- package/dist/agent/tests/mcpClientManager.test.d.ts +0 -1
- package/dist/agent/tests/mcpClientManager.test.js +0 -284
- package/dist/agent/tests/mcpResourceTools.test.cjs +0 -101
- package/dist/agent/tests/mcpResourceTools.test.d.ts +0 -1
- package/dist/agent/tests/mcpResourceTools.test.js +0 -95
- package/dist/agent/tests/modelFactory.test.cjs +0 -190
- package/dist/agent/tests/modelFactory.test.d.ts +0 -1
- package/dist/agent/tests/modelFactory.test.js +0 -184
- package/dist/agent/tests/terminalSessionManager.test.cjs +0 -121
- package/dist/agent/tests/terminalSessionManager.test.d.ts +0 -1
- package/dist/agent/tests/terminalSessionManager.test.js +0 -115
- package/dist/agent/tests/test-agent-loader.cjs +0 -33
- package/dist/agent/tests/test-agent-loader.d.ts +0 -1
- package/dist/agent/tests/test-agent-loader.js +0 -27
- package/dist/agent/tests/test-subagent-loading.cjs +0 -99
- package/dist/agent/tests/test-subagent-loading.d.ts +0 -1
- package/dist/agent/tests/test-subagent-loading.js +0 -93
- package/dist/agent/tests/toolRegistry.test.cjs +0 -147
- package/dist/agent/tests/toolRegistry.test.d.ts +0 -1
- package/dist/agent/tests/toolRegistry.test.js +0 -141
- package/dist/agent/tests/uiRegistryTools.test.cjs +0 -114
- package/dist/agent/tests/uiRegistryTools.test.d.ts +0 -1
- package/dist/agent/tests/uiRegistryTools.test.js +0 -105
- package/dist/agent/tests/xaiImageModel.test.cjs +0 -194
- package/dist/agent/tests/xaiImageModel.test.d.ts +0 -1
- package/dist/agent/tests/xaiImageModel.test.js +0 -188
- package/dist/tests/additionalMessageMiddleware.test.cjs +0 -216
- package/dist/tests/additionalMessageMiddleware.test.d.ts +0 -1
- package/dist/tests/additionalMessageMiddleware.test.js +0 -188
- package/dist/tests/agent-config-voice.test.cjs +0 -25
- package/dist/tests/agent-config-voice.test.d.ts +0 -1
- package/dist/tests/agent-config-voice.test.js +0 -19
- package/dist/tests/agentInvokerAttachments.test.cjs +0 -190
- package/dist/tests/agentInvokerAttachments.test.d.ts +0 -1
- package/dist/tests/agentInvokerAttachments.test.js +0 -184
- package/dist/tests/agentInvokerSummarization.test.cjs +0 -613
- package/dist/tests/agentInvokerSummarization.test.d.ts +0 -1
- package/dist/tests/agentInvokerSummarization.test.js +0 -607
- package/dist/tests/agentInvokerTokenUsage.test.cjs +0 -124
- package/dist/tests/agentInvokerTokenUsage.test.d.ts +0 -1
- package/dist/tests/agentInvokerTokenUsage.test.js +0 -118
- package/dist/tests/agentInvokerWorkdir.test.cjs +0 -150
- package/dist/tests/agentInvokerWorkdir.test.d.ts +0 -1
- package/dist/tests/agentInvokerWorkdir.test.js +0 -122
- package/dist/tests/agents-api.test.cjs +0 -324
- package/dist/tests/agents-api.test.d.ts +0 -1
- package/dist/tests/agents-api.test.js +0 -318
- package/dist/tests/attachments-utils.test.cjs +0 -46
- package/dist/tests/attachments-utils.test.d.ts +0 -1
- package/dist/tests/attachments-utils.test.js +0 -40
- package/dist/tests/browser-command.test.cjs +0 -264
- package/dist/tests/browser-command.test.d.ts +0 -1
- package/dist/tests/browser-command.test.js +0 -258
- package/dist/tests/browser-relay-server.test.cjs +0 -20
- package/dist/tests/browser-relay-server.test.d.ts +0 -1
- package/dist/tests/browser-relay-server.test.js +0 -14
- package/dist/tests/bunSqliteAdapter.test.cjs +0 -265
- package/dist/tests/bunSqliteAdapter.test.d.ts +0 -1
- package/dist/tests/bunSqliteAdapter.test.js +0 -259
- package/dist/tests/candleRange.test.cjs +0 -48
- package/dist/tests/candleRange.test.d.ts +0 -1
- package/dist/tests/candleRange.test.js +0 -42
- package/dist/tests/cli-config-loader.test.cjs +0 -532
- package/dist/tests/cli-config-loader.test.d.ts +0 -1
- package/dist/tests/cli-config-loader.test.js +0 -526
- package/dist/tests/cli-config-warnings.test.cjs +0 -94
- package/dist/tests/cli-config-warnings.test.d.ts +0 -1
- package/dist/tests/cli-config-warnings.test.js +0 -88
- package/dist/tests/cli-init.test.cjs +0 -225
- package/dist/tests/cli-init.test.d.ts +0 -1
- package/dist/tests/cli-init.test.js +0 -219
- package/dist/tests/cli-workspace-root.test.cjs +0 -114
- package/dist/tests/cli-workspace-root.test.d.ts +0 -1
- package/dist/tests/cli-workspace-root.test.js +0 -108
- package/dist/tests/codex-credentials-precedence.test.cjs +0 -94
- package/dist/tests/codex-credentials-precedence.test.d.ts +0 -1
- package/dist/tests/codex-credentials-precedence.test.js +0 -88
- package/dist/tests/codex-provider.test.cjs +0 -383
- package/dist/tests/codex-provider.test.d.ts +0 -1
- package/dist/tests/codex-provider.test.js +0 -377
- package/dist/tests/config-json-schema.test.cjs +0 -37
- package/dist/tests/config-json-schema.test.d.ts +0 -1
- package/dist/tests/config-json-schema.test.js +0 -31
- package/dist/tests/discord-adapter.test.cjs +0 -89
- package/dist/tests/discord-adapter.test.d.ts +0 -1
- package/dist/tests/discord-adapter.test.js +0 -83
- package/dist/tests/falRuntime.test.cjs +0 -78
- package/dist/tests/falRuntime.test.d.ts +0 -1
- package/dist/tests/falRuntime.test.js +0 -72
- package/dist/tests/falSummary.test.cjs +0 -51
- package/dist/tests/falSummary.test.d.ts +0 -1
- package/dist/tests/falSummary.test.js +0 -45
- package/dist/tests/fs-api.test.cjs +0 -138
- package/dist/tests/fs-api.test.d.ts +0 -1
- package/dist/tests/fs-api.test.js +0 -132
- package/dist/tests/gateway-command-workspace.test.cjs +0 -150
- package/dist/tests/gateway-command-workspace.test.d.ts +0 -1
- package/dist/tests/gateway-command-workspace.test.js +0 -144
- package/dist/tests/gateway-http-security.test.cjs +0 -318
- package/dist/tests/gateway-http-security.test.d.ts +0 -1
- package/dist/tests/gateway-http-security.test.js +0 -312
- package/dist/tests/gateway-node-mode.test.cjs +0 -174
- package/dist/tests/gateway-node-mode.test.d.ts +0 -1
- package/dist/tests/gateway-node-mode.test.js +0 -168
- package/dist/tests/gateway-origin-policy.test.cjs +0 -82
- package/dist/tests/gateway-origin-policy.test.d.ts +0 -1
- package/dist/tests/gateway-origin-policy.test.js +0 -76
- package/dist/tests/gateway-request-execution-overrides.test.cjs +0 -42
- package/dist/tests/gateway-request-execution-overrides.test.d.ts +0 -1
- package/dist/tests/gateway-request-execution-overrides.test.js +0 -36
- package/dist/tests/gateway.test.cjs +0 -700
- package/dist/tests/gateway.test.d.ts +0 -1
- package/dist/tests/gateway.test.js +0 -694
- package/dist/tests/hooks-matcher.test.cjs +0 -309
- package/dist/tests/hooks-matcher.test.d.ts +0 -1
- package/dist/tests/hooks-matcher.test.js +0 -303
- package/dist/tests/hooks-merger.test.cjs +0 -528
- package/dist/tests/hooks-merger.test.d.ts +0 -1
- package/dist/tests/hooks-merger.test.js +0 -522
- package/dist/tests/imagePersistence.test.cjs +0 -169
- package/dist/tests/imagePersistence.test.d.ts +0 -1
- package/dist/tests/imagePersistence.test.js +0 -163
- package/dist/tests/integration/agent-invocation.integration.test.cjs +0 -264
- package/dist/tests/integration/agent-invocation.integration.test.d.ts +0 -1
- package/dist/tests/integration/agent-invocation.integration.test.js +0 -258
- package/dist/tests/integration/finnhub-candles.integration.test.cjs +0 -98
- package/dist/tests/integration/finnhub-candles.integration.test.d.ts +0 -1
- package/dist/tests/integration/finnhub-candles.integration.test.js +0 -92
- package/dist/tests/integration/summarization-e2e.integration.test.cjs +0 -127
- package/dist/tests/integration/summarization-e2e.integration.test.d.ts +0 -1
- package/dist/tests/integration/summarization-e2e.integration.test.js +0 -121
- package/dist/tests/logger.test.cjs +0 -353
- package/dist/tests/logger.test.d.ts +0 -1
- package/dist/tests/logger.test.js +0 -347
- package/dist/tests/mediaCompatibilityMiddleware.test.cjs +0 -106
- package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +0 -1
- package/dist/tests/mediaCompatibilityMiddleware.test.js +0 -100
- package/dist/tests/node-tools.test.cjs +0 -77
- package/dist/tests/node-tools.test.d.ts +0 -1
- package/dist/tests/node-tools.test.js +0 -71
- package/dist/tests/nodes-api.test.cjs +0 -86
- package/dist/tests/nodes-api.test.d.ts +0 -1
- package/dist/tests/nodes-api.test.js +0 -80
- package/dist/tests/outputManagerContextSummarized.test.cjs +0 -43
- package/dist/tests/outputManagerContextSummarized.test.d.ts +0 -1
- package/dist/tests/outputManagerContextSummarized.test.js +0 -37
- package/dist/tests/provider-command-codex.test.cjs +0 -57
- package/dist/tests/provider-command-codex.test.d.ts +0 -1
- package/dist/tests/provider-command-codex.test.js +0 -51
- package/dist/tests/routines-api.test.cjs +0 -107
- package/dist/tests/routines-api.test.d.ts +0 -1
- package/dist/tests/routines-api.test.js +0 -101
- package/dist/tests/run-terminal-bench-official-script.test.cjs +0 -61
- package/dist/tests/run-terminal-bench-official-script.test.d.ts +0 -1
- package/dist/tests/run-terminal-bench-official-script.test.js +0 -55
- package/dist/tests/sessionManager-uionly.test.cjs +0 -50
- package/dist/tests/sessionManager-uionly.test.d.ts +0 -1
- package/dist/tests/sessionManager-uionly.test.js +0 -44
- package/dist/tests/sessionMessageAttachments.test.cjs +0 -197
- package/dist/tests/sessionMessageAttachments.test.d.ts +0 -1
- package/dist/tests/sessionMessageAttachments.test.js +0 -191
- package/dist/tests/sessionMessageRole.test.cjs +0 -44
- package/dist/tests/sessionMessageRole.test.d.ts +0 -1
- package/dist/tests/sessionMessageRole.test.js +0 -38
- package/dist/tests/sessionStateMessages.test.cjs +0 -236
- package/dist/tests/sessionStateMessages.test.d.ts +0 -1
- package/dist/tests/sessionStateMessages.test.js +0 -230
- package/dist/tests/sessions-api.test.cjs +0 -250
- package/dist/tests/sessions-api.test.d.ts +0 -1
- package/dist/tests/sessions-api.test.js +0 -244
- package/dist/tests/skill-activation.test.cjs +0 -86
- package/dist/tests/skill-activation.test.d.ts +0 -1
- package/dist/tests/skill-activation.test.js +0 -80
- package/dist/tests/skill-metadata.test.cjs +0 -119
- package/dist/tests/skill-metadata.test.d.ts +0 -1
- package/dist/tests/skill-metadata.test.js +0 -113
- package/dist/tests/skill-repository.test.cjs +0 -469
- package/dist/tests/skill-repository.test.d.ts +0 -1
- package/dist/tests/skill-repository.test.js +0 -463
- package/dist/tests/skill-security-scanner.test.cjs +0 -126
- package/dist/tests/skill-security-scanner.test.d.ts +0 -1
- package/dist/tests/skill-security-scanner.test.js +0 -120
- package/dist/tests/sms-api.test.cjs +0 -183
- package/dist/tests/sms-api.test.d.ts +0 -1
- package/dist/tests/sms-api.test.js +0 -177
- package/dist/tests/sms-commands.test.cjs +0 -90
- package/dist/tests/sms-commands.test.d.ts +0 -1
- package/dist/tests/sms-commands.test.js +0 -84
- package/dist/tests/sms-policy-store.test.cjs +0 -69
- package/dist/tests/sms-policy-store.test.d.ts +0 -1
- package/dist/tests/sms-policy-store.test.js +0 -63
- package/dist/tests/teams-adapter.test.cjs +0 -58
- package/dist/tests/teams-adapter.test.d.ts +0 -1
- package/dist/tests/teams-adapter.test.js +0 -52
- package/dist/tests/technicalIndicators.test.cjs +0 -82
- package/dist/tests/technicalIndicators.test.d.ts +0 -1
- package/dist/tests/technicalIndicators.test.js +0 -76
- package/dist/tests/terminal-bench-adapters-helpers.test.cjs +0 -64
- package/dist/tests/terminal-bench-adapters-helpers.test.d.ts +0 -1
- package/dist/tests/terminal-bench-adapters-helpers.test.js +0 -58
- package/dist/tests/terminal-bench-cleanup.test.cjs +0 -93
- package/dist/tests/terminal-bench-cleanup.test.d.ts +0 -1
- package/dist/tests/terminal-bench-cleanup.test.js +0 -87
- package/dist/tests/terminal-bench-config.test.cjs +0 -62
- package/dist/tests/terminal-bench-config.test.d.ts +0 -1
- package/dist/tests/terminal-bench-config.test.js +0 -56
- package/dist/tests/terminal-bench-official.test.cjs +0 -194
- package/dist/tests/terminal-bench-official.test.d.ts +0 -1
- package/dist/tests/terminal-bench-official.test.js +0 -188
- package/dist/tests/terminal-bench-runner.test.cjs +0 -82
- package/dist/tests/terminal-bench-runner.test.d.ts +0 -1
- package/dist/tests/terminal-bench-runner.test.js +0 -76
- package/dist/tests/terminal-bench-scoring.test.cjs +0 -128
- package/dist/tests/terminal-bench-scoring.test.d.ts +0 -1
- package/dist/tests/terminal-bench-scoring.test.js +0 -122
- package/dist/tests/terminalProbe.test.cjs +0 -45
- package/dist/tests/terminalProbe.test.d.ts +0 -1
- package/dist/tests/terminalProbe.test.js +0 -39
- package/dist/tests/terminalProbeAuth.test.cjs +0 -85
- package/dist/tests/terminalProbeAuth.test.d.ts +0 -1
- package/dist/tests/terminalProbeAuth.test.js +0 -79
- package/dist/tests/toolDisplayHelpers.test.cjs +0 -46
- package/dist/tests/toolDisplayHelpers.test.d.ts +0 -1
- package/dist/tests/toolDisplayHelpers.test.js +0 -40
- package/dist/tests/uv.test.cjs +0 -47
- package/dist/tests/uv.test.d.ts +0 -1
- package/dist/tests/uv.test.js +0 -41
- package/dist/tests/voice-config.test.cjs +0 -35
- package/dist/tests/voice-config.test.d.ts +0 -1
- package/dist/tests/voice-config.test.js +0 -29
- package/dist/tests/websocket-transport.test.cjs +0 -31
- package/dist/tests/websocket-transport.test.d.ts +0 -1
- package/dist/tests/websocket-transport.test.js +0 -25
- package/dist/tests/yahooCandles.test.cjs +0 -111
- package/dist/tests/yahooCandles.test.d.ts +0 -1
- package/dist/tests/yahooCandles.test.js +0 -105
- package/dist/tools/finance/optionsAnalytics.test.cjs +0 -128
- package/dist/tools/finance/optionsAnalytics.test.d.ts +0 -1
- package/dist/tools/finance/optionsAnalytics.test.js +0 -122
- package/dist/webui/assets/index-BMf95nv5.js +0 -215
- package/dist/webui/assets/index-DhJQ8Mbn.css +0 -11
- package/dist/webui/assets/wingman_logo-Cogyt3qm.webp +0 -0
|
@@ -1,194 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __webpack_exports__ = {};
|
|
3
|
-
const messages_namespaceObject = require("@langchain/core/messages");
|
|
4
|
-
const external_vitest_namespaceObject = require("vitest");
|
|
5
|
-
const xaiImageModel_cjs_namespaceObject = require("../config/xaiImageModel.cjs");
|
|
6
|
-
const originalXaiApiKey = process.env.XAI_API_KEY;
|
|
7
|
-
(0, external_vitest_namespaceObject.describe)("NativeXAIImageModel", ()=>{
|
|
8
|
-
(0, external_vitest_namespaceObject.beforeEach)(()=>{
|
|
9
|
-
process.env.XAI_API_KEY = "test-xai-api-key";
|
|
10
|
-
});
|
|
11
|
-
(0, external_vitest_namespaceObject.afterEach)(()=>{
|
|
12
|
-
external_vitest_namespaceObject.vi.unstubAllGlobals();
|
|
13
|
-
external_vitest_namespaceObject.vi.restoreAllMocks();
|
|
14
|
-
if (void 0 === originalXaiApiKey) return void delete process.env.XAI_API_KEY;
|
|
15
|
-
process.env.XAI_API_KEY = originalXaiApiKey;
|
|
16
|
-
});
|
|
17
|
-
(0, external_vitest_namespaceObject.it)("maps xAI image URLs to output_image content blocks", async ()=>{
|
|
18
|
-
const fetchMock = external_vitest_namespaceObject.vi.fn(async ()=>new Response(JSON.stringify({
|
|
19
|
-
data: [
|
|
20
|
-
{
|
|
21
|
-
url: "https://cdn.example.com/generated.png"
|
|
22
|
-
}
|
|
23
|
-
]
|
|
24
|
-
}), {
|
|
25
|
-
status: 200,
|
|
26
|
-
headers: {
|
|
27
|
-
"Content-Type": "application/json"
|
|
28
|
-
}
|
|
29
|
-
}));
|
|
30
|
-
external_vitest_namespaceObject.vi.stubGlobal("fetch", fetchMock);
|
|
31
|
-
const model = new xaiImageModel_cjs_namespaceObject.NativeXAIImageModel({
|
|
32
|
-
model: "grok-imagine-image",
|
|
33
|
-
apiKey: process.env.XAI_API_KEY
|
|
34
|
-
});
|
|
35
|
-
const result = await model.invoke([
|
|
36
|
-
new messages_namespaceObject.SystemMessage("Always prioritize cinematic composition."),
|
|
37
|
-
new messages_namespaceObject.HumanMessage("A floating city at sunset")
|
|
38
|
-
]);
|
|
39
|
-
const content = result.content;
|
|
40
|
-
(0, external_vitest_namespaceObject.expect)(Array.isArray(content)).toBe(true);
|
|
41
|
-
(0, external_vitest_namespaceObject.expect)(content).toEqual(external_vitest_namespaceObject.expect.arrayContaining([
|
|
42
|
-
external_vitest_namespaceObject.expect.objectContaining({
|
|
43
|
-
type: "output_image",
|
|
44
|
-
image_url: "https://cdn.example.com/generated.png"
|
|
45
|
-
})
|
|
46
|
-
]));
|
|
47
|
-
(0, external_vitest_namespaceObject.expect)(fetchMock).toHaveBeenCalledTimes(1);
|
|
48
|
-
const firstCall = fetchMock.mock.calls[0];
|
|
49
|
-
(0, external_vitest_namespaceObject.expect)(firstCall).toBeDefined();
|
|
50
|
-
const [endpoint, init] = firstCall;
|
|
51
|
-
const headers = init?.headers && "object" == typeof init.headers ? init.headers : {};
|
|
52
|
-
(0, external_vitest_namespaceObject.expect)(endpoint).toBe("https://api.x.ai/v1/images/generations");
|
|
53
|
-
(0, external_vitest_namespaceObject.expect)(headers.Authorization).toBe("Bearer test-xai-api-key");
|
|
54
|
-
const rawBody = "string" == typeof init.body ? init.body : "{}";
|
|
55
|
-
const body = JSON.parse(rawBody);
|
|
56
|
-
(0, external_vitest_namespaceObject.expect)(body.model).toBe("grok-imagine-image");
|
|
57
|
-
(0, external_vitest_namespaceObject.expect)(String(body.prompt || "")).toContain("A floating city at sunset");
|
|
58
|
-
});
|
|
59
|
-
(0, external_vitest_namespaceObject.it)("maps b64_json responses to data URLs", async ()=>{
|
|
60
|
-
const fetchMock = external_vitest_namespaceObject.vi.fn(async ()=>new Response(JSON.stringify({
|
|
61
|
-
data: [
|
|
62
|
-
{
|
|
63
|
-
b64_json: "abc123",
|
|
64
|
-
mime_type: "image/jpeg"
|
|
65
|
-
}
|
|
66
|
-
]
|
|
67
|
-
}), {
|
|
68
|
-
status: 200,
|
|
69
|
-
headers: {
|
|
70
|
-
"Content-Type": "application/json"
|
|
71
|
-
}
|
|
72
|
-
}));
|
|
73
|
-
external_vitest_namespaceObject.vi.stubGlobal("fetch", fetchMock);
|
|
74
|
-
const model = new xaiImageModel_cjs_namespaceObject.NativeXAIImageModel({
|
|
75
|
-
model: "grok-imagine-image",
|
|
76
|
-
apiKey: process.env.XAI_API_KEY
|
|
77
|
-
});
|
|
78
|
-
const result = await model.invoke("Retro arcade poster");
|
|
79
|
-
const content = result.content;
|
|
80
|
-
const imageBlock = content.find((entry)=>"output_image" === entry.type);
|
|
81
|
-
(0, external_vitest_namespaceObject.expect)(imageBlock).toBeDefined();
|
|
82
|
-
(0, external_vitest_namespaceObject.expect)(String(imageBlock?.image_url || "")).toBe("data:image/jpeg;base64,abc123");
|
|
83
|
-
});
|
|
84
|
-
(0, external_vitest_namespaceObject.it)("surfaces xAI API error messages", async ()=>{
|
|
85
|
-
const fetchMock = external_vitest_namespaceObject.vi.fn(async ()=>new Response(JSON.stringify({
|
|
86
|
-
error: {
|
|
87
|
-
message: "Model does not support this endpoint"
|
|
88
|
-
}
|
|
89
|
-
}), {
|
|
90
|
-
status: 400,
|
|
91
|
-
headers: {
|
|
92
|
-
"Content-Type": "application/json"
|
|
93
|
-
}
|
|
94
|
-
}));
|
|
95
|
-
external_vitest_namespaceObject.vi.stubGlobal("fetch", fetchMock);
|
|
96
|
-
const model = new xaiImageModel_cjs_namespaceObject.NativeXAIImageModel({
|
|
97
|
-
model: "grok-imagine-image",
|
|
98
|
-
apiKey: process.env.XAI_API_KEY
|
|
99
|
-
});
|
|
100
|
-
await (0, external_vitest_namespaceObject.expect)(model.invoke("Generate a hero banner")).rejects.toThrow(/Model does not support this endpoint/i);
|
|
101
|
-
});
|
|
102
|
-
(0, external_vitest_namespaceObject.it)("fails fast when xAI credentials are missing", async ()=>{
|
|
103
|
-
const fetchMock = external_vitest_namespaceObject.vi.fn();
|
|
104
|
-
external_vitest_namespaceObject.vi.stubGlobal("fetch", fetchMock);
|
|
105
|
-
const model = new xaiImageModel_cjs_namespaceObject.NativeXAIImageModel({
|
|
106
|
-
model: "grok-imagine-image"
|
|
107
|
-
});
|
|
108
|
-
await (0, external_vitest_namespaceObject.expect)(model.invoke("Generate a logo")).rejects.toThrow(/Missing xAI credentials/i);
|
|
109
|
-
(0, external_vitest_namespaceObject.expect)(fetchMock).not.toHaveBeenCalled();
|
|
110
|
-
});
|
|
111
|
-
(0, external_vitest_namespaceObject.it)("supports no-op bindTools for LangGraph compatibility", ()=>{
|
|
112
|
-
const model = new xaiImageModel_cjs_namespaceObject.NativeXAIImageModel({
|
|
113
|
-
model: "grok-imagine-image",
|
|
114
|
-
apiKey: process.env.XAI_API_KEY
|
|
115
|
-
});
|
|
116
|
-
const bound = model.bindTools([]);
|
|
117
|
-
(0, external_vitest_namespaceObject.expect)(bound).toBe(model);
|
|
118
|
-
});
|
|
119
|
-
(0, external_vitest_namespaceObject.it)("ignores hidden middleware user prompts when building xAI image input", async ()=>{
|
|
120
|
-
const fetchMock = external_vitest_namespaceObject.vi.fn(async ()=>new Response(JSON.stringify({
|
|
121
|
-
data: [
|
|
122
|
-
{
|
|
123
|
-
url: "https://cdn.example.com/generated.png"
|
|
124
|
-
}
|
|
125
|
-
]
|
|
126
|
-
}), {
|
|
127
|
-
status: 200,
|
|
128
|
-
headers: {
|
|
129
|
-
"Content-Type": "application/json"
|
|
130
|
-
}
|
|
131
|
-
}));
|
|
132
|
-
external_vitest_namespaceObject.vi.stubGlobal("fetch", fetchMock);
|
|
133
|
-
const model = new xaiImageModel_cjs_namespaceObject.NativeXAIImageModel({
|
|
134
|
-
model: "grok-imagine-image",
|
|
135
|
-
apiKey: process.env.XAI_API_KEY
|
|
136
|
-
});
|
|
137
|
-
await model.invoke([
|
|
138
|
-
new messages_namespaceObject.HumanMessage("hi"),
|
|
139
|
-
new messages_namespaceObject.HumanMessage({
|
|
140
|
-
content: "# Confidentiality (Internal)\n** Current Date Time (UTC): 2026-03-01T20:57:29.433Z **\n** Dynamic UI Registry **",
|
|
141
|
-
additional_kwargs: {
|
|
142
|
-
ui_hidden: true,
|
|
143
|
-
source: "additional-message-middleware"
|
|
144
|
-
}
|
|
145
|
-
})
|
|
146
|
-
]);
|
|
147
|
-
(0, external_vitest_namespaceObject.expect)(fetchMock).toHaveBeenCalledTimes(1);
|
|
148
|
-
const firstCall = fetchMock.mock.calls[0];
|
|
149
|
-
(0, external_vitest_namespaceObject.expect)(firstCall).toBeDefined();
|
|
150
|
-
const [, init] = firstCall;
|
|
151
|
-
const rawBody = "string" == typeof init.body ? init.body : "{}";
|
|
152
|
-
const body = JSON.parse(rawBody);
|
|
153
|
-
const prompt = String(body.prompt || "");
|
|
154
|
-
(0, external_vitest_namespaceObject.expect)(prompt).toContain("hi");
|
|
155
|
-
(0, external_vitest_namespaceObject.expect)(prompt.toLowerCase()).not.toContain("# confidentiality (internal)");
|
|
156
|
-
(0, external_vitest_namespaceObject.expect)(prompt.toLowerCase()).not.toContain("dynamic ui registry");
|
|
157
|
-
});
|
|
158
|
-
(0, external_vitest_namespaceObject.it)("clamps oversized prompts to xAI-compatible length", async ()=>{
|
|
159
|
-
const fetchMock = external_vitest_namespaceObject.vi.fn(async ()=>new Response(JSON.stringify({
|
|
160
|
-
data: [
|
|
161
|
-
{
|
|
162
|
-
url: "https://cdn.example.com/generated.png"
|
|
163
|
-
}
|
|
164
|
-
]
|
|
165
|
-
}), {
|
|
166
|
-
status: 200,
|
|
167
|
-
headers: {
|
|
168
|
-
"Content-Type": "application/json"
|
|
169
|
-
}
|
|
170
|
-
}));
|
|
171
|
-
external_vitest_namespaceObject.vi.stubGlobal("fetch", fetchMock);
|
|
172
|
-
const model = new xaiImageModel_cjs_namespaceObject.NativeXAIImageModel({
|
|
173
|
-
model: "grok-imagine-image",
|
|
174
|
-
apiKey: process.env.XAI_API_KEY
|
|
175
|
-
});
|
|
176
|
-
await model.invoke([
|
|
177
|
-
new messages_namespaceObject.SystemMessage("S".repeat(20000)),
|
|
178
|
-
new messages_namespaceObject.HumanMessage("hi")
|
|
179
|
-
]);
|
|
180
|
-
(0, external_vitest_namespaceObject.expect)(fetchMock).toHaveBeenCalledTimes(1);
|
|
181
|
-
const firstCall = fetchMock.mock.calls[0];
|
|
182
|
-
(0, external_vitest_namespaceObject.expect)(firstCall).toBeDefined();
|
|
183
|
-
const [, init] = firstCall;
|
|
184
|
-
const rawBody = "string" == typeof init.body ? init.body : "{}";
|
|
185
|
-
const body = JSON.parse(rawBody);
|
|
186
|
-
const prompt = String(body.prompt || "");
|
|
187
|
-
(0, external_vitest_namespaceObject.expect)(prompt.length).toBeLessThanOrEqual(7900);
|
|
188
|
-
(0, external_vitest_namespaceObject.expect)(prompt).toContain("User request:\nhi");
|
|
189
|
-
});
|
|
190
|
-
});
|
|
191
|
-
for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
192
|
-
Object.defineProperty(exports, '__esModule', {
|
|
193
|
-
value: true
|
|
194
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,188 +0,0 @@
|
|
|
1
|
-
import { HumanMessage, SystemMessage } from "@langchain/core/messages";
|
|
2
|
-
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
3
|
-
import { NativeXAIImageModel } from "../config/xaiImageModel.js";
|
|
4
|
-
const originalXaiApiKey = process.env.XAI_API_KEY;
|
|
5
|
-
describe("NativeXAIImageModel", ()=>{
|
|
6
|
-
beforeEach(()=>{
|
|
7
|
-
process.env.XAI_API_KEY = "test-xai-api-key";
|
|
8
|
-
});
|
|
9
|
-
afterEach(()=>{
|
|
10
|
-
vi.unstubAllGlobals();
|
|
11
|
-
vi.restoreAllMocks();
|
|
12
|
-
if (void 0 === originalXaiApiKey) return void delete process.env.XAI_API_KEY;
|
|
13
|
-
process.env.XAI_API_KEY = originalXaiApiKey;
|
|
14
|
-
});
|
|
15
|
-
it("maps xAI image URLs to output_image content blocks", async ()=>{
|
|
16
|
-
const fetchMock = vi.fn(async ()=>new Response(JSON.stringify({
|
|
17
|
-
data: [
|
|
18
|
-
{
|
|
19
|
-
url: "https://cdn.example.com/generated.png"
|
|
20
|
-
}
|
|
21
|
-
]
|
|
22
|
-
}), {
|
|
23
|
-
status: 200,
|
|
24
|
-
headers: {
|
|
25
|
-
"Content-Type": "application/json"
|
|
26
|
-
}
|
|
27
|
-
}));
|
|
28
|
-
vi.stubGlobal("fetch", fetchMock);
|
|
29
|
-
const model = new NativeXAIImageModel({
|
|
30
|
-
model: "grok-imagine-image",
|
|
31
|
-
apiKey: process.env.XAI_API_KEY
|
|
32
|
-
});
|
|
33
|
-
const result = await model.invoke([
|
|
34
|
-
new SystemMessage("Always prioritize cinematic composition."),
|
|
35
|
-
new HumanMessage("A floating city at sunset")
|
|
36
|
-
]);
|
|
37
|
-
const content = result.content;
|
|
38
|
-
expect(Array.isArray(content)).toBe(true);
|
|
39
|
-
expect(content).toEqual(expect.arrayContaining([
|
|
40
|
-
expect.objectContaining({
|
|
41
|
-
type: "output_image",
|
|
42
|
-
image_url: "https://cdn.example.com/generated.png"
|
|
43
|
-
})
|
|
44
|
-
]));
|
|
45
|
-
expect(fetchMock).toHaveBeenCalledTimes(1);
|
|
46
|
-
const firstCall = fetchMock.mock.calls[0];
|
|
47
|
-
expect(firstCall).toBeDefined();
|
|
48
|
-
const [endpoint, init] = firstCall;
|
|
49
|
-
const headers = init?.headers && "object" == typeof init.headers ? init.headers : {};
|
|
50
|
-
expect(endpoint).toBe("https://api.x.ai/v1/images/generations");
|
|
51
|
-
expect(headers.Authorization).toBe("Bearer test-xai-api-key");
|
|
52
|
-
const rawBody = "string" == typeof init.body ? init.body : "{}";
|
|
53
|
-
const body = JSON.parse(rawBody);
|
|
54
|
-
expect(body.model).toBe("grok-imagine-image");
|
|
55
|
-
expect(String(body.prompt || "")).toContain("A floating city at sunset");
|
|
56
|
-
});
|
|
57
|
-
it("maps b64_json responses to data URLs", async ()=>{
|
|
58
|
-
const fetchMock = vi.fn(async ()=>new Response(JSON.stringify({
|
|
59
|
-
data: [
|
|
60
|
-
{
|
|
61
|
-
b64_json: "abc123",
|
|
62
|
-
mime_type: "image/jpeg"
|
|
63
|
-
}
|
|
64
|
-
]
|
|
65
|
-
}), {
|
|
66
|
-
status: 200,
|
|
67
|
-
headers: {
|
|
68
|
-
"Content-Type": "application/json"
|
|
69
|
-
}
|
|
70
|
-
}));
|
|
71
|
-
vi.stubGlobal("fetch", fetchMock);
|
|
72
|
-
const model = new NativeXAIImageModel({
|
|
73
|
-
model: "grok-imagine-image",
|
|
74
|
-
apiKey: process.env.XAI_API_KEY
|
|
75
|
-
});
|
|
76
|
-
const result = await model.invoke("Retro arcade poster");
|
|
77
|
-
const content = result.content;
|
|
78
|
-
const imageBlock = content.find((entry)=>"output_image" === entry.type);
|
|
79
|
-
expect(imageBlock).toBeDefined();
|
|
80
|
-
expect(String(imageBlock?.image_url || "")).toBe("data:image/jpeg;base64,abc123");
|
|
81
|
-
});
|
|
82
|
-
it("surfaces xAI API error messages", async ()=>{
|
|
83
|
-
const fetchMock = vi.fn(async ()=>new Response(JSON.stringify({
|
|
84
|
-
error: {
|
|
85
|
-
message: "Model does not support this endpoint"
|
|
86
|
-
}
|
|
87
|
-
}), {
|
|
88
|
-
status: 400,
|
|
89
|
-
headers: {
|
|
90
|
-
"Content-Type": "application/json"
|
|
91
|
-
}
|
|
92
|
-
}));
|
|
93
|
-
vi.stubGlobal("fetch", fetchMock);
|
|
94
|
-
const model = new NativeXAIImageModel({
|
|
95
|
-
model: "grok-imagine-image",
|
|
96
|
-
apiKey: process.env.XAI_API_KEY
|
|
97
|
-
});
|
|
98
|
-
await expect(model.invoke("Generate a hero banner")).rejects.toThrow(/Model does not support this endpoint/i);
|
|
99
|
-
});
|
|
100
|
-
it("fails fast when xAI credentials are missing", async ()=>{
|
|
101
|
-
const fetchMock = vi.fn();
|
|
102
|
-
vi.stubGlobal("fetch", fetchMock);
|
|
103
|
-
const model = new NativeXAIImageModel({
|
|
104
|
-
model: "grok-imagine-image"
|
|
105
|
-
});
|
|
106
|
-
await expect(model.invoke("Generate a logo")).rejects.toThrow(/Missing xAI credentials/i);
|
|
107
|
-
expect(fetchMock).not.toHaveBeenCalled();
|
|
108
|
-
});
|
|
109
|
-
it("supports no-op bindTools for LangGraph compatibility", ()=>{
|
|
110
|
-
const model = new NativeXAIImageModel({
|
|
111
|
-
model: "grok-imagine-image",
|
|
112
|
-
apiKey: process.env.XAI_API_KEY
|
|
113
|
-
});
|
|
114
|
-
const bound = model.bindTools([]);
|
|
115
|
-
expect(bound).toBe(model);
|
|
116
|
-
});
|
|
117
|
-
it("ignores hidden middleware user prompts when building xAI image input", async ()=>{
|
|
118
|
-
const fetchMock = vi.fn(async ()=>new Response(JSON.stringify({
|
|
119
|
-
data: [
|
|
120
|
-
{
|
|
121
|
-
url: "https://cdn.example.com/generated.png"
|
|
122
|
-
}
|
|
123
|
-
]
|
|
124
|
-
}), {
|
|
125
|
-
status: 200,
|
|
126
|
-
headers: {
|
|
127
|
-
"Content-Type": "application/json"
|
|
128
|
-
}
|
|
129
|
-
}));
|
|
130
|
-
vi.stubGlobal("fetch", fetchMock);
|
|
131
|
-
const model = new NativeXAIImageModel({
|
|
132
|
-
model: "grok-imagine-image",
|
|
133
|
-
apiKey: process.env.XAI_API_KEY
|
|
134
|
-
});
|
|
135
|
-
await model.invoke([
|
|
136
|
-
new HumanMessage("hi"),
|
|
137
|
-
new HumanMessage({
|
|
138
|
-
content: "# Confidentiality (Internal)\n** Current Date Time (UTC): 2026-03-01T20:57:29.433Z **\n** Dynamic UI Registry **",
|
|
139
|
-
additional_kwargs: {
|
|
140
|
-
ui_hidden: true,
|
|
141
|
-
source: "additional-message-middleware"
|
|
142
|
-
}
|
|
143
|
-
})
|
|
144
|
-
]);
|
|
145
|
-
expect(fetchMock).toHaveBeenCalledTimes(1);
|
|
146
|
-
const firstCall = fetchMock.mock.calls[0];
|
|
147
|
-
expect(firstCall).toBeDefined();
|
|
148
|
-
const [, init] = firstCall;
|
|
149
|
-
const rawBody = "string" == typeof init.body ? init.body : "{}";
|
|
150
|
-
const body = JSON.parse(rawBody);
|
|
151
|
-
const prompt = String(body.prompt || "");
|
|
152
|
-
expect(prompt).toContain("hi");
|
|
153
|
-
expect(prompt.toLowerCase()).not.toContain("# confidentiality (internal)");
|
|
154
|
-
expect(prompt.toLowerCase()).not.toContain("dynamic ui registry");
|
|
155
|
-
});
|
|
156
|
-
it("clamps oversized prompts to xAI-compatible length", async ()=>{
|
|
157
|
-
const fetchMock = vi.fn(async ()=>new Response(JSON.stringify({
|
|
158
|
-
data: [
|
|
159
|
-
{
|
|
160
|
-
url: "https://cdn.example.com/generated.png"
|
|
161
|
-
}
|
|
162
|
-
]
|
|
163
|
-
}), {
|
|
164
|
-
status: 200,
|
|
165
|
-
headers: {
|
|
166
|
-
"Content-Type": "application/json"
|
|
167
|
-
}
|
|
168
|
-
}));
|
|
169
|
-
vi.stubGlobal("fetch", fetchMock);
|
|
170
|
-
const model = new NativeXAIImageModel({
|
|
171
|
-
model: "grok-imagine-image",
|
|
172
|
-
apiKey: process.env.XAI_API_KEY
|
|
173
|
-
});
|
|
174
|
-
await model.invoke([
|
|
175
|
-
new SystemMessage("S".repeat(20000)),
|
|
176
|
-
new HumanMessage("hi")
|
|
177
|
-
]);
|
|
178
|
-
expect(fetchMock).toHaveBeenCalledTimes(1);
|
|
179
|
-
const firstCall = fetchMock.mock.calls[0];
|
|
180
|
-
expect(firstCall).toBeDefined();
|
|
181
|
-
const [, init] = firstCall;
|
|
182
|
-
const rawBody = "string" == typeof init.body ? init.body : "{}";
|
|
183
|
-
const body = JSON.parse(rawBody);
|
|
184
|
-
const prompt = String(body.prompt || "");
|
|
185
|
-
expect(prompt.length).toBeLessThanOrEqual(7900);
|
|
186
|
-
expect(prompt).toContain("User request:\nhi");
|
|
187
|
-
});
|
|
188
|
-
});
|
|
@@ -1,216 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __webpack_require__ = {};
|
|
3
|
-
(()=>{
|
|
4
|
-
__webpack_require__.n = (module)=>{
|
|
5
|
-
var getter = module && module.__esModule ? ()=>module['default'] : ()=>module;
|
|
6
|
-
__webpack_require__.d(getter, {
|
|
7
|
-
a: getter
|
|
8
|
-
});
|
|
9
|
-
return getter;
|
|
10
|
-
};
|
|
11
|
-
})();
|
|
12
|
-
(()=>{
|
|
13
|
-
__webpack_require__.d = (exports1, definition)=>{
|
|
14
|
-
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
15
|
-
enumerable: true,
|
|
16
|
-
get: definition[key]
|
|
17
|
-
});
|
|
18
|
-
};
|
|
19
|
-
})();
|
|
20
|
-
(()=>{
|
|
21
|
-
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
22
|
-
})();
|
|
23
|
-
var __webpack_exports__ = {};
|
|
24
|
-
const external_node_path_namespaceObject = require("node:path");
|
|
25
|
-
var external_node_path_default = /*#__PURE__*/ __webpack_require__.n(external_node_path_namespaceObject);
|
|
26
|
-
const external_vitest_namespaceObject = require("vitest");
|
|
27
|
-
const external_langchain_namespaceObject = require("langchain");
|
|
28
|
-
const additional_messages_cjs_namespaceObject = require("../agent/middleware/additional-messages.cjs");
|
|
29
|
-
(0, external_vitest_namespaceObject.describe)("additionalMessageMiddleware", ()=>{
|
|
30
|
-
(0, external_vitest_namespaceObject.it)("injects the additional message when missing", async ()=>{
|
|
31
|
-
const middleware = (0, additional_messages_cjs_namespaceObject.additionalMessageMiddleware)();
|
|
32
|
-
const input = {
|
|
33
|
-
messages: [
|
|
34
|
-
new external_langchain_namespaceObject.HumanMessage("Hello")
|
|
35
|
-
]
|
|
36
|
-
};
|
|
37
|
-
const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
|
|
38
|
-
if (!beforeAgent) throw new Error("beforeAgent hook not configured");
|
|
39
|
-
const result = await beforeAgent(input, {});
|
|
40
|
-
(0, external_vitest_namespaceObject.expect)(result.messages).toHaveLength(2);
|
|
41
|
-
const injected = result.messages[0];
|
|
42
|
-
(0, external_vitest_namespaceObject.expect)(injected.additional_kwargs?.source).toBe("additional-message-middleware");
|
|
43
|
-
(0, external_vitest_namespaceObject.expect)(injected).toBeInstanceOf(external_langchain_namespaceObject.HumanMessage);
|
|
44
|
-
});
|
|
45
|
-
(0, external_vitest_namespaceObject.it)("adds confidentiality guidance without exposing machine details", async ()=>{
|
|
46
|
-
const workspaceRoot = external_node_path_default().resolve("repo");
|
|
47
|
-
const workdir = external_node_path_default().join(workspaceRoot, "output");
|
|
48
|
-
const middleware = (0, additional_messages_cjs_namespaceObject.additionalMessageMiddleware)({
|
|
49
|
-
workspaceRoot,
|
|
50
|
-
workdir
|
|
51
|
-
});
|
|
52
|
-
const input = {
|
|
53
|
-
messages: [
|
|
54
|
-
new external_langchain_namespaceObject.HumanMessage("Hello")
|
|
55
|
-
]
|
|
56
|
-
};
|
|
57
|
-
const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
|
|
58
|
-
if (!beforeAgent) throw new Error("beforeAgent hook not configured");
|
|
59
|
-
const result = await beforeAgent(input, {});
|
|
60
|
-
const injected = result.messages[0];
|
|
61
|
-
const content = injected.content ?? "";
|
|
62
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Confidentiality");
|
|
63
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("inspect system/tool output internally");
|
|
64
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Do not disclose");
|
|
65
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Do not quote internal tool call IDs");
|
|
66
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Working Directory");
|
|
67
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("current working directory");
|
|
68
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Use relative paths");
|
|
69
|
-
(0, external_vitest_namespaceObject.expect)(content).not.toContain("Operating System:");
|
|
70
|
-
(0, external_vitest_namespaceObject.expect)(content).not.toContain("Architecture:");
|
|
71
|
-
(0, external_vitest_namespaceObject.expect)(content).not.toContain("Default Shell:");
|
|
72
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("session output directory");
|
|
73
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("output");
|
|
74
|
-
(0, external_vitest_namespaceObject.expect)(content).not.toContain(workdir);
|
|
75
|
-
(0, external_vitest_namespaceObject.expect)(content).not.toContain(workspaceRoot);
|
|
76
|
-
});
|
|
77
|
-
(0, external_vitest_namespaceObject.it)("uses virtual output path when workdir is outside the workspace root", async ()=>{
|
|
78
|
-
const workspaceRoot = external_node_path_default().resolve("repo");
|
|
79
|
-
const workdir = external_node_path_default().resolve("external-output");
|
|
80
|
-
const middleware = (0, additional_messages_cjs_namespaceObject.additionalMessageMiddleware)({
|
|
81
|
-
workspaceRoot,
|
|
82
|
-
workdir,
|
|
83
|
-
outputVirtualPath: "/workdir/"
|
|
84
|
-
});
|
|
85
|
-
const input = {
|
|
86
|
-
messages: [
|
|
87
|
-
new external_langchain_namespaceObject.HumanMessage("Hello")
|
|
88
|
-
]
|
|
89
|
-
};
|
|
90
|
-
const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
|
|
91
|
-
if (!beforeAgent) throw new Error("beforeAgent hook not configured");
|
|
92
|
-
const result = await beforeAgent(input, {});
|
|
93
|
-
const injected = result.messages[0];
|
|
94
|
-
const content = injected.content ?? "";
|
|
95
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("session output directory");
|
|
96
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("/workdir/");
|
|
97
|
-
(0, external_vitest_namespaceObject.expect)(content).not.toContain("(path hidden)");
|
|
98
|
-
(0, external_vitest_namespaceObject.expect)(content).not.toContain(workdir);
|
|
99
|
-
});
|
|
100
|
-
(0, external_vitest_namespaceObject.it)("does not inject the additional message twice", async ()=>{
|
|
101
|
-
const middleware = (0, additional_messages_cjs_namespaceObject.additionalMessageMiddleware)();
|
|
102
|
-
const input = {
|
|
103
|
-
messages: [
|
|
104
|
-
new external_langchain_namespaceObject.HumanMessage("Hello")
|
|
105
|
-
]
|
|
106
|
-
};
|
|
107
|
-
const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
|
|
108
|
-
if (!beforeAgent) throw new Error("beforeAgent hook not configured");
|
|
109
|
-
const first = await beforeAgent(input, {});
|
|
110
|
-
const second = await beforeAgent({
|
|
111
|
-
messages: first.messages
|
|
112
|
-
}, {});
|
|
113
|
-
const messages = second.messages;
|
|
114
|
-
const injectedCount = messages.filter((message)=>{
|
|
115
|
-
const source = message.additional_kwargs?.source;
|
|
116
|
-
return "additional-message-middleware" === source;
|
|
117
|
-
}).length;
|
|
118
|
-
(0, external_vitest_namespaceObject.expect)(injectedCount).toBe(1);
|
|
119
|
-
});
|
|
120
|
-
(0, external_vitest_namespaceObject.it)("refreshes injected node context on each invocation", async ()=>{
|
|
121
|
-
let connectedIds = [
|
|
122
|
-
"node-a"
|
|
123
|
-
];
|
|
124
|
-
const middleware = (0, additional_messages_cjs_namespaceObject.additionalMessageMiddleware)({
|
|
125
|
-
nodeConnectedIdsProvider: ()=>connectedIds
|
|
126
|
-
});
|
|
127
|
-
const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
|
|
128
|
-
if (!beforeAgent) throw new Error("beforeAgent hook not configured");
|
|
129
|
-
const first = await beforeAgent({
|
|
130
|
-
messages: [
|
|
131
|
-
new external_langchain_namespaceObject.HumanMessage("Hello")
|
|
132
|
-
]
|
|
133
|
-
}, {});
|
|
134
|
-
const firstContent = first.messages[0]?.content ?? "";
|
|
135
|
-
(0, external_vitest_namespaceObject.expect)(firstContent).toContain("Connected node IDs: node-a");
|
|
136
|
-
connectedIds = [
|
|
137
|
-
"node-b"
|
|
138
|
-
];
|
|
139
|
-
const second = await beforeAgent({
|
|
140
|
-
messages: first.messages
|
|
141
|
-
}, {});
|
|
142
|
-
const secondContent = second.messages[0]?.content ?? "";
|
|
143
|
-
(0, external_vitest_namespaceObject.expect)(secondContent).toContain("Connected node IDs: node-b");
|
|
144
|
-
(0, external_vitest_namespaceObject.expect)(secondContent).not.toContain("Connected node IDs: node-a");
|
|
145
|
-
});
|
|
146
|
-
(0, external_vitest_namespaceObject.it)("injects connected node IDs for node tool targeting when provided", async ()=>{
|
|
147
|
-
const middleware = (0, additional_messages_cjs_namespaceObject.additionalMessageMiddleware)({
|
|
148
|
-
nodeConnectedIdsProvider: ()=>[
|
|
149
|
-
"node-b",
|
|
150
|
-
"node-a",
|
|
151
|
-
"",
|
|
152
|
-
"node-b"
|
|
153
|
-
]
|
|
154
|
-
});
|
|
155
|
-
const input = {
|
|
156
|
-
messages: [
|
|
157
|
-
new external_langchain_namespaceObject.HumanMessage("Hello")
|
|
158
|
-
]
|
|
159
|
-
};
|
|
160
|
-
const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
|
|
161
|
-
if (!beforeAgent) throw new Error("beforeAgent hook not configured");
|
|
162
|
-
const result = await beforeAgent(input, {});
|
|
163
|
-
const content = result.messages[0]?.content ?? "";
|
|
164
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Connected Node Targets");
|
|
165
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Connected node IDs: node-b, node-a");
|
|
166
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("target.nodeId or target.clientId");
|
|
167
|
-
});
|
|
168
|
-
(0, external_vitest_namespaceObject.it)("injects default node target clientId when present", async ()=>{
|
|
169
|
-
const middleware = (0, additional_messages_cjs_namespaceObject.additionalMessageMiddleware)({
|
|
170
|
-
nodeConnectedIdsProvider: ()=>[],
|
|
171
|
-
defaultNodeTargetClientId: "desktop-abc123"
|
|
172
|
-
});
|
|
173
|
-
const input = {
|
|
174
|
-
messages: [
|
|
175
|
-
new external_langchain_namespaceObject.HumanMessage("Hello")
|
|
176
|
-
]
|
|
177
|
-
};
|
|
178
|
-
const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
|
|
179
|
-
if (!beforeAgent) throw new Error("beforeAgent hook not configured");
|
|
180
|
-
const result = await beforeAgent(input, {});
|
|
181
|
-
const content = result.messages[0]?.content ?? "";
|
|
182
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Connected node IDs: (none currently connected)");
|
|
183
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Default node target clientId for this request: desktop-abc123");
|
|
184
|
-
});
|
|
185
|
-
(0, external_vitest_namespaceObject.it)("injects connected node metadata when provided", async ()=>{
|
|
186
|
-
const middleware = (0, additional_messages_cjs_namespaceObject.additionalMessageMiddleware)({
|
|
187
|
-
nodeConnectedTargetsProvider: ()=>[
|
|
188
|
-
{
|
|
189
|
-
nodeId: "node-a",
|
|
190
|
-
clientId: "desktop-a",
|
|
191
|
-
name: "Russell MacBook",
|
|
192
|
-
capabilities: [
|
|
193
|
-
"system.notify",
|
|
194
|
-
"system.run"
|
|
195
|
-
]
|
|
196
|
-
}
|
|
197
|
-
]
|
|
198
|
-
});
|
|
199
|
-
const input = {
|
|
200
|
-
messages: [
|
|
201
|
-
new external_langchain_namespaceObject.HumanMessage("Hello")
|
|
202
|
-
]
|
|
203
|
-
};
|
|
204
|
-
const beforeAgent = "function" == typeof middleware.beforeAgent ? middleware.beforeAgent : middleware.beforeAgent?.hook;
|
|
205
|
-
if (!beforeAgent) throw new Error("beforeAgent hook not configured");
|
|
206
|
-
const result = await beforeAgent(input, {});
|
|
207
|
-
const content = result.messages[0]?.content ?? "";
|
|
208
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("Connected node metadata:");
|
|
209
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("node-a (clientId: desktop-a; name: Russell MacBook;");
|
|
210
|
-
(0, external_vitest_namespaceObject.expect)(content).toContain("capabilities: system.notify, system.run");
|
|
211
|
-
});
|
|
212
|
-
});
|
|
213
|
-
for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
214
|
-
Object.defineProperty(exports, '__esModule', {
|
|
215
|
-
value: true
|
|
216
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|