@wingman-ai/gateway 0.2.2 → 0.2.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.wingman/agents/README.md +7 -1
- package/.wingman/agents/coding/agent.md +299 -201
- package/.wingman/agents/coding-v2/agent.md +127 -0
- package/.wingman/agents/coding-v2/implementor.md +89 -0
- package/.wingman/agents/main/agent.md +4 -0
- package/README.md +1 -0
- package/dist/agent/config/agentConfig.cjs +31 -17
- package/dist/agent/config/agentConfig.d.ts +23 -1
- package/dist/agent/config/agentConfig.js +30 -19
- package/dist/agent/config/agentLoader.cjs +26 -8
- package/dist/agent/config/agentLoader.d.ts +4 -2
- package/dist/agent/config/agentLoader.js +26 -8
- package/dist/agent/config/modelFactory.cjs +95 -25
- package/dist/agent/config/modelFactory.d.ts +13 -1
- package/dist/agent/config/modelFactory.js +95 -25
- package/dist/agent/config/toolRegistry.cjs +19 -6
- package/dist/agent/config/toolRegistry.d.ts +5 -2
- package/dist/agent/config/toolRegistry.js +19 -6
- package/dist/agent/middleware/hooks/types.cjs +13 -13
- package/dist/agent/middleware/hooks/types.d.ts +1 -1
- package/dist/agent/middleware/hooks/types.js +14 -14
- package/dist/agent/tests/agentConfig.test.cjs +22 -2
- package/dist/agent/tests/agentConfig.test.js +22 -2
- package/dist/agent/tests/agentLoader.test.cjs +38 -1
- package/dist/agent/tests/agentLoader.test.js +38 -1
- package/dist/agent/tests/backgroundTerminal.test.cjs +70 -0
- package/dist/agent/tests/backgroundTerminal.test.d.ts +1 -0
- package/dist/agent/tests/backgroundTerminal.test.js +64 -0
- package/dist/agent/tests/commandExecuteTool.test.cjs +29 -0
- package/dist/agent/tests/commandExecuteTool.test.d.ts +1 -0
- package/dist/agent/tests/commandExecuteTool.test.js +23 -0
- package/dist/agent/tests/modelFactory.test.cjs +47 -5
- package/dist/agent/tests/modelFactory.test.js +47 -5
- package/dist/agent/tests/terminalSessionManager.test.cjs +121 -0
- package/dist/agent/tests/terminalSessionManager.test.d.ts +1 -0
- package/dist/agent/tests/terminalSessionManager.test.js +115 -0
- package/dist/agent/tests/toolRegistry.test.cjs +14 -2
- package/dist/agent/tests/toolRegistry.test.js +14 -2
- package/dist/agent/tools/background_terminal.cjs +128 -0
- package/dist/agent/tools/background_terminal.d.ts +41 -0
- package/dist/agent/tools/background_terminal.js +94 -0
- package/dist/agent/tools/code_search.cjs +6 -6
- package/dist/agent/tools/code_search.d.ts +1 -1
- package/dist/agent/tools/code_search.js +7 -7
- package/dist/agent/tools/command_execute.cjs +22 -7
- package/dist/agent/tools/command_execute.d.ts +3 -2
- package/dist/agent/tools/command_execute.js +23 -8
- package/dist/agent/tools/git_status.cjs +3 -3
- package/dist/agent/tools/git_status.d.ts +1 -1
- package/dist/agent/tools/git_status.js +4 -4
- package/dist/agent/tools/internet_search.cjs +6 -6
- package/dist/agent/tools/internet_search.d.ts +1 -1
- package/dist/agent/tools/internet_search.js +7 -7
- package/dist/agent/tools/terminal_session_manager.cjs +321 -0
- package/dist/agent/tools/terminal_session_manager.d.ts +77 -0
- package/dist/agent/tools/terminal_session_manager.js +284 -0
- package/dist/agent/tools/think.cjs +4 -4
- package/dist/agent/tools/think.d.ts +1 -1
- package/dist/agent/tools/think.js +5 -5
- package/dist/agent/tools/ui_registry.cjs +13 -13
- package/dist/agent/tools/ui_registry.d.ts +4 -4
- package/dist/agent/tools/ui_registry.js +14 -14
- package/dist/agent/tools/web_crawler.cjs +4 -4
- package/dist/agent/tools/web_crawler.d.ts +1 -1
- package/dist/agent/tools/web_crawler.js +5 -5
- package/dist/agent/utils.cjs +2 -1
- package/dist/agent/utils.js +2 -1
- package/dist/cli/commands/init.cjs +7 -6
- package/dist/cli/commands/init.js +7 -6
- package/dist/cli/commands/provider.cjs +17 -3
- package/dist/cli/commands/provider.js +17 -3
- package/dist/cli/config/loader.cjs +27 -0
- package/dist/cli/config/loader.js +27 -0
- package/dist/cli/config/schema.cjs +146 -68
- package/dist/cli/config/schema.d.ts +89 -1
- package/dist/cli/config/schema.js +134 -68
- package/dist/cli/core/agentInvoker.cjs +344 -17
- package/dist/cli/core/agentInvoker.d.ts +63 -3
- package/dist/cli/core/agentInvoker.js +303 -12
- package/dist/cli/core/sessionManager.cjs +32 -5
- package/dist/cli/core/sessionManager.js +32 -5
- package/dist/cli/core/streamParser.cjs +15 -0
- package/dist/cli/core/streamParser.js +15 -0
- package/dist/cli/index.cjs +6 -5
- package/dist/cli/index.js +6 -5
- package/dist/cli/types.d.ts +32 -0
- package/dist/cli/ui/toolDisplayHelpers.cjs +2 -0
- package/dist/cli/ui/toolDisplayHelpers.js +2 -0
- package/dist/gateway/hooks/registry.cjs +2 -1
- package/dist/gateway/hooks/registry.d.ts +1 -1
- package/dist/gateway/hooks/registry.js +2 -1
- package/dist/gateway/hooks/types.cjs +11 -11
- package/dist/gateway/hooks/types.d.ts +1 -1
- package/dist/gateway/hooks/types.js +12 -12
- package/dist/gateway/http/agents.cjs +67 -4
- package/dist/gateway/http/agents.js +67 -4
- package/dist/gateway/http/sessions.cjs +7 -7
- package/dist/gateway/http/sessions.js +7 -7
- package/dist/gateway/http/types.d.ts +5 -3
- package/dist/gateway/http/webhooks.cjs +6 -5
- package/dist/gateway/http/webhooks.js +6 -5
- package/dist/gateway/server.cjs +198 -41
- package/dist/gateway/server.d.ts +9 -1
- package/dist/gateway/server.js +198 -41
- package/dist/gateway/types.d.ts +1 -0
- package/dist/gateway/validation.cjs +39 -39
- package/dist/gateway/validation.d.ts +1 -1
- package/dist/gateway/validation.js +40 -40
- package/dist/providers/codex.cjs +167 -0
- package/dist/providers/codex.d.ts +15 -0
- package/dist/providers/codex.js +127 -0
- package/dist/providers/credentials.cjs +8 -0
- package/dist/providers/credentials.js +8 -0
- package/dist/providers/registry.cjs +11 -0
- package/dist/providers/registry.d.ts +1 -1
- package/dist/providers/registry.js +11 -0
- package/dist/tests/additionalMessageMiddleware.test.cjs +3 -0
- package/dist/tests/additionalMessageMiddleware.test.js +3 -0
- package/dist/tests/agentInvokerSummarization.test.cjs +455 -0
- package/dist/tests/agentInvokerSummarization.test.d.ts +1 -0
- package/dist/tests/agentInvokerSummarization.test.js +449 -0
- package/dist/tests/agents-api.test.cjs +45 -5
- package/dist/tests/agents-api.test.js +45 -5
- package/dist/tests/cli-config-loader.test.cjs +88 -0
- package/dist/tests/cli-config-loader.test.js +88 -0
- package/dist/tests/cli-init.test.cjs +27 -3
- package/dist/tests/cli-init.test.js +27 -3
- package/dist/tests/codex-credentials-precedence.test.cjs +94 -0
- package/dist/tests/codex-credentials-precedence.test.d.ts +1 -0
- package/dist/tests/codex-credentials-precedence.test.js +88 -0
- package/dist/tests/codex-provider.test.cjs +210 -0
- package/dist/tests/codex-provider.test.d.ts +1 -0
- package/dist/tests/codex-provider.test.js +204 -0
- package/dist/tests/gateway.test.cjs +115 -8
- package/dist/tests/gateway.test.js +115 -8
- package/dist/tests/provider-command-codex.test.cjs +57 -0
- package/dist/tests/provider-command-codex.test.d.ts +1 -0
- package/dist/tests/provider-command-codex.test.js +51 -0
- package/dist/tests/sessionStateMessages.test.cjs +38 -0
- package/dist/tests/sessionStateMessages.test.js +38 -0
- package/dist/tests/toolDisplayHelpers.test.cjs +3 -0
- package/dist/tests/toolDisplayHelpers.test.js +3 -0
- package/dist/tools/mcp-finance.cjs +48 -48
- package/dist/tools/mcp-finance.js +48 -48
- package/dist/types/mcp.cjs +15 -15
- package/dist/types/mcp.d.ts +1 -1
- package/dist/types/mcp.js +16 -16
- package/dist/types/voice.cjs +21 -21
- package/dist/types/voice.d.ts +1 -1
- package/dist/types/voice.js +22 -22
- package/dist/webui/assets/index-DVWQluit.css +11 -0
- package/dist/webui/assets/index-Dlyzwalc.js +270 -0
- package/dist/webui/favicon-32x32.png +0 -0
- package/dist/webui/favicon-64x64.png +0 -0
- package/dist/webui/favicon.webp +0 -0
- package/dist/webui/index.html +4 -2
- package/package.json +13 -12
- package/.wingman/agents/coding/implementor.md +0 -79
- package/dist/webui/assets/index-CPhfGPHc.js +0 -182
- package/dist/webui/assets/index-DDsMIOTX.css +0 -11
|
@@ -0,0 +1,455 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_exports__ = {};
|
|
3
|
+
const external_vitest_namespaceObject = require("vitest");
|
|
4
|
+
const schema_cjs_namespaceObject = require("../cli/config/schema.cjs");
|
|
5
|
+
const agentInvoker_cjs_namespaceObject = require("../cli/core/agentInvoker.cjs");
|
|
6
|
+
const parseConfig = (input)=>{
|
|
7
|
+
const result = (0, schema_cjs_namespaceObject.validateConfig)(input);
|
|
8
|
+
if (!result.success || !result.data) throw new Error(result.error || "Expected config validation to succeed");
|
|
9
|
+
return result.data;
|
|
10
|
+
};
|
|
11
|
+
(0, external_vitest_namespaceObject.describe)("resolveSummarizationMiddlewareSettings", ()=>{
|
|
12
|
+
(0, external_vitest_namespaceObject.it)("returns default summarization settings from config defaults", ()=>{
|
|
13
|
+
const config = parseConfig({});
|
|
14
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveSummarizationMiddlewareSettings)(config)).toEqual({
|
|
15
|
+
maxTokensBeforeSummary: 12000,
|
|
16
|
+
messagesToKeep: 8
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
(0, external_vitest_namespaceObject.it)("returns null when summarization is disabled", ()=>{
|
|
20
|
+
const config = parseConfig({
|
|
21
|
+
summarization: {
|
|
22
|
+
enabled: false
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveSummarizationMiddlewareSettings)(config)).toBeNull();
|
|
26
|
+
});
|
|
27
|
+
(0, external_vitest_namespaceObject.it)("returns custom summarization settings when configured", ()=>{
|
|
28
|
+
const config = parseConfig({
|
|
29
|
+
summarization: {
|
|
30
|
+
enabled: true,
|
|
31
|
+
maxTokensBeforeSummary: 20000,
|
|
32
|
+
messagesToKeep: 10
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveSummarizationMiddlewareSettings)(config)).toEqual({
|
|
36
|
+
maxTokensBeforeSummary: 20000,
|
|
37
|
+
messagesToKeep: 10
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
(0, external_vitest_namespaceObject.describe)("configureDeepAgentSummarizationMiddleware", ()=>{
|
|
42
|
+
(0, external_vitest_namespaceObject.it)("replaces built-in summarization middleware with configured settings", ()=>{
|
|
43
|
+
const agent = {
|
|
44
|
+
options: {
|
|
45
|
+
middleware: [
|
|
46
|
+
{
|
|
47
|
+
name: "todoListMiddleware"
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
name: "SummarizationMiddleware",
|
|
51
|
+
marker: "old"
|
|
52
|
+
}
|
|
53
|
+
]
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
(0, agentInvoker_cjs_namespaceObject.configureDeepAgentSummarizationMiddleware)(agent, {
|
|
57
|
+
maxTokensBeforeSummary: 9000,
|
|
58
|
+
messagesToKeep: 5
|
|
59
|
+
}, "openai:gpt-4o-mini");
|
|
60
|
+
(0, external_vitest_namespaceObject.expect)(agent.options.middleware).toHaveLength(2);
|
|
61
|
+
(0, external_vitest_namespaceObject.expect)(agent.options.middleware[1]?.name).toBe("SummarizationMiddleware");
|
|
62
|
+
(0, external_vitest_namespaceObject.expect)(agent.options.middleware[1]?.marker).toBeUndefined();
|
|
63
|
+
});
|
|
64
|
+
(0, external_vitest_namespaceObject.it)("removes built-in summarization middleware when disabled", ()=>{
|
|
65
|
+
const agent = {
|
|
66
|
+
options: {
|
|
67
|
+
middleware: [
|
|
68
|
+
{
|
|
69
|
+
name: "todoListMiddleware"
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
name: "SummarizationMiddleware"
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
name: "patchToolCallsMiddleware"
|
|
76
|
+
}
|
|
77
|
+
]
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
(0, agentInvoker_cjs_namespaceObject.configureDeepAgentSummarizationMiddleware)(agent, null);
|
|
81
|
+
(0, external_vitest_namespaceObject.expect)(agent.options.middleware.map((m)=>m.name)).toEqual([
|
|
82
|
+
"todoListMiddleware",
|
|
83
|
+
"patchToolCallsMiddleware"
|
|
84
|
+
]);
|
|
85
|
+
});
|
|
86
|
+
});
|
|
87
|
+
(0, external_vitest_namespaceObject.describe)("resolveModelRetryMiddlewareSettings", ()=>{
|
|
88
|
+
(0, external_vitest_namespaceObject.it)("returns default retry settings when config defaults are used", ()=>{
|
|
89
|
+
const config = parseConfig({});
|
|
90
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveModelRetryMiddlewareSettings)(config)).toEqual({
|
|
91
|
+
maxRetries: 2,
|
|
92
|
+
backoffFactor: 2,
|
|
93
|
+
initialDelayMs: 1000,
|
|
94
|
+
maxDelayMs: 60000,
|
|
95
|
+
jitter: true,
|
|
96
|
+
onFailure: "continue"
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
(0, external_vitest_namespaceObject.it)("returns configured retry settings when enabled", ()=>{
|
|
100
|
+
const config = parseConfig({
|
|
101
|
+
modelRetry: {
|
|
102
|
+
enabled: true,
|
|
103
|
+
maxRetries: 3,
|
|
104
|
+
backoffFactor: 1.5,
|
|
105
|
+
initialDelayMs: 250,
|
|
106
|
+
maxDelayMs: 5000,
|
|
107
|
+
jitter: false,
|
|
108
|
+
onFailure: "error"
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveModelRetryMiddlewareSettings)(config)).toEqual({
|
|
112
|
+
maxRetries: 3,
|
|
113
|
+
backoffFactor: 1.5,
|
|
114
|
+
initialDelayMs: 250,
|
|
115
|
+
maxDelayMs: 5000,
|
|
116
|
+
jitter: false,
|
|
117
|
+
onFailure: "error"
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
(0, external_vitest_namespaceObject.describe)("resolveToolRetryMiddlewareSettings", ()=>{
|
|
122
|
+
(0, external_vitest_namespaceObject.it)("returns null by default", ()=>{
|
|
123
|
+
const config = parseConfig({});
|
|
124
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveToolRetryMiddlewareSettings)(config)).toBeNull();
|
|
125
|
+
});
|
|
126
|
+
(0, external_vitest_namespaceObject.it)("returns configured retry settings and tool filter when enabled", ()=>{
|
|
127
|
+
const config = parseConfig({
|
|
128
|
+
toolRetry: {
|
|
129
|
+
enabled: true,
|
|
130
|
+
maxRetries: 4,
|
|
131
|
+
backoffFactor: 2,
|
|
132
|
+
initialDelayMs: 500,
|
|
133
|
+
maxDelayMs: 10000,
|
|
134
|
+
jitter: true,
|
|
135
|
+
onFailure: "continue",
|
|
136
|
+
tools: [
|
|
137
|
+
"internet_search",
|
|
138
|
+
"web_crawler"
|
|
139
|
+
]
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveToolRetryMiddlewareSettings)(config)).toEqual({
|
|
143
|
+
maxRetries: 4,
|
|
144
|
+
backoffFactor: 2,
|
|
145
|
+
initialDelayMs: 500,
|
|
146
|
+
maxDelayMs: 10000,
|
|
147
|
+
jitter: true,
|
|
148
|
+
onFailure: "continue",
|
|
149
|
+
tools: [
|
|
150
|
+
"internet_search",
|
|
151
|
+
"web_crawler"
|
|
152
|
+
]
|
|
153
|
+
});
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
(0, external_vitest_namespaceObject.describe)("resolveHumanInTheLoopSettings", ()=>{
|
|
157
|
+
(0, external_vitest_namespaceObject.it)("returns null by default", ()=>{
|
|
158
|
+
const config = parseConfig({});
|
|
159
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveHumanInTheLoopSettings)(config)).toBeNull();
|
|
160
|
+
});
|
|
161
|
+
(0, external_vitest_namespaceObject.it)("returns null when enabled but no tool policy is defined", ()=>{
|
|
162
|
+
const config = parseConfig({
|
|
163
|
+
humanInTheLoop: {
|
|
164
|
+
enabled: true,
|
|
165
|
+
interruptOn: {}
|
|
166
|
+
}
|
|
167
|
+
});
|
|
168
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveHumanInTheLoopSettings)(config)).toBeNull();
|
|
169
|
+
});
|
|
170
|
+
(0, external_vitest_namespaceObject.it)("returns interrupt map when enabled with tool policies", ()=>{
|
|
171
|
+
const config = parseConfig({
|
|
172
|
+
humanInTheLoop: {
|
|
173
|
+
enabled: true,
|
|
174
|
+
interruptOn: {
|
|
175
|
+
command_execute: {
|
|
176
|
+
allowedDecisions: [
|
|
177
|
+
"approve",
|
|
178
|
+
"reject"
|
|
179
|
+
],
|
|
180
|
+
description: "Command execution requires approval"
|
|
181
|
+
},
|
|
182
|
+
internet_search: false
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
});
|
|
186
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.resolveHumanInTheLoopSettings)(config)).toEqual({
|
|
187
|
+
interruptOn: {
|
|
188
|
+
command_execute: {
|
|
189
|
+
allowedDecisions: [
|
|
190
|
+
"approve",
|
|
191
|
+
"reject"
|
|
192
|
+
],
|
|
193
|
+
description: "Command execution requires approval"
|
|
194
|
+
},
|
|
195
|
+
internet_search: false
|
|
196
|
+
}
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
});
|
|
200
|
+
(0, external_vitest_namespaceObject.describe)("detectToolEventContext", ()=>{
|
|
201
|
+
(0, external_vitest_namespaceObject.it)("extracts tool context for tool start events", ()=>{
|
|
202
|
+
const detected = (0, agentInvoker_cjs_namespaceObject.detectToolEventContext)({
|
|
203
|
+
event: "on_tool_start",
|
|
204
|
+
name: "glob"
|
|
205
|
+
});
|
|
206
|
+
(0, external_vitest_namespaceObject.expect)(detected).toEqual({
|
|
207
|
+
event: "on_tool_start",
|
|
208
|
+
toolName: "glob"
|
|
209
|
+
});
|
|
210
|
+
});
|
|
211
|
+
(0, external_vitest_namespaceObject.it)("extracts tool context for tool error events", ()=>{
|
|
212
|
+
const detected = (0, agentInvoker_cjs_namespaceObject.detectToolEventContext)({
|
|
213
|
+
event: "on_tool_error",
|
|
214
|
+
name: "grep"
|
|
215
|
+
});
|
|
216
|
+
(0, external_vitest_namespaceObject.expect)(detected).toEqual({
|
|
217
|
+
event: "on_tool_error",
|
|
218
|
+
toolName: "grep"
|
|
219
|
+
});
|
|
220
|
+
});
|
|
221
|
+
(0, external_vitest_namespaceObject.it)("returns null for non-tool events", ()=>{
|
|
222
|
+
const detected = (0, agentInvoker_cjs_namespaceObject.detectToolEventContext)({
|
|
223
|
+
event: "on_chat_model_stream",
|
|
224
|
+
data: {
|
|
225
|
+
chunk: {
|
|
226
|
+
text: "hello"
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
});
|
|
230
|
+
(0, external_vitest_namespaceObject.expect)(detected).toBeNull();
|
|
231
|
+
});
|
|
232
|
+
});
|
|
233
|
+
(0, external_vitest_namespaceObject.describe)("chunkHasAssistantText", ()=>{
|
|
234
|
+
(0, external_vitest_namespaceObject.it)("detects text in on_chat_model_stream chunks", ()=>{
|
|
235
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.chunkHasAssistantText)({
|
|
236
|
+
event: "on_chat_model_stream",
|
|
237
|
+
data: {
|
|
238
|
+
chunk: {
|
|
239
|
+
content: [
|
|
240
|
+
{
|
|
241
|
+
type: "text",
|
|
242
|
+
text: "hello"
|
|
243
|
+
}
|
|
244
|
+
]
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
})).toBe(true);
|
|
248
|
+
});
|
|
249
|
+
(0, external_vitest_namespaceObject.it)("detects text in on_llm_stream chunks", ()=>{
|
|
250
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.chunkHasAssistantText)({
|
|
251
|
+
event: "on_llm_stream",
|
|
252
|
+
data: {
|
|
253
|
+
chunk: {
|
|
254
|
+
text: "delta"
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
})).toBe(true);
|
|
258
|
+
});
|
|
259
|
+
(0, external_vitest_namespaceObject.it)("returns false when chunk has no assistant text", ()=>{
|
|
260
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.chunkHasAssistantText)({
|
|
261
|
+
event: "on_tool_start",
|
|
262
|
+
name: "glob"
|
|
263
|
+
})).toBe(false);
|
|
264
|
+
});
|
|
265
|
+
});
|
|
266
|
+
(0, external_vitest_namespaceObject.describe)("selectStreamingFallbackText", ()=>{
|
|
267
|
+
(0, external_vitest_namespaceObject.it)("returns assistant text introduced during the current invocation", ()=>{
|
|
268
|
+
const selected = (0, agentInvoker_cjs_namespaceObject.selectStreamingFallbackText)([
|
|
269
|
+
{
|
|
270
|
+
role: "assistant",
|
|
271
|
+
content: "stale message"
|
|
272
|
+
}
|
|
273
|
+
], [
|
|
274
|
+
{
|
|
275
|
+
role: "assistant",
|
|
276
|
+
content: "stale message"
|
|
277
|
+
},
|
|
278
|
+
{
|
|
279
|
+
role: "assistant",
|
|
280
|
+
content: "fresh fallback"
|
|
281
|
+
}
|
|
282
|
+
]);
|
|
283
|
+
(0, external_vitest_namespaceObject.expect)(selected).toBe("fresh fallback");
|
|
284
|
+
});
|
|
285
|
+
(0, external_vitest_namespaceObject.it)("returns undefined when no new assistant text is introduced", ()=>{
|
|
286
|
+
const selected = (0, agentInvoker_cjs_namespaceObject.selectStreamingFallbackText)([
|
|
287
|
+
{
|
|
288
|
+
role: "assistant",
|
|
289
|
+
content: "existing response"
|
|
290
|
+
}
|
|
291
|
+
], [
|
|
292
|
+
{
|
|
293
|
+
role: "user",
|
|
294
|
+
content: "not assistant"
|
|
295
|
+
},
|
|
296
|
+
{
|
|
297
|
+
role: "assistant",
|
|
298
|
+
content: "existing response"
|
|
299
|
+
}
|
|
300
|
+
]);
|
|
301
|
+
(0, external_vitest_namespaceObject.expect)(selected).toBeUndefined();
|
|
302
|
+
});
|
|
303
|
+
(0, external_vitest_namespaceObject.it)("handles repeated assistant messages by count", ()=>{
|
|
304
|
+
const selected = (0, agentInvoker_cjs_namespaceObject.selectStreamingFallbackText)([
|
|
305
|
+
{
|
|
306
|
+
role: "assistant",
|
|
307
|
+
content: "repeat"
|
|
308
|
+
}
|
|
309
|
+
], [
|
|
310
|
+
{
|
|
311
|
+
role: "assistant",
|
|
312
|
+
content: "repeat"
|
|
313
|
+
},
|
|
314
|
+
{
|
|
315
|
+
role: "assistant",
|
|
316
|
+
content: "repeat"
|
|
317
|
+
}
|
|
318
|
+
]);
|
|
319
|
+
(0, external_vitest_namespaceObject.expect)(selected).toBe("repeat");
|
|
320
|
+
});
|
|
321
|
+
});
|
|
322
|
+
(0, external_vitest_namespaceObject.describe)("detectStreamErrorMessage", ()=>{
|
|
323
|
+
(0, external_vitest_namespaceObject.it)("extracts non-tool stream error messages", ()=>{
|
|
324
|
+
const detected = (0, agentInvoker_cjs_namespaceObject.detectStreamErrorMessage)({
|
|
325
|
+
event: "on_chat_model_error",
|
|
326
|
+
data: {
|
|
327
|
+
error: {
|
|
328
|
+
message: "Model call failed after retries"
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
});
|
|
332
|
+
(0, external_vitest_namespaceObject.expect)(detected).toBe("Model call failed after retries");
|
|
333
|
+
});
|
|
334
|
+
(0, external_vitest_namespaceObject.it)("ignores tool errors and non-error events", ()=>{
|
|
335
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.detectStreamErrorMessage)({
|
|
336
|
+
event: "on_tool_error",
|
|
337
|
+
data: {
|
|
338
|
+
error: "tool failed"
|
|
339
|
+
}
|
|
340
|
+
})).toBeUndefined();
|
|
341
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.detectStreamErrorMessage)({
|
|
342
|
+
event: "on_chat_model_stream",
|
|
343
|
+
data: {
|
|
344
|
+
chunk: {
|
|
345
|
+
text: "hello"
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
})).toBeUndefined();
|
|
349
|
+
});
|
|
350
|
+
});
|
|
351
|
+
(0, external_vitest_namespaceObject.describe)("evaluateStreamingCompletion", ()=>{
|
|
352
|
+
(0, external_vitest_namespaceObject.it)("blocks with stream_error when no assistant text and stream error exists", ()=>{
|
|
353
|
+
const result = (0, agentInvoker_cjs_namespaceObject.evaluateStreamingCompletion)({
|
|
354
|
+
sawAssistantText: false,
|
|
355
|
+
fallbackText: void 0,
|
|
356
|
+
streamErrorMessage: "provider timeout"
|
|
357
|
+
});
|
|
358
|
+
(0, external_vitest_namespaceObject.expect)(result).toEqual({
|
|
359
|
+
status: "blocked",
|
|
360
|
+
reason: "stream_error",
|
|
361
|
+
message: "Model call failed: provider timeout"
|
|
362
|
+
});
|
|
363
|
+
});
|
|
364
|
+
(0, external_vitest_namespaceObject.it)("blocks with empty_stream_response when no text or fallback is present", ()=>{
|
|
365
|
+
const result = (0, agentInvoker_cjs_namespaceObject.evaluateStreamingCompletion)({
|
|
366
|
+
sawAssistantText: false,
|
|
367
|
+
fallbackText: void 0,
|
|
368
|
+
streamErrorMessage: void 0
|
|
369
|
+
});
|
|
370
|
+
(0, external_vitest_namespaceObject.expect)(result).toEqual({
|
|
371
|
+
status: "blocked",
|
|
372
|
+
reason: "empty_stream_response",
|
|
373
|
+
message: "Model completed without a response. Check provider logs for request errors."
|
|
374
|
+
});
|
|
375
|
+
});
|
|
376
|
+
(0, external_vitest_namespaceObject.it)("returns ok when assistant text exists", ()=>{
|
|
377
|
+
const result = (0, agentInvoker_cjs_namespaceObject.evaluateStreamingCompletion)({
|
|
378
|
+
sawAssistantText: true,
|
|
379
|
+
fallbackText: void 0,
|
|
380
|
+
streamErrorMessage: void 0
|
|
381
|
+
});
|
|
382
|
+
(0, external_vitest_namespaceObject.expect)(result).toEqual({
|
|
383
|
+
status: "ok"
|
|
384
|
+
});
|
|
385
|
+
});
|
|
386
|
+
});
|
|
387
|
+
(0, external_vitest_namespaceObject.describe)("LangGraph lifecycle termination", ()=>{
|
|
388
|
+
(0, external_vitest_namespaceObject.it)("tracks root LangGraph run id from parentless on_chain_start", ()=>{
|
|
389
|
+
const rootRunId = (0, agentInvoker_cjs_namespaceObject.trackRootLangGraphRunId)(void 0, {
|
|
390
|
+
event: "on_chain_start",
|
|
391
|
+
name: "LangGraph",
|
|
392
|
+
run_id: "root-run",
|
|
393
|
+
parent_ids: []
|
|
394
|
+
});
|
|
395
|
+
(0, external_vitest_namespaceObject.expect)(rootRunId).toBe("root-run");
|
|
396
|
+
});
|
|
397
|
+
(0, external_vitest_namespaceObject.it)("ignores non-root or non-LangGraph start events", ()=>{
|
|
398
|
+
const nestedRunId = (0, agentInvoker_cjs_namespaceObject.trackRootLangGraphRunId)(void 0, {
|
|
399
|
+
event: "on_chain_start",
|
|
400
|
+
name: "LangGraph",
|
|
401
|
+
run_id: "child-run",
|
|
402
|
+
parent_ids: [
|
|
403
|
+
"root-run"
|
|
404
|
+
]
|
|
405
|
+
});
|
|
406
|
+
(0, external_vitest_namespaceObject.expect)(nestedRunId).toBeUndefined();
|
|
407
|
+
const otherChainRunId = (0, agentInvoker_cjs_namespaceObject.trackRootLangGraphRunId)(void 0, {
|
|
408
|
+
event: "on_chain_start",
|
|
409
|
+
name: "CustomChain",
|
|
410
|
+
run_id: "other-run",
|
|
411
|
+
parent_ids: []
|
|
412
|
+
});
|
|
413
|
+
(0, external_vitest_namespaceObject.expect)(otherChainRunId).toBeUndefined();
|
|
414
|
+
});
|
|
415
|
+
(0, external_vitest_namespaceObject.it)("detects terminal root LangGraph on_chain_end by run id", ()=>{
|
|
416
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.isRootLangGraphTerminalEvent)({
|
|
417
|
+
event: "on_chain_end",
|
|
418
|
+
name: "LangGraph",
|
|
419
|
+
run_id: "root-run",
|
|
420
|
+
parent_ids: []
|
|
421
|
+
}, "root-run")).toBe(true);
|
|
422
|
+
});
|
|
423
|
+
(0, external_vitest_namespaceObject.it)("does not treat nested, mismatched, or non-LangGraph chain end as terminal", ()=>{
|
|
424
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.isRootLangGraphTerminalEvent)({
|
|
425
|
+
event: "on_chain_end",
|
|
426
|
+
name: "LangGraph",
|
|
427
|
+
run_id: "child-run",
|
|
428
|
+
parent_ids: [
|
|
429
|
+
"root-run"
|
|
430
|
+
]
|
|
431
|
+
}, "root-run")).toBe(false);
|
|
432
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.isRootLangGraphTerminalEvent)({
|
|
433
|
+
event: "on_chain_end",
|
|
434
|
+
name: "LangGraph",
|
|
435
|
+
run_id: "other-run",
|
|
436
|
+
parent_ids: []
|
|
437
|
+
}, "root-run")).toBe(false);
|
|
438
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.isRootLangGraphTerminalEvent)({
|
|
439
|
+
event: "on_chain_end",
|
|
440
|
+
name: "CustomChain",
|
|
441
|
+
run_id: "root-run",
|
|
442
|
+
parent_ids: []
|
|
443
|
+
}, "root-run")).toBe(false);
|
|
444
|
+
(0, external_vitest_namespaceObject.expect)((0, agentInvoker_cjs_namespaceObject.isRootLangGraphTerminalEvent)({
|
|
445
|
+
event: "on_chain_end",
|
|
446
|
+
name: "LangGraph",
|
|
447
|
+
run_id: "root-run",
|
|
448
|
+
parent_ids: []
|
|
449
|
+
}, void 0)).toBe(false);
|
|
450
|
+
});
|
|
451
|
+
});
|
|
452
|
+
for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
453
|
+
Object.defineProperty(exports, '__esModule', {
|
|
454
|
+
value: true
|
|
455
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|