@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,184 +0,0 @@
|
|
|
1
|
-
import { ChatAnthropic } from "@langchain/anthropic";
|
|
2
|
-
import { ChatOllama } from "@langchain/ollama";
|
|
3
|
-
import { ChatOpenAI } from "@langchain/openai";
|
|
4
|
-
import { ChatXAI } from "@langchain/xai";
|
|
5
|
-
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
6
|
-
import { ModelFactory } from "../config/modelFactory.js";
|
|
7
|
-
import { NativeXAIImageModel } from "../config/xaiImageModel.js";
|
|
8
|
-
const originalAnthropicApiKey = process.env.ANTHROPIC_API_KEY;
|
|
9
|
-
const originalXaiApiKey = process.env.XAI_API_KEY;
|
|
10
|
-
beforeEach(()=>{
|
|
11
|
-
process.env.ANTHROPIC_API_KEY = "test-anthropic-api-key";
|
|
12
|
-
process.env.XAI_API_KEY = "test-xai-api-key";
|
|
13
|
-
});
|
|
14
|
-
afterEach(()=>{
|
|
15
|
-
if (void 0 === originalAnthropicApiKey) delete process.env.ANTHROPIC_API_KEY;
|
|
16
|
-
else process.env.ANTHROPIC_API_KEY = originalAnthropicApiKey;
|
|
17
|
-
if (void 0 === originalXaiApiKey) return void delete process.env.XAI_API_KEY;
|
|
18
|
-
process.env.XAI_API_KEY = originalXaiApiKey;
|
|
19
|
-
});
|
|
20
|
-
describe("ModelFactory", ()=>{
|
|
21
|
-
describe("createModel", ()=>{
|
|
22
|
-
it("should create an Anthropic model", ()=>{
|
|
23
|
-
const model = ModelFactory.createModel("anthropic:claude-opus-4-5");
|
|
24
|
-
expect(model).toBeInstanceOf(ChatAnthropic);
|
|
25
|
-
});
|
|
26
|
-
it("should create an OpenAI model", ()=>{
|
|
27
|
-
const model = ModelFactory.createModel("openai:gpt-4o");
|
|
28
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
29
|
-
});
|
|
30
|
-
it("should create a Codex model", ()=>{
|
|
31
|
-
const model = ModelFactory.createModel("codex:codex-mini-latest");
|
|
32
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
33
|
-
expect(model.useResponsesApi).toBe(true);
|
|
34
|
-
expect(model.zdrEnabled).toBe(true);
|
|
35
|
-
});
|
|
36
|
-
it("should force OpenAI models onto the responses API", ()=>{
|
|
37
|
-
const model = ModelFactory.createModel("openai:gpt-5.2-codex");
|
|
38
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
39
|
-
expect(model.useResponsesApi).toBe(true);
|
|
40
|
-
});
|
|
41
|
-
it("should apply reasoning effort for supported OpenAI reasoning models", ()=>{
|
|
42
|
-
const model = ModelFactory.createModel("openai:gpt-5.2-codex", {
|
|
43
|
-
reasoningEffort: "high"
|
|
44
|
-
});
|
|
45
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
46
|
-
expect(model.reasoning).toEqual({
|
|
47
|
-
effort: "high"
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
it("should ignore reasoning effort for unsupported OpenAI models", ()=>{
|
|
51
|
-
const model = ModelFactory.createModel("openai:gpt-4o", {
|
|
52
|
-
reasoningEffort: "medium"
|
|
53
|
-
});
|
|
54
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
55
|
-
expect(model.reasoning).toBeUndefined();
|
|
56
|
-
});
|
|
57
|
-
it("should map reasoning effort to anthropic thinking budget", ()=>{
|
|
58
|
-
const model = ModelFactory.createModel("anthropic:claude-sonnet-4-5", {
|
|
59
|
-
reasoningEffort: "medium"
|
|
60
|
-
});
|
|
61
|
-
expect(model).toBeInstanceOf(ChatAnthropic);
|
|
62
|
-
expect(model.thinking).toEqual({
|
|
63
|
-
type: "enabled",
|
|
64
|
-
budget_tokens: 4096
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
it("should create an OpenRouter model", ()=>{
|
|
68
|
-
const model = ModelFactory.createModel("openrouter:openai/gpt-4o");
|
|
69
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
70
|
-
});
|
|
71
|
-
it("should ignore reasoning effort for unsupported providers", ()=>{
|
|
72
|
-
const model = ModelFactory.createModel("openrouter:openai/gpt-5", {
|
|
73
|
-
reasoningEffort: "high"
|
|
74
|
-
});
|
|
75
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
76
|
-
expect(model.reasoning).toBeUndefined();
|
|
77
|
-
});
|
|
78
|
-
it("should create a Copilot model", ()=>{
|
|
79
|
-
const model = ModelFactory.createModel("copilot:gpt-4o");
|
|
80
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
81
|
-
});
|
|
82
|
-
it("should create an LMStudio model", ()=>{
|
|
83
|
-
const model = ModelFactory.createModel("lmstudio:llama-3.1-8b");
|
|
84
|
-
expect(model).toBeInstanceOf(ChatOpenAI);
|
|
85
|
-
});
|
|
86
|
-
it("should create an Ollama model", ()=>{
|
|
87
|
-
const model = ModelFactory.createModel("ollama:llama3.2");
|
|
88
|
-
expect(model).toBeInstanceOf(ChatOllama);
|
|
89
|
-
expect(model.baseUrl).toBe("http://localhost:11434");
|
|
90
|
-
});
|
|
91
|
-
it("should allow model names with additional colons", ()=>{
|
|
92
|
-
const model = ModelFactory.createModel("ollama:phi4:14b-q8_0");
|
|
93
|
-
expect(model).toBeInstanceOf(ChatOllama);
|
|
94
|
-
});
|
|
95
|
-
it("should create native xAI image model for grok-imagine-image", ()=>{
|
|
96
|
-
const model = ModelFactory.createModel("xai:grok-imagine-image");
|
|
97
|
-
expect(model).toBeInstanceOf(NativeXAIImageModel);
|
|
98
|
-
});
|
|
99
|
-
it("should keep text xAI models on ChatXAI", ()=>{
|
|
100
|
-
const model = ModelFactory.createModel("xai:grok-beta");
|
|
101
|
-
expect(model).toBeInstanceOf(ChatXAI);
|
|
102
|
-
});
|
|
103
|
-
it("should throw error for invalid format (missing colon)", ()=>{
|
|
104
|
-
expect(()=>{
|
|
105
|
-
ModelFactory.createModel("anthropic-claude-opus");
|
|
106
|
-
}).toThrow(/Invalid model format/);
|
|
107
|
-
});
|
|
108
|
-
it("should throw error for invalid format (empty provider)", ()=>{
|
|
109
|
-
expect(()=>{
|
|
110
|
-
ModelFactory.createModel(":claude-opus-4-5");
|
|
111
|
-
}).toThrow(/Invalid model format/);
|
|
112
|
-
});
|
|
113
|
-
it("should throw error for invalid format (empty model)", ()=>{
|
|
114
|
-
expect(()=>{
|
|
115
|
-
ModelFactory.createModel("anthropic:");
|
|
116
|
-
}).toThrow(/Invalid model format/);
|
|
117
|
-
});
|
|
118
|
-
it("should throw error for unsupported provider", ()=>{
|
|
119
|
-
expect(()=>{
|
|
120
|
-
ModelFactory.createModel("unsupported:model-name");
|
|
121
|
-
}).toThrow(/Unknown model provider/);
|
|
122
|
-
});
|
|
123
|
-
it("should be case insensitive for provider names", ()=>{
|
|
124
|
-
const model1 = ModelFactory.createModel("Anthropic:claude-opus-4-5");
|
|
125
|
-
const model2 = ModelFactory.createModel("ANTHROPIC:claude-opus-4-5");
|
|
126
|
-
expect(model1).toBeInstanceOf(ChatAnthropic);
|
|
127
|
-
expect(model2).toBeInstanceOf(ChatAnthropic);
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
describe("validateModelString", ()=>{
|
|
131
|
-
it("should validate correct model strings", ()=>{
|
|
132
|
-
const validModels = [
|
|
133
|
-
"anthropic:claude-opus-4-5",
|
|
134
|
-
"openai:gpt-4o",
|
|
135
|
-
"codex:codex-mini-latest",
|
|
136
|
-
"anthropic:claude-sonnet-4-5-20250929",
|
|
137
|
-
"openrouter:openai/gpt-4o",
|
|
138
|
-
"copilot:gpt-4o",
|
|
139
|
-
"lmstudio:llama-3.1-8b",
|
|
140
|
-
"ollama:llama3.2",
|
|
141
|
-
"ollama:phi4:14b-q8_0"
|
|
142
|
-
];
|
|
143
|
-
for (const modelString of validModels){
|
|
144
|
-
const result = ModelFactory.validateModelString(modelString);
|
|
145
|
-
expect(result.valid).toBe(true);
|
|
146
|
-
expect(result.error).toBeUndefined();
|
|
147
|
-
}
|
|
148
|
-
});
|
|
149
|
-
it("should reject invalid format", ()=>{
|
|
150
|
-
const result = ModelFactory.validateModelString("invalid-format");
|
|
151
|
-
expect(result.valid).toBe(false);
|
|
152
|
-
expect(result.error).toContain("Invalid format");
|
|
153
|
-
});
|
|
154
|
-
it("should reject empty provider", ()=>{
|
|
155
|
-
const result = ModelFactory.validateModelString(":model-name");
|
|
156
|
-
expect(result.valid).toBe(false);
|
|
157
|
-
expect(result.error).toContain("required");
|
|
158
|
-
});
|
|
159
|
-
it("should reject empty model", ()=>{
|
|
160
|
-
const result = ModelFactory.validateModelString("anthropic:");
|
|
161
|
-
expect(result.valid).toBe(false);
|
|
162
|
-
expect(result.error).toContain("required");
|
|
163
|
-
});
|
|
164
|
-
it("should reject unsupported provider", ()=>{
|
|
165
|
-
const result = ModelFactory.validateModelString("unsupported:model");
|
|
166
|
-
expect(result.valid).toBe(false);
|
|
167
|
-
expect(result.error).toContain("Unknown provider");
|
|
168
|
-
});
|
|
169
|
-
it("should accept case variations of providers", ()=>{
|
|
170
|
-
const result1 = ModelFactory.validateModelString("Anthropic:model");
|
|
171
|
-
const result2 = ModelFactory.validateModelString("OPENAI:model");
|
|
172
|
-
const result3 = ModelFactory.validateModelString("CODEX:model");
|
|
173
|
-
const result4 = ModelFactory.validateModelString("Copilot:model");
|
|
174
|
-
const result5 = ModelFactory.validateModelString("LMStudio:model");
|
|
175
|
-
const result6 = ModelFactory.validateModelString("OLLAMA:model");
|
|
176
|
-
expect(result1.valid).toBe(true);
|
|
177
|
-
expect(result2.valid).toBe(true);
|
|
178
|
-
expect(result3.valid).toBe(true);
|
|
179
|
-
expect(result4.valid).toBe(true);
|
|
180
|
-
expect(result5.valid).toBe(true);
|
|
181
|
-
expect(result6.valid).toBe(true);
|
|
182
|
-
});
|
|
183
|
-
});
|
|
184
|
-
});
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __webpack_exports__ = {};
|
|
3
|
-
const external_vitest_namespaceObject = require("vitest");
|
|
4
|
-
const terminal_session_manager_cjs_namespaceObject = require("../tools/terminal_session_manager.cjs");
|
|
5
|
-
async function waitForTerminalCompletion(manager, ownerId, sessionId, timeoutMs = 5000) {
|
|
6
|
-
const started = Date.now();
|
|
7
|
-
let lastOutput = "";
|
|
8
|
-
while(Date.now() - started < timeoutMs){
|
|
9
|
-
const poll = await manager.pollSession({
|
|
10
|
-
ownerId,
|
|
11
|
-
sessionId,
|
|
12
|
-
waitMs: 200,
|
|
13
|
-
maxOutputChars: 2000
|
|
14
|
-
});
|
|
15
|
-
lastOutput += poll.output;
|
|
16
|
-
if ("running" !== poll.status) return {
|
|
17
|
-
...poll,
|
|
18
|
-
output: lastOutput
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
throw new Error(`Timed out waiting for terminal session ${sessionId}`);
|
|
22
|
-
}
|
|
23
|
-
(0, external_vitest_namespaceObject.describe)("TerminalSessionManager", ()=>{
|
|
24
|
-
(0, external_vitest_namespaceObject.it)("runs commands and returns output", async ()=>{
|
|
25
|
-
const manager = new terminal_session_manager_cjs_namespaceObject.TerminalSessionManager();
|
|
26
|
-
try {
|
|
27
|
-
const session = manager.startSession({
|
|
28
|
-
ownerId: "owner-a",
|
|
29
|
-
command: "node -e \"process.stdout.write('hello\\n')\"",
|
|
30
|
-
cwd: process.cwd(),
|
|
31
|
-
env: process.env
|
|
32
|
-
});
|
|
33
|
-
const finalState = await waitForTerminalCompletion(manager, "owner-a", session.sessionId);
|
|
34
|
-
(0, external_vitest_namespaceObject.expect)(finalState.output).toContain("hello");
|
|
35
|
-
(0, external_vitest_namespaceObject.expect)([
|
|
36
|
-
"completed",
|
|
37
|
-
"error",
|
|
38
|
-
"killed",
|
|
39
|
-
"timed_out"
|
|
40
|
-
]).toContain(finalState.status);
|
|
41
|
-
} finally{
|
|
42
|
-
manager.dispose();
|
|
43
|
-
}
|
|
44
|
-
});
|
|
45
|
-
(0, external_vitest_namespaceObject.it)("enforces session ownership", async ()=>{
|
|
46
|
-
const manager = new terminal_session_manager_cjs_namespaceObject.TerminalSessionManager();
|
|
47
|
-
try {
|
|
48
|
-
const session = manager.startSession({
|
|
49
|
-
ownerId: "owner-allowed",
|
|
50
|
-
command: 'node -e "setTimeout(() => {}, 500)"',
|
|
51
|
-
cwd: process.cwd(),
|
|
52
|
-
env: process.env
|
|
53
|
-
});
|
|
54
|
-
await (0, external_vitest_namespaceObject.expect)(manager.pollSession({
|
|
55
|
-
ownerId: "owner-denied",
|
|
56
|
-
sessionId: session.sessionId,
|
|
57
|
-
waitMs: 0
|
|
58
|
-
})).rejects.toThrow("not accessible");
|
|
59
|
-
} finally{
|
|
60
|
-
manager.dispose();
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
(0, external_vitest_namespaceObject.it)("supports stdin writes and kill", async ()=>{
|
|
64
|
-
const manager = new terminal_session_manager_cjs_namespaceObject.TerminalSessionManager();
|
|
65
|
-
try {
|
|
66
|
-
const session = manager.startSession({
|
|
67
|
-
ownerId: "owner-b",
|
|
68
|
-
command: "cat",
|
|
69
|
-
cwd: process.cwd(),
|
|
70
|
-
env: process.env
|
|
71
|
-
});
|
|
72
|
-
manager.writeSession({
|
|
73
|
-
ownerId: "owner-b",
|
|
74
|
-
sessionId: session.sessionId,
|
|
75
|
-
chars: "ping\n"
|
|
76
|
-
});
|
|
77
|
-
const poll = await manager.pollSession({
|
|
78
|
-
ownerId: "owner-b",
|
|
79
|
-
sessionId: session.sessionId,
|
|
80
|
-
waitMs: 1000,
|
|
81
|
-
maxOutputChars: 2000
|
|
82
|
-
});
|
|
83
|
-
(0, external_vitest_namespaceObject.expect)(poll.output).toContain("ping");
|
|
84
|
-
const killed = manager.killSession({
|
|
85
|
-
ownerId: "owner-b",
|
|
86
|
-
sessionId: session.sessionId,
|
|
87
|
-
signal: "SIGTERM"
|
|
88
|
-
});
|
|
89
|
-
(0, external_vitest_namespaceObject.expect)([
|
|
90
|
-
"running",
|
|
91
|
-
"killed",
|
|
92
|
-
"timed_out",
|
|
93
|
-
"error",
|
|
94
|
-
"completed"
|
|
95
|
-
]).toContain(killed.status);
|
|
96
|
-
} finally{
|
|
97
|
-
manager.dispose();
|
|
98
|
-
}
|
|
99
|
-
});
|
|
100
|
-
(0, external_vitest_namespaceObject.it)("drops buffered output when max buffer is exceeded", async ()=>{
|
|
101
|
-
const manager = new terminal_session_manager_cjs_namespaceObject.TerminalSessionManager({
|
|
102
|
-
maxBufferedCharsPerSession: 32
|
|
103
|
-
});
|
|
104
|
-
try {
|
|
105
|
-
const session = manager.startSession({
|
|
106
|
-
ownerId: "owner-c",
|
|
107
|
-
command: "node -e \"process.stdout.write('abcdefghijklmnopqrstuvwxyz0123456789')\"",
|
|
108
|
-
cwd: process.cwd(),
|
|
109
|
-
env: process.env
|
|
110
|
-
});
|
|
111
|
-
const finalState = await waitForTerminalCompletion(manager, "owner-c", session.sessionId);
|
|
112
|
-
(0, external_vitest_namespaceObject.expect)(finalState.droppedChars).toBeGreaterThan(0);
|
|
113
|
-
} finally{
|
|
114
|
-
manager.dispose();
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
119
|
-
Object.defineProperty(exports, '__esModule', {
|
|
120
|
-
value: true
|
|
121
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from "vitest";
|
|
2
|
-
import { TerminalSessionManager } from "../tools/terminal_session_manager.js";
|
|
3
|
-
async function waitForTerminalCompletion(manager, ownerId, sessionId, timeoutMs = 5000) {
|
|
4
|
-
const started = Date.now();
|
|
5
|
-
let lastOutput = "";
|
|
6
|
-
while(Date.now() - started < timeoutMs){
|
|
7
|
-
const poll = await manager.pollSession({
|
|
8
|
-
ownerId,
|
|
9
|
-
sessionId,
|
|
10
|
-
waitMs: 200,
|
|
11
|
-
maxOutputChars: 2000
|
|
12
|
-
});
|
|
13
|
-
lastOutput += poll.output;
|
|
14
|
-
if ("running" !== poll.status) return {
|
|
15
|
-
...poll,
|
|
16
|
-
output: lastOutput
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
throw new Error(`Timed out waiting for terminal session ${sessionId}`);
|
|
20
|
-
}
|
|
21
|
-
describe("TerminalSessionManager", ()=>{
|
|
22
|
-
it("runs commands and returns output", async ()=>{
|
|
23
|
-
const manager = new TerminalSessionManager();
|
|
24
|
-
try {
|
|
25
|
-
const session = manager.startSession({
|
|
26
|
-
ownerId: "owner-a",
|
|
27
|
-
command: "node -e \"process.stdout.write('hello\\n')\"",
|
|
28
|
-
cwd: process.cwd(),
|
|
29
|
-
env: process.env
|
|
30
|
-
});
|
|
31
|
-
const finalState = await waitForTerminalCompletion(manager, "owner-a", session.sessionId);
|
|
32
|
-
expect(finalState.output).toContain("hello");
|
|
33
|
-
expect([
|
|
34
|
-
"completed",
|
|
35
|
-
"error",
|
|
36
|
-
"killed",
|
|
37
|
-
"timed_out"
|
|
38
|
-
]).toContain(finalState.status);
|
|
39
|
-
} finally{
|
|
40
|
-
manager.dispose();
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
it("enforces session ownership", async ()=>{
|
|
44
|
-
const manager = new TerminalSessionManager();
|
|
45
|
-
try {
|
|
46
|
-
const session = manager.startSession({
|
|
47
|
-
ownerId: "owner-allowed",
|
|
48
|
-
command: 'node -e "setTimeout(() => {}, 500)"',
|
|
49
|
-
cwd: process.cwd(),
|
|
50
|
-
env: process.env
|
|
51
|
-
});
|
|
52
|
-
await expect(manager.pollSession({
|
|
53
|
-
ownerId: "owner-denied",
|
|
54
|
-
sessionId: session.sessionId,
|
|
55
|
-
waitMs: 0
|
|
56
|
-
})).rejects.toThrow("not accessible");
|
|
57
|
-
} finally{
|
|
58
|
-
manager.dispose();
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
it("supports stdin writes and kill", async ()=>{
|
|
62
|
-
const manager = new TerminalSessionManager();
|
|
63
|
-
try {
|
|
64
|
-
const session = manager.startSession({
|
|
65
|
-
ownerId: "owner-b",
|
|
66
|
-
command: "cat",
|
|
67
|
-
cwd: process.cwd(),
|
|
68
|
-
env: process.env
|
|
69
|
-
});
|
|
70
|
-
manager.writeSession({
|
|
71
|
-
ownerId: "owner-b",
|
|
72
|
-
sessionId: session.sessionId,
|
|
73
|
-
chars: "ping\n"
|
|
74
|
-
});
|
|
75
|
-
const poll = await manager.pollSession({
|
|
76
|
-
ownerId: "owner-b",
|
|
77
|
-
sessionId: session.sessionId,
|
|
78
|
-
waitMs: 1000,
|
|
79
|
-
maxOutputChars: 2000
|
|
80
|
-
});
|
|
81
|
-
expect(poll.output).toContain("ping");
|
|
82
|
-
const killed = manager.killSession({
|
|
83
|
-
ownerId: "owner-b",
|
|
84
|
-
sessionId: session.sessionId,
|
|
85
|
-
signal: "SIGTERM"
|
|
86
|
-
});
|
|
87
|
-
expect([
|
|
88
|
-
"running",
|
|
89
|
-
"killed",
|
|
90
|
-
"timed_out",
|
|
91
|
-
"error",
|
|
92
|
-
"completed"
|
|
93
|
-
]).toContain(killed.status);
|
|
94
|
-
} finally{
|
|
95
|
-
manager.dispose();
|
|
96
|
-
}
|
|
97
|
-
});
|
|
98
|
-
it("drops buffered output when max buffer is exceeded", async ()=>{
|
|
99
|
-
const manager = new TerminalSessionManager({
|
|
100
|
-
maxBufferedCharsPerSession: 32
|
|
101
|
-
});
|
|
102
|
-
try {
|
|
103
|
-
const session = manager.startSession({
|
|
104
|
-
ownerId: "owner-c",
|
|
105
|
-
command: "node -e \"process.stdout.write('abcdefghijklmnopqrstuvwxyz0123456789')\"",
|
|
106
|
-
cwd: process.cwd(),
|
|
107
|
-
env: process.env
|
|
108
|
-
});
|
|
109
|
-
const finalState = await waitForTerminalCompletion(manager, "owner-c", session.sessionId);
|
|
110
|
-
expect(finalState.droppedChars).toBeGreaterThan(0);
|
|
111
|
-
} finally{
|
|
112
|
-
manager.dispose();
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
});
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __webpack_exports__ = {};
|
|
3
|
-
const agentLoader_cjs_namespaceObject = require("../config/agentLoader.cjs");
|
|
4
|
-
const loader = new agentLoader_cjs_namespaceObject.AgentLoader(".wingman", process.cwd());
|
|
5
|
-
const agents = loader.loadAllAgentConfigs();
|
|
6
|
-
console.log(`Loaded ${agents.length} agents:`);
|
|
7
|
-
agents.forEach((agent)=>{
|
|
8
|
-
console.log(` - ${agent.name}: ${agent.description}`);
|
|
9
|
-
console.log(` Tools: ${agent.tools?.length || 0}`);
|
|
10
|
-
console.log(` Model: ${agent.model ? "Custom" : "Default"}`);
|
|
11
|
-
});
|
|
12
|
-
const expectedAgents = [
|
|
13
|
-
"researcher",
|
|
14
|
-
"coding",
|
|
15
|
-
"planner",
|
|
16
|
-
"implementor",
|
|
17
|
-
"reviewer"
|
|
18
|
-
];
|
|
19
|
-
const loadedAgentNames = agents.map((a)=>a.name);
|
|
20
|
-
console.log("\nExpected agents check:");
|
|
21
|
-
expectedAgents.forEach((name)=>{
|
|
22
|
-
const found = loadedAgentNames.includes(name);
|
|
23
|
-
console.log(` ${found ? "✓" : "✗"} ${name}`);
|
|
24
|
-
});
|
|
25
|
-
if (agents.length !== expectedAgents.length) {
|
|
26
|
-
console.error(`\nERROR: Expected ${expectedAgents.length} agents, but loaded ${agents.length}`);
|
|
27
|
-
process.exit(1);
|
|
28
|
-
}
|
|
29
|
-
console.log("\n✓ All tests passed!");
|
|
30
|
-
for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
31
|
-
Object.defineProperty(exports, '__esModule', {
|
|
32
|
-
value: true
|
|
33
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { AgentLoader } from "../config/agentLoader.js";
|
|
2
|
-
const loader = new AgentLoader(".wingman", process.cwd());
|
|
3
|
-
const agents = loader.loadAllAgentConfigs();
|
|
4
|
-
console.log(`Loaded ${agents.length} agents:`);
|
|
5
|
-
agents.forEach((agent)=>{
|
|
6
|
-
console.log(` - ${agent.name}: ${agent.description}`);
|
|
7
|
-
console.log(` Tools: ${agent.tools?.length || 0}`);
|
|
8
|
-
console.log(` Model: ${agent.model ? "Custom" : "Default"}`);
|
|
9
|
-
});
|
|
10
|
-
const expectedAgents = [
|
|
11
|
-
"researcher",
|
|
12
|
-
"coding",
|
|
13
|
-
"planner",
|
|
14
|
-
"implementor",
|
|
15
|
-
"reviewer"
|
|
16
|
-
];
|
|
17
|
-
const loadedAgentNames = agents.map((a)=>a.name);
|
|
18
|
-
console.log("\nExpected agents check:");
|
|
19
|
-
expectedAgents.forEach((name)=>{
|
|
20
|
-
const found = loadedAgentNames.includes(name);
|
|
21
|
-
console.log(` ${found ? "✓" : "✗"} ${name}`);
|
|
22
|
-
});
|
|
23
|
-
if (agents.length !== expectedAgents.length) {
|
|
24
|
-
console.error(`\nERROR: Expected ${expectedAgents.length} agents, but loaded ${agents.length}`);
|
|
25
|
-
process.exit(1);
|
|
26
|
-
}
|
|
27
|
-
console.log("\n✓ All tests passed!");
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __webpack_exports__ = {};
|
|
3
|
-
const external_node_fs_namespaceObject = require("node:fs");
|
|
4
|
-
const external_node_path_namespaceObject = require("node:path");
|
|
5
|
-
const agentLoader_cjs_namespaceObject = require("../config/agentLoader.cjs");
|
|
6
|
-
const testDir = (0, external_node_path_namespaceObject.join)(process.cwd(), ".test-subagents");
|
|
7
|
-
const testAgentsDir = (0, external_node_path_namespaceObject.join)(testDir, "agents");
|
|
8
|
-
function cleanup() {
|
|
9
|
-
if ((0, external_node_fs_namespaceObject.existsSync)(testDir)) {
|
|
10
|
-
(0, external_node_fs_namespaceObject.unlinkSync)((0, external_node_path_namespaceObject.join)(testAgentsDir, "parent-agent.json"));
|
|
11
|
-
process.chdir(process.cwd());
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
try {
|
|
15
|
-
if (!(0, external_node_fs_namespaceObject.existsSync)(testDir)) (0, external_node_fs_namespaceObject.mkdirSync)(testDir, {
|
|
16
|
-
recursive: true
|
|
17
|
-
});
|
|
18
|
-
if (!(0, external_node_fs_namespaceObject.existsSync)(testAgentsDir)) (0, external_node_fs_namespaceObject.mkdirSync)(testAgentsDir, {
|
|
19
|
-
recursive: true
|
|
20
|
-
});
|
|
21
|
-
console.log("\n=== Test 1: Agent with subagents ===");
|
|
22
|
-
const agentWithSubagents = {
|
|
23
|
-
name: "parent-agent",
|
|
24
|
-
description: "Parent agent with subagents",
|
|
25
|
-
systemPrompt: "You are a parent agent that delegates to subagents.",
|
|
26
|
-
tools: [
|
|
27
|
-
"think"
|
|
28
|
-
],
|
|
29
|
-
subagents: [
|
|
30
|
-
{
|
|
31
|
-
name: "child-1",
|
|
32
|
-
description: "First child agent",
|
|
33
|
-
systemPrompt: "You are child agent 1",
|
|
34
|
-
tools: [
|
|
35
|
-
"web_crawler"
|
|
36
|
-
]
|
|
37
|
-
},
|
|
38
|
-
{
|
|
39
|
-
name: "child-2",
|
|
40
|
-
description: "Second child agent",
|
|
41
|
-
systemPrompt: "You are child agent 2",
|
|
42
|
-
tools: [
|
|
43
|
-
"internet_search"
|
|
44
|
-
]
|
|
45
|
-
}
|
|
46
|
-
]
|
|
47
|
-
};
|
|
48
|
-
(0, external_node_fs_namespaceObject.writeFileSync)((0, external_node_path_namespaceObject.join)(testAgentsDir, "parent-agent.json"), JSON.stringify(agentWithSubagents, null, 2));
|
|
49
|
-
const loader1 = new agentLoader_cjs_namespaceObject.AgentLoader(".wingman", testDir);
|
|
50
|
-
const agents1 = loader1.loadAllAgentConfigs();
|
|
51
|
-
console.log(`Loaded ${agents1.length} agent(s)`);
|
|
52
|
-
console.log(`Agent name: ${agents1[0]?.name}`);
|
|
53
|
-
console.log(`Agent has subagents: ${agents1[0]?.subagents ? "Yes" : "No"}`);
|
|
54
|
-
if (agents1[0]?.subagents) {
|
|
55
|
-
console.log(`Number of subagents: ${agents1[0].subagents.length}`);
|
|
56
|
-
agents1[0].subagents.forEach((sub, i)=>{
|
|
57
|
-
console.log(` Subagent ${i + 1}: ${sub.name} - ${sub.description}`);
|
|
58
|
-
console.log(` Tools: ${sub.tools?.length || 0}`);
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
console.log("\n=== Test 2: Validation - Subagents cannot have subagents ===");
|
|
62
|
-
const invalidAgent = {
|
|
63
|
-
name: "invalid-agent",
|
|
64
|
-
description: "Agent with nested subagents (should fail)",
|
|
65
|
-
systemPrompt: "Invalid config",
|
|
66
|
-
subagents: [
|
|
67
|
-
{
|
|
68
|
-
name: "child",
|
|
69
|
-
description: "Child with its own subagents",
|
|
70
|
-
systemPrompt: "Child agent",
|
|
71
|
-
subagents: [
|
|
72
|
-
{
|
|
73
|
-
name: "grandchild",
|
|
74
|
-
description: "This should fail validation",
|
|
75
|
-
systemPrompt: "Grandchild"
|
|
76
|
-
}
|
|
77
|
-
]
|
|
78
|
-
}
|
|
79
|
-
]
|
|
80
|
-
};
|
|
81
|
-
(0, external_node_fs_namespaceObject.writeFileSync)((0, external_node_path_namespaceObject.join)(testAgentsDir, "parent-agent.json"), JSON.stringify(invalidAgent, null, 2));
|
|
82
|
-
const loader2 = new agentLoader_cjs_namespaceObject.AgentLoader(".wingman", testDir);
|
|
83
|
-
const agents2 = loader2.loadAllAgentConfigs();
|
|
84
|
-
if (0 === agents2.length) console.log("✓ Validation correctly rejected nested subagents");
|
|
85
|
-
else {
|
|
86
|
-
console.log("✗ ERROR: Validation should have rejected nested subagents");
|
|
87
|
-
process.exit(1);
|
|
88
|
-
}
|
|
89
|
-
console.log("\n✓ All subagent tests passed!");
|
|
90
|
-
cleanup();
|
|
91
|
-
} catch (error) {
|
|
92
|
-
console.error("Test failed:", error);
|
|
93
|
-
cleanup();
|
|
94
|
-
process.exit(1);
|
|
95
|
-
}
|
|
96
|
-
for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
97
|
-
Object.defineProperty(exports, '__esModule', {
|
|
98
|
-
value: true
|
|
99
|
-
});
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|