@illuma-ai/agents 1.1.21 → 1.1.22
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/cjs/graphs/Graph.cjs +12 -1
- package/dist/cjs/graphs/Graph.cjs.map +1 -1
- package/dist/cjs/graphs/MultiAgentGraph.cjs +85 -1
- package/dist/cjs/graphs/MultiAgentGraph.cjs.map +1 -1
- package/dist/cjs/run.cjs +20 -9
- package/dist/cjs/run.cjs.map +1 -1
- package/dist/esm/graphs/Graph.mjs +12 -1
- package/dist/esm/graphs/Graph.mjs.map +1 -1
- package/dist/esm/graphs/MultiAgentGraph.mjs +85 -1
- package/dist/esm/graphs/MultiAgentGraph.mjs.map +1 -1
- package/dist/esm/run.mjs +20 -9
- package/dist/esm/run.mjs.map +1 -1
- package/dist/types/graphs/MultiAgentGraph.d.ts +17 -0
- package/package.json +1 -1
- package/src/graphs/Graph.ts +12 -1
- package/src/graphs/MultiAgentGraph.ts +105 -1
- package/src/graphs/__tests__/multi-agent-delegate.test.ts +191 -0
- package/src/run.ts +20 -11
- package/src/scripts/test-bedrock-handoff-autonomous.ts +231 -0
- package/src/agents/AgentContext.js +0 -782
- package/src/agents/AgentContext.test.js +0 -421
- package/src/agents/__tests__/AgentContext.test.js +0 -678
- package/src/agents/__tests__/resolveStructuredOutputMode.test.js +0 -117
- package/src/common/enum.js +0 -192
- package/src/common/index.js +0 -3
- package/src/events.js +0 -166
- package/src/graphs/Graph.js +0 -1857
- package/src/graphs/MultiAgentGraph.js +0 -1092
- package/src/graphs/__tests__/structured-output.integration.test.js +0 -624
- package/src/graphs/__tests__/structured-output.test.js +0 -144
- package/src/graphs/contextManagement.e2e.test.js +0 -718
- package/src/graphs/contextManagement.test.js +0 -485
- package/src/graphs/handoffValidation.test.js +0 -276
- package/src/graphs/index.js +0 -3
- package/src/index.js +0 -28
- package/src/instrumentation.js +0 -21
- package/src/llm/anthropic/index.js +0 -319
- package/src/llm/anthropic/types.js +0 -46
- package/src/llm/anthropic/utils/message_inputs.js +0 -627
- package/src/llm/anthropic/utils/message_outputs.js +0 -290
- package/src/llm/anthropic/utils/output_parsers.js +0 -89
- package/src/llm/anthropic/utils/tools.js +0 -25
- package/src/llm/bedrock/__tests__/bedrock-caching.test.js +0 -392
- package/src/llm/bedrock/index.js +0 -303
- package/src/llm/bedrock/types.js +0 -2
- package/src/llm/bedrock/utils/index.js +0 -6
- package/src/llm/bedrock/utils/message_inputs.js +0 -463
- package/src/llm/bedrock/utils/message_outputs.js +0 -269
- package/src/llm/fake.js +0 -92
- package/src/llm/google/index.js +0 -215
- package/src/llm/google/types.js +0 -12
- package/src/llm/google/utils/common.js +0 -670
- package/src/llm/google/utils/tools.js +0 -111
- package/src/llm/google/utils/zod_to_genai_parameters.js +0 -47
- package/src/llm/openai/index.js +0 -1033
- package/src/llm/openai/types.js +0 -2
- package/src/llm/openai/utils/index.js +0 -756
- package/src/llm/openai/utils/isReasoningModel.test.js +0 -79
- package/src/llm/openrouter/index.js +0 -261
- package/src/llm/openrouter/reasoning.test.js +0 -181
- package/src/llm/providers.js +0 -36
- package/src/llm/text.js +0 -65
- package/src/llm/vertexai/index.js +0 -402
- package/src/messages/__tests__/tools.test.js +0 -392
- package/src/messages/cache.js +0 -404
- package/src/messages/cache.test.js +0 -1167
- package/src/messages/content.js +0 -48
- package/src/messages/content.test.js +0 -314
- package/src/messages/core.js +0 -359
- package/src/messages/ensureThinkingBlock.test.js +0 -997
- package/src/messages/format.js +0 -973
- package/src/messages/formatAgentMessages.test.js +0 -2278
- package/src/messages/formatAgentMessages.tools.test.js +0 -362
- package/src/messages/formatMessage.test.js +0 -608
- package/src/messages/ids.js +0 -18
- package/src/messages/index.js +0 -9
- package/src/messages/labelContentByAgent.test.js +0 -725
- package/src/messages/prune.js +0 -438
- package/src/messages/reducer.js +0 -60
- package/src/messages/shiftIndexTokenCountMap.test.js +0 -63
- package/src/messages/summarize.js +0 -146
- package/src/messages/summarize.test.js +0 -332
- package/src/messages/tools.js +0 -90
- package/src/mockStream.js +0 -81
- package/src/prompts/collab.js +0 -7
- package/src/prompts/index.js +0 -3
- package/src/prompts/taskmanager.js +0 -58
- package/src/run.js +0 -427
- package/src/schemas/index.js +0 -3
- package/src/schemas/schema-preparation.test.js +0 -370
- package/src/schemas/validate.js +0 -314
- package/src/schemas/validate.test.js +0 -264
- package/src/scripts/abort.js +0 -127
- package/src/scripts/ant_web_search.js +0 -130
- package/src/scripts/ant_web_search_edge_case.js +0 -133
- package/src/scripts/ant_web_search_error_edge_case.js +0 -119
- package/src/scripts/args.js +0 -41
- package/src/scripts/bedrock-cache-debug.js +0 -186
- package/src/scripts/bedrock-content-aggregation-test.js +0 -195
- package/src/scripts/bedrock-merge-test.js +0 -80
- package/src/scripts/bedrock-parallel-tools-test.js +0 -150
- package/src/scripts/caching.js +0 -106
- package/src/scripts/cli.js +0 -152
- package/src/scripts/cli2.js +0 -119
- package/src/scripts/cli3.js +0 -163
- package/src/scripts/cli4.js +0 -165
- package/src/scripts/cli5.js +0 -165
- package/src/scripts/code_exec.js +0 -171
- package/src/scripts/code_exec_files.js +0 -180
- package/src/scripts/code_exec_multi_session.js +0 -185
- package/src/scripts/code_exec_ptc.js +0 -265
- package/src/scripts/code_exec_session.js +0 -217
- package/src/scripts/code_exec_simple.js +0 -120
- package/src/scripts/content.js +0 -111
- package/src/scripts/empty_input.js +0 -125
- package/src/scripts/handoff-test.js +0 -96
- package/src/scripts/image.js +0 -138
- package/src/scripts/memory.js +0 -83
- package/src/scripts/multi-agent-chain.js +0 -271
- package/src/scripts/multi-agent-conditional.js +0 -185
- package/src/scripts/multi-agent-document-review-chain.js +0 -171
- package/src/scripts/multi-agent-hybrid-flow.js +0 -264
- package/src/scripts/multi-agent-parallel-start.js +0 -214
- package/src/scripts/multi-agent-parallel.js +0 -346
- package/src/scripts/multi-agent-sequence.js +0 -184
- package/src/scripts/multi-agent-supervisor.js +0 -324
- package/src/scripts/multi-agent-test.js +0 -147
- package/src/scripts/parallel-asymmetric-tools-test.js +0 -202
- package/src/scripts/parallel-full-metadata-test.js +0 -176
- package/src/scripts/parallel-tools-test.js +0 -256
- package/src/scripts/programmatic_exec.js +0 -277
- package/src/scripts/programmatic_exec_agent.js +0 -168
- package/src/scripts/search.js +0 -118
- package/src/scripts/sequential-full-metadata-test.js +0 -143
- package/src/scripts/simple.js +0 -174
- package/src/scripts/single-agent-metadata-test.js +0 -152
- package/src/scripts/stream.js +0 -113
- package/src/scripts/test-custom-prompt-key.js +0 -132
- package/src/scripts/test-handoff-input.js +0 -143
- package/src/scripts/test-handoff-preamble.js +0 -227
- package/src/scripts/test-handoff-steering.js +0 -353
- package/src/scripts/test-multi-agent-list-handoff.js +0 -318
- package/src/scripts/test-parallel-agent-labeling.js +0 -253
- package/src/scripts/test-parallel-handoffs.js +0 -229
- package/src/scripts/test-thinking-handoff-bedrock.js +0 -132
- package/src/scripts/test-thinking-handoff.js +0 -132
- package/src/scripts/test-thinking-to-thinking-handoff-bedrock.js +0 -140
- package/src/scripts/test-tool-before-handoff-role-order.js +0 -223
- package/src/scripts/test-tools-before-handoff.js +0 -187
- package/src/scripts/test_code_api.js +0 -263
- package/src/scripts/thinking-bedrock.js +0 -128
- package/src/scripts/thinking-vertexai.js +0 -130
- package/src/scripts/thinking.js +0 -134
- package/src/scripts/tool_search.js +0 -114
- package/src/scripts/tools.js +0 -125
- package/src/specs/agent-handoffs-bedrock.integration.test.js +0 -280
- package/src/specs/agent-handoffs.test.js +0 -924
- package/src/specs/anthropic.simple.test.js +0 -287
- package/src/specs/azure.simple.test.js +0 -381
- package/src/specs/cache.simple.test.js +0 -282
- package/src/specs/custom-event-await.test.js +0 -148
- package/src/specs/deepseek.simple.test.js +0 -189
- package/src/specs/emergency-prune.test.js +0 -308
- package/src/specs/moonshot.simple.test.js +0 -237
- package/src/specs/observability.integration.test.js +0 -1337
- package/src/specs/openai.simple.test.js +0 -233
- package/src/specs/openrouter.simple.test.js +0 -202
- package/src/specs/prune.test.js +0 -733
- package/src/specs/reasoning.test.js +0 -144
- package/src/specs/spec.utils.js +0 -4
- package/src/specs/thinking-handoff.test.js +0 -486
- package/src/specs/thinking-prune.test.js +0 -600
- package/src/specs/token-distribution-edge-case.test.js +0 -246
- package/src/specs/token-memoization.test.js +0 -32
- package/src/specs/tokens.test.js +0 -49
- package/src/specs/tool-error.test.js +0 -139
- package/src/splitStream.js +0 -204
- package/src/splitStream.test.js +0 -504
- package/src/stream.js +0 -650
- package/src/stream.test.js +0 -225
- package/src/test/mockTools.js +0 -340
- package/src/tools/BrowserTools.js +0 -245
- package/src/tools/Calculator.js +0 -38
- package/src/tools/Calculator.test.js +0 -225
- package/src/tools/CodeExecutor.js +0 -233
- package/src/tools/ProgrammaticToolCalling.js +0 -602
- package/src/tools/StreamingToolCallBuffer.js +0 -179
- package/src/tools/ToolNode.js +0 -930
- package/src/tools/ToolSearch.js +0 -904
- package/src/tools/__tests__/BrowserTools.test.js +0 -306
- package/src/tools/__tests__/ProgrammaticToolCalling.integration.test.js +0 -276
- package/src/tools/__tests__/ProgrammaticToolCalling.test.js +0 -807
- package/src/tools/__tests__/StreamingToolCallBuffer.test.js +0 -175
- package/src/tools/__tests__/ToolApproval.test.js +0 -675
- package/src/tools/__tests__/ToolNode.recovery.test.js +0 -200
- package/src/tools/__tests__/ToolNode.session.test.js +0 -319
- package/src/tools/__tests__/ToolSearch.integration.test.js +0 -125
- package/src/tools/__tests__/ToolSearch.test.js +0 -812
- package/src/tools/__tests__/handlers.test.js +0 -799
- package/src/tools/__tests__/truncation-recovery.integration.test.js +0 -362
- package/src/tools/handlers.js +0 -306
- package/src/tools/schema.js +0 -25
- package/src/tools/search/anthropic.js +0 -34
- package/src/tools/search/content.js +0 -116
- package/src/tools/search/content.test.js +0 -133
- package/src/tools/search/firecrawl.js +0 -173
- package/src/tools/search/format.js +0 -198
- package/src/tools/search/highlights.js +0 -241
- package/src/tools/search/index.js +0 -3
- package/src/tools/search/jina-reranker.test.js +0 -106
- package/src/tools/search/rerankers.js +0 -165
- package/src/tools/search/schema.js +0 -102
- package/src/tools/search/search.js +0 -561
- package/src/tools/search/serper-scraper.js +0 -126
- package/src/tools/search/test.js +0 -129
- package/src/tools/search/tool.js +0 -453
- package/src/tools/search/types.js +0 -2
- package/src/tools/search/utils.js +0 -59
- package/src/types/graph.js +0 -24
- package/src/types/graph.test.js +0 -192
- package/src/types/index.js +0 -7
- package/src/types/llm.js +0 -2
- package/src/types/messages.js +0 -2
- package/src/types/run.js +0 -2
- package/src/types/stream.js +0 -2
- package/src/types/tools.js +0 -2
- package/src/utils/contextAnalytics.js +0 -79
- package/src/utils/contextAnalytics.test.js +0 -166
- package/src/utils/events.js +0 -26
- package/src/utils/graph.js +0 -11
- package/src/utils/handlers.js +0 -65
- package/src/utils/index.js +0 -10
- package/src/utils/llm.js +0 -21
- package/src/utils/llmConfig.js +0 -205
- package/src/utils/logging.js +0 -37
- package/src/utils/misc.js +0 -51
- package/src/utils/run.js +0 -69
- package/src/utils/schema.js +0 -21
- package/src/utils/title.js +0 -119
- package/src/utils/tokens.js +0 -92
- package/src/utils/toonFormat.js +0 -379
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
import { StreamingToolCallBuffer } from '../StreamingToolCallBuffer';
|
|
2
|
-
describe('StreamingToolCallBuffer', () => {
|
|
3
|
-
let buffer;
|
|
4
|
-
beforeEach(() => {
|
|
5
|
-
buffer = new StreamingToolCallBuffer();
|
|
6
|
-
});
|
|
7
|
-
describe('append', () => {
|
|
8
|
-
it('should accumulate arg chunks for a tool call ID', () => {
|
|
9
|
-
buffer.append('tc_1', '{"action":"wri');
|
|
10
|
-
buffer.append('tc_1', 'te","content":"hello');
|
|
11
|
-
expect(buffer.getRawArgs('tc_1')).toBe('{"action":"write","content":"hello');
|
|
12
|
-
});
|
|
13
|
-
it('should track multiple tool calls independently', () => {
|
|
14
|
-
buffer.append('tc_1', '{"action":"write"}');
|
|
15
|
-
buffer.append('tc_2', '{"action":"read"}');
|
|
16
|
-
expect(buffer.getRawArgs('tc_1')).toBe('{"action":"write"}');
|
|
17
|
-
expect(buffer.getRawArgs('tc_2')).toBe('{"action":"read"}');
|
|
18
|
-
});
|
|
19
|
-
it('should return undefined for unknown tool call IDs', () => {
|
|
20
|
-
expect(buffer.getRawArgs('unknown')).toBeUndefined();
|
|
21
|
-
});
|
|
22
|
-
});
|
|
23
|
-
describe('setToolName / getToolName', () => {
|
|
24
|
-
it('should store and retrieve tool names', () => {
|
|
25
|
-
buffer.setToolName('tc_1', 'content_tool');
|
|
26
|
-
expect(buffer.getToolName('tc_1')).toBe('content_tool');
|
|
27
|
-
});
|
|
28
|
-
it('should not overwrite an existing tool name', () => {
|
|
29
|
-
buffer.setToolName('tc_1', 'content_tool');
|
|
30
|
-
buffer.setToolName('tc_1', 'other_tool');
|
|
31
|
-
expect(buffer.getToolName('tc_1')).toBe('content_tool');
|
|
32
|
-
});
|
|
33
|
-
it('should return undefined for unknown tool calls', () => {
|
|
34
|
-
expect(buffer.getToolName('unknown')).toBeUndefined();
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
describe('extractFieldValue', () => {
|
|
38
|
-
it('should extract a simple string field', () => {
|
|
39
|
-
buffer.append('tc_1', '{"action":"write","filename":"test.tsx"}');
|
|
40
|
-
expect(buffer.extractFieldValue('tc_1', 'action')).toBe('write');
|
|
41
|
-
expect(buffer.extractFieldValue('tc_1', 'filename')).toBe('test.tsx');
|
|
42
|
-
});
|
|
43
|
-
it('should extract content with escaped characters', () => {
|
|
44
|
-
buffer.append('tc_1', '{"content":"line1\\nline2\\ttab"}');
|
|
45
|
-
expect(buffer.extractFieldValue('tc_1', 'content')).toBe('line1\nline2\ttab');
|
|
46
|
-
});
|
|
47
|
-
it('should extract content with escaped quotes', () => {
|
|
48
|
-
buffer.append('tc_1', '{"content":"say \\"hello\\""}');
|
|
49
|
-
expect(buffer.extractFieldValue('tc_1', 'content')).toBe('say "hello"');
|
|
50
|
-
});
|
|
51
|
-
it('should extract content with escaped backslashes', () => {
|
|
52
|
-
buffer.append('tc_1', '{"content":"path\\\\to\\\\file"}');
|
|
53
|
-
expect(buffer.extractFieldValue('tc_1', 'content')).toBe('path\\to\\file');
|
|
54
|
-
});
|
|
55
|
-
it('should handle truncated content (no closing quote)', () => {
|
|
56
|
-
buffer.append('tc_1', '{"action":"write","content":"function App() {\\n return <div>He');
|
|
57
|
-
const content = buffer.extractFieldValue('tc_1', 'content');
|
|
58
|
-
expect(content).toBe('function App() {\n return <div>He');
|
|
59
|
-
});
|
|
60
|
-
it('should handle field with space before colon', () => {
|
|
61
|
-
buffer.append('tc_1', '{"content": "value with space"}');
|
|
62
|
-
expect(buffer.extractFieldValue('tc_1', 'content')).toBe('value with space');
|
|
63
|
-
});
|
|
64
|
-
it('should handle field with spaces around colon', () => {
|
|
65
|
-
buffer.append('tc_1', '{"content" : "value"}');
|
|
66
|
-
expect(buffer.extractFieldValue('tc_1', 'content')).toBe('value');
|
|
67
|
-
});
|
|
68
|
-
it('should return undefined for missing field', () => {
|
|
69
|
-
buffer.append('tc_1', '{"action":"write"}');
|
|
70
|
-
expect(buffer.extractFieldValue('tc_1', 'content')).toBeUndefined();
|
|
71
|
-
});
|
|
72
|
-
it('should return undefined for unknown tool call ID', () => {
|
|
73
|
-
expect(buffer.extractFieldValue('unknown', 'content')).toBeUndefined();
|
|
74
|
-
});
|
|
75
|
-
it('should extract large content (simulating 30k+ token file)', () => {
|
|
76
|
-
const largeContent = 'x'.repeat(50000);
|
|
77
|
-
buffer.append('tc_1', `{"action":"write","content":"${largeContent}"}`);
|
|
78
|
-
expect(buffer.extractFieldValue('tc_1', 'content')).toBe(largeContent);
|
|
79
|
-
});
|
|
80
|
-
it('should extract from incrementally streamed chunks', () => {
|
|
81
|
-
// Simulate real streaming: args arrive in small chunks
|
|
82
|
-
const chunks = [
|
|
83
|
-
'{"action":"w',
|
|
84
|
-
'rite","file',
|
|
85
|
-
'name":"app.tsx","con',
|
|
86
|
-
'tent":"import React',
|
|
87
|
-
' from \'react\';\\n',
|
|
88
|
-
'export default func',
|
|
89
|
-
'tion App() {\\n ret',
|
|
90
|
-
'urn <div>Hello</div',
|
|
91
|
-
'>;\\n}',
|
|
92
|
-
];
|
|
93
|
-
for (const chunk of chunks) {
|
|
94
|
-
buffer.append('tc_1', chunk);
|
|
95
|
-
}
|
|
96
|
-
expect(buffer.extractFieldValue('tc_1', 'action')).toBe('write');
|
|
97
|
-
expect(buffer.extractFieldValue('tc_1', 'filename')).toBe('app.tsx');
|
|
98
|
-
expect(buffer.extractFieldValue('tc_1', 'content')).toBe("import React from 'react';\nexport default function App() {\n return <div>Hello</div>;\n}");
|
|
99
|
-
});
|
|
100
|
-
});
|
|
101
|
-
describe('has', () => {
|
|
102
|
-
it('should return true for tracked tool calls', () => {
|
|
103
|
-
buffer.append('tc_1', '{}');
|
|
104
|
-
expect(buffer.has('tc_1')).toBe(true);
|
|
105
|
-
});
|
|
106
|
-
it('should return false for untracked tool calls', () => {
|
|
107
|
-
expect(buffer.has('tc_1')).toBe(false);
|
|
108
|
-
});
|
|
109
|
-
});
|
|
110
|
-
describe('clear', () => {
|
|
111
|
-
it('should remove a specific tool call', () => {
|
|
112
|
-
buffer.append('tc_1', '{"a":1}');
|
|
113
|
-
buffer.setToolName('tc_1', 'test_tool');
|
|
114
|
-
buffer.clear('tc_1');
|
|
115
|
-
expect(buffer.has('tc_1')).toBe(false);
|
|
116
|
-
expect(buffer.getRawArgs('tc_1')).toBeUndefined();
|
|
117
|
-
expect(buffer.getToolName('tc_1')).toBeUndefined();
|
|
118
|
-
});
|
|
119
|
-
it('should not affect other tool calls', () => {
|
|
120
|
-
buffer.append('tc_1', '{"a":1}');
|
|
121
|
-
buffer.append('tc_2', '{"b":2}');
|
|
122
|
-
buffer.clear('tc_1');
|
|
123
|
-
expect(buffer.has('tc_2')).toBe(true);
|
|
124
|
-
});
|
|
125
|
-
});
|
|
126
|
-
describe('clearAll', () => {
|
|
127
|
-
it('should remove all tool calls', () => {
|
|
128
|
-
buffer.append('tc_1', '{"a":1}');
|
|
129
|
-
buffer.append('tc_2', '{"b":2}');
|
|
130
|
-
buffer.setToolName('tc_1', 'tool_a');
|
|
131
|
-
buffer.setToolName('tc_2', 'tool_b');
|
|
132
|
-
buffer.clearAll();
|
|
133
|
-
expect(buffer.has('tc_1')).toBe(false);
|
|
134
|
-
expect(buffer.has('tc_2')).toBe(false);
|
|
135
|
-
expect(buffer.getToolName('tc_1')).toBeUndefined();
|
|
136
|
-
expect(buffer.getToolName('tc_2')).toBeUndefined();
|
|
137
|
-
});
|
|
138
|
-
it('should clear index-to-id mappings', () => {
|
|
139
|
-
buffer.setIndexMapping(0, 'tc_1');
|
|
140
|
-
buffer.setIndexMapping(1, 'tc_2');
|
|
141
|
-
buffer.clearAll();
|
|
142
|
-
expect(buffer.getIdByIndex(0)).toBeUndefined();
|
|
143
|
-
expect(buffer.getIdByIndex(1)).toBeUndefined();
|
|
144
|
-
});
|
|
145
|
-
});
|
|
146
|
-
describe('setIndexMapping / getIdByIndex', () => {
|
|
147
|
-
it('should store and retrieve index-to-id mappings', () => {
|
|
148
|
-
buffer.setIndexMapping(0, 'tc_1');
|
|
149
|
-
buffer.setIndexMapping(1, 'tc_2');
|
|
150
|
-
expect(buffer.getIdByIndex(0)).toBe('tc_1');
|
|
151
|
-
expect(buffer.getIdByIndex(1)).toBe('tc_2');
|
|
152
|
-
});
|
|
153
|
-
it('should return undefined for unmapped index', () => {
|
|
154
|
-
expect(buffer.getIdByIndex(99)).toBeUndefined();
|
|
155
|
-
});
|
|
156
|
-
it('should overwrite existing index mapping', () => {
|
|
157
|
-
buffer.setIndexMapping(0, 'tc_old');
|
|
158
|
-
buffer.setIndexMapping(0, 'tc_new');
|
|
159
|
-
expect(buffer.getIdByIndex(0)).toBe('tc_new');
|
|
160
|
-
});
|
|
161
|
-
it('should support Bedrock streaming pattern end-to-end', () => {
|
|
162
|
-
// START chunk: id + name + index
|
|
163
|
-
buffer.setIndexMapping(0, 'tooluse_abc');
|
|
164
|
-
buffer.setToolName('tooluse_abc', 'content_tool');
|
|
165
|
-
// DELTA chunks: args + index (no id)
|
|
166
|
-
const resolvedId = buffer.getIdByIndex(0);
|
|
167
|
-
expect(resolvedId).toBe('tooluse_abc');
|
|
168
|
-
buffer.append(resolvedId, '{"action":"wri');
|
|
169
|
-
buffer.append(resolvedId, 'te","content":"hello"}');
|
|
170
|
-
expect(buffer.getRawArgs('tooluse_abc')).toBe('{"action":"write","content":"hello"}');
|
|
171
|
-
expect(buffer.getToolName('tooluse_abc')).toBe('content_tool');
|
|
172
|
-
});
|
|
173
|
-
});
|
|
174
|
-
});
|
|
175
|
-
//# sourceMappingURL=StreamingToolCallBuffer.test.js.map
|