@strands-agents/sdk 0.3.0 → 0.5.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/README.md +43 -0
- package/dist/src/__fixtures__/agent-helpers.d.ts +10 -1
- package/dist/src/__fixtures__/agent-helpers.d.ts.map +1 -1
- package/dist/src/__fixtures__/agent-helpers.js +13 -2
- package/dist/src/__fixtures__/agent-helpers.js.map +1 -1
- package/dist/src/__fixtures__/mock-hook-provider.d.ts +3 -7
- package/dist/src/__fixtures__/mock-hook-provider.d.ts.map +1 -1
- package/dist/src/__fixtures__/mock-hook-provider.js +3 -9
- package/dist/src/__fixtures__/mock-hook-provider.js.map +1 -1
- package/dist/src/__fixtures__/mock-message-model.d.ts +8 -2
- package/dist/src/__fixtures__/mock-message-model.d.ts.map +1 -1
- package/dist/src/__fixtures__/mock-message-model.js +1 -0
- package/dist/src/__fixtures__/mock-message-model.js.map +1 -1
- package/dist/src/__fixtures__/mock-span.d.ts +78 -0
- package/dist/src/__fixtures__/mock-span.d.ts.map +1 -0
- package/dist/src/__fixtures__/mock-span.js +93 -0
- package/dist/src/__fixtures__/mock-span.js.map +1 -0
- package/dist/src/__fixtures__/mock-storage-provider.d.ts +37 -0
- package/dist/src/__fixtures__/mock-storage-provider.d.ts.map +1 -0
- package/dist/src/__fixtures__/mock-storage-provider.js +105 -0
- package/dist/src/__fixtures__/mock-storage-provider.js.map +1 -0
- package/dist/src/__fixtures__/slim-types.d.ts +50 -0
- package/dist/src/__fixtures__/slim-types.d.ts.map +1 -0
- package/dist/src/__fixtures__/slim-types.js +6 -0
- package/dist/src/__fixtures__/slim-types.js.map +1 -0
- package/dist/src/__fixtures__/tool-helpers.d.ts +10 -5
- package/dist/src/__fixtures__/tool-helpers.d.ts.map +1 -1
- package/dist/src/__fixtures__/tool-helpers.js +5 -5
- package/dist/src/__fixtures__/tool-helpers.js.map +1 -1
- package/dist/src/__tests__/app-state.test.d.ts +2 -0
- package/dist/src/__tests__/app-state.test.d.ts.map +1 -0
- package/dist/src/{agent/__tests__/state.test.js → __tests__/app-state.test.js} +62 -43
- package/dist/src/__tests__/app-state.test.js.map +1 -0
- package/dist/src/__tests__/mcp.test.js +96 -15
- package/dist/src/__tests__/mcp.test.js.map +1 -1
- package/dist/src/agent/__tests__/agent.hook.test.js +18 -18
- package/dist/src/agent/__tests__/agent.hook.test.js.map +1 -1
- package/dist/src/agent/__tests__/agent.test.js +234 -8
- package/dist/src/agent/__tests__/agent.test.js.map +1 -1
- package/dist/src/agent/__tests__/agent.tracer.test.d.ts +2 -0
- package/dist/src/agent/__tests__/agent.tracer.test.d.ts.map +1 -0
- package/dist/src/agent/__tests__/agent.tracer.test.js +470 -0
- package/dist/src/agent/__tests__/agent.tracer.test.js.map +1 -0
- package/dist/src/agent/__tests__/printer.test.js +5 -9
- package/dist/src/agent/__tests__/printer.test.js.map +1 -1
- package/dist/src/agent/__tests__/snapshot.test.d.ts +2 -0
- package/dist/src/agent/__tests__/snapshot.test.d.ts.map +1 -0
- package/dist/src/agent/__tests__/snapshot.test.js +249 -0
- package/dist/src/agent/__tests__/snapshot.test.js.map +1 -0
- package/dist/src/agent/agent.d.ts +78 -10
- package/dist/src/agent/agent.d.ts.map +1 -1
- package/dist/src/agent/agent.js +252 -55
- package/dist/src/agent/agent.js.map +1 -1
- package/dist/src/agent/printer.d.ts +4 -0
- package/dist/src/agent/printer.d.ts.map +1 -1
- package/dist/src/agent/printer.js +18 -6
- package/dist/src/agent/printer.js.map +1 -1
- package/dist/src/agent/snapshot.d.ts +132 -0
- package/dist/src/agent/snapshot.d.ts.map +1 -0
- package/dist/src/agent/snapshot.js +151 -0
- package/dist/src/agent/snapshot.js.map +1 -0
- package/dist/src/{agent/state.d.ts → app-state.d.ts} +19 -6
- package/dist/src/app-state.d.ts.map +1 -0
- package/dist/src/{agent/state.js → app-state.js} +27 -6
- package/dist/src/app-state.js.map +1 -0
- package/dist/src/conversation-manager/sliding-window-conversation-manager.d.ts +1 -1
- package/dist/src/conversation-manager/sliding-window-conversation-manager.js +1 -1
- package/dist/src/errors.d.ts +15 -0
- package/dist/src/errors.d.ts.map +1 -1
- package/dist/src/errors.js +18 -0
- package/dist/src/errors.js.map +1 -1
- package/dist/src/hooks/__tests__/events.test.js +102 -21
- package/dist/src/hooks/__tests__/events.test.js.map +1 -1
- package/dist/src/hooks/events.d.ts +156 -22
- package/dist/src/hooks/events.d.ts.map +1 -1
- package/dist/src/hooks/events.js +158 -18
- package/dist/src/hooks/events.js.map +1 -1
- package/dist/src/hooks/index.d.ts +12 -4
- package/dist/src/hooks/index.d.ts.map +1 -1
- package/dist/src/hooks/index.js +11 -3
- package/dist/src/hooks/index.js.map +1 -1
- package/dist/src/hooks/registry.d.ts +5 -5
- package/dist/src/hooks/registry.d.ts.map +1 -1
- package/dist/src/hooks/registry.js.map +1 -1
- package/dist/src/hooks/types.d.ts +5 -5
- package/dist/src/hooks/types.d.ts.map +1 -1
- package/dist/src/index.d.ts +6 -3
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +8 -3
- package/dist/src/index.js.map +1 -1
- package/dist/src/mcp.d.ts +3 -0
- package/dist/src/mcp.d.ts.map +1 -1
- package/dist/src/mcp.js +38 -1
- package/dist/src/mcp.js.map +1 -1
- package/dist/src/models/__tests__/anthropic.test.js +31 -42
- package/dist/src/models/__tests__/anthropic.test.js.map +1 -1
- package/dist/src/models/__tests__/bedrock.test.js +70 -107
- package/dist/src/models/__tests__/bedrock.test.js.map +1 -1
- package/dist/src/models/__tests__/gemini.test.js +18 -18
- package/dist/src/models/__tests__/gemini.test.js.map +1 -1
- package/dist/src/models/__tests__/model.test.js +21 -13
- package/dist/src/models/__tests__/model.test.js.map +1 -1
- package/dist/src/models/__tests__/openai.test.js +73 -83
- package/dist/src/models/__tests__/openai.test.js.map +1 -1
- package/dist/src/models/model.d.ts +4 -0
- package/dist/src/models/model.d.ts.map +1 -1
- package/dist/src/models/model.js +6 -0
- package/dist/src/models/model.js.map +1 -1
- package/dist/src/models/streaming.d.ts +9 -1
- package/dist/src/models/streaming.d.ts.map +1 -1
- package/dist/src/models/streaming.js +17 -0
- package/dist/src/models/streaming.js.map +1 -1
- package/dist/src/multiagent/__tests__/events.test.d.ts +2 -0
- package/dist/src/multiagent/__tests__/events.test.d.ts.map +1 -0
- package/dist/src/multiagent/__tests__/events.test.js +189 -0
- package/dist/src/multiagent/__tests__/events.test.js.map +1 -0
- package/dist/src/multiagent/__tests__/nodes.test.d.ts +2 -0
- package/dist/src/multiagent/__tests__/nodes.test.d.ts.map +1 -0
- package/dist/src/multiagent/__tests__/nodes.test.js +194 -0
- package/dist/src/multiagent/__tests__/nodes.test.js.map +1 -0
- package/dist/src/multiagent/__tests__/queue.test.d.ts +2 -0
- package/dist/src/multiagent/__tests__/queue.test.d.ts.map +1 -0
- package/dist/src/multiagent/__tests__/queue.test.js +96 -0
- package/dist/src/multiagent/__tests__/queue.test.js.map +1 -0
- package/dist/src/multiagent/base.d.ts +25 -0
- package/dist/src/multiagent/base.d.ts.map +1 -0
- package/dist/src/multiagent/base.js +2 -0
- package/dist/src/multiagent/base.js.map +1 -0
- package/dist/src/multiagent/edge.d.ts +29 -0
- package/dist/src/multiagent/edge.d.ts.map +1 -0
- package/dist/src/multiagent/edge.js +15 -0
- package/dist/src/multiagent/edge.js.map +1 -0
- package/dist/src/multiagent/events.d.ts +135 -0
- package/dist/src/multiagent/events.d.ts.map +1 -0
- package/dist/src/multiagent/events.js +140 -0
- package/dist/src/multiagent/events.js.map +1 -0
- package/dist/src/multiagent/index.d.ts +13 -0
- package/dist/src/multiagent/index.d.ts.map +1 -0
- package/dist/src/multiagent/index.js +8 -0
- package/dist/src/multiagent/index.js.map +1 -0
- package/dist/src/multiagent/nodes.d.ts +123 -0
- package/dist/src/multiagent/nodes.d.ts.map +1 -0
- package/dist/src/multiagent/nodes.js +148 -0
- package/dist/src/multiagent/nodes.js.map +1 -0
- package/dist/src/multiagent/queue.d.ts +67 -0
- package/dist/src/multiagent/queue.d.ts.map +1 -0
- package/dist/src/multiagent/queue.js +59 -0
- package/dist/src/multiagent/queue.js.map +1 -0
- package/dist/src/multiagent/state.d.ts +122 -0
- package/dist/src/multiagent/state.d.ts.map +1 -0
- package/dist/src/multiagent/state.js +132 -0
- package/dist/src/multiagent/state.js.map +1 -0
- package/dist/src/registry/tool-registry.d.ts +2 -1
- package/dist/src/registry/tool-registry.d.ts.map +1 -1
- package/dist/src/registry/tool-registry.js +4 -2
- package/dist/src/registry/tool-registry.js.map +1 -1
- package/dist/src/session/__tests__/file-storage.test.node.d.ts +2 -0
- package/dist/src/session/__tests__/file-storage.test.node.d.ts.map +1 -0
- package/dist/src/session/__tests__/file-storage.test.node.js +218 -0
- package/dist/src/session/__tests__/file-storage.test.node.js.map +1 -0
- package/dist/src/session/__tests__/s3-storage.test.node.d.ts +2 -0
- package/dist/src/session/__tests__/s3-storage.test.node.d.ts.map +1 -0
- package/dist/src/session/__tests__/s3-storage.test.node.js +375 -0
- package/dist/src/session/__tests__/s3-storage.test.node.js.map +1 -0
- package/dist/src/session/__tests__/validation.test.d.ts +2 -0
- package/dist/src/session/__tests__/validation.test.d.ts.map +1 -0
- package/dist/src/session/__tests__/validation.test.js +20 -0
- package/dist/src/session/__tests__/validation.test.js.map +1 -0
- package/dist/src/session/file-storage.d.ts +79 -0
- package/dist/src/session/file-storage.d.ts.map +1 -0
- package/dist/src/session/file-storage.js +144 -0
- package/dist/src/session/file-storage.js.map +1 -0
- package/dist/src/session/index.d.ts +19 -0
- package/dist/src/session/index.d.ts.map +1 -0
- package/dist/src/session/index.js +18 -0
- package/dist/src/session/index.js.map +1 -0
- package/dist/src/session/s3-storage.d.ts +93 -0
- package/dist/src/session/s3-storage.d.ts.map +1 -0
- package/dist/src/session/s3-storage.js +150 -0
- package/dist/src/session/s3-storage.js.map +1 -0
- package/dist/src/session/storage.d.ts +91 -0
- package/dist/src/session/storage.d.ts.map +1 -0
- package/dist/src/session/storage.js +2 -0
- package/dist/src/session/storage.js.map +1 -0
- package/dist/src/session/types.d.ts +49 -0
- package/dist/src/session/types.d.ts.map +1 -0
- package/dist/src/session/types.js +2 -0
- package/dist/src/session/types.js.map +1 -0
- package/dist/src/session/validation.d.ts +10 -0
- package/dist/src/session/validation.d.ts.map +1 -0
- package/dist/src/session/validation.js +16 -0
- package/dist/src/session/validation.js.map +1 -0
- package/dist/src/structured-output/__tests__/context.test.d.ts +2 -0
- package/dist/src/structured-output/__tests__/context.test.d.ts.map +1 -0
- package/dist/src/structured-output/__tests__/context.test.js +201 -0
- package/dist/src/structured-output/__tests__/context.test.js.map +1 -0
- package/dist/src/structured-output/__tests__/exceptions.test.d.ts +2 -0
- package/dist/src/structured-output/__tests__/exceptions.test.d.ts.map +1 -0
- package/dist/src/structured-output/__tests__/exceptions.test.js +103 -0
- package/dist/src/structured-output/__tests__/exceptions.test.js.map +1 -0
- package/dist/src/structured-output/__tests__/tool.test.d.ts +2 -0
- package/dist/src/structured-output/__tests__/tool.test.d.ts.map +1 -0
- package/dist/src/structured-output/__tests__/tool.test.js +256 -0
- package/dist/src/structured-output/__tests__/tool.test.js.map +1 -0
- package/dist/src/structured-output/__tests__/utils.test.d.ts +2 -0
- package/dist/src/structured-output/__tests__/utils.test.d.ts.map +1 -0
- package/dist/src/structured-output/__tests__/utils.test.js +183 -0
- package/dist/src/structured-output/__tests__/utils.test.js.map +1 -0
- package/dist/src/structured-output/context.d.ts +91 -0
- package/dist/src/structured-output/context.d.ts.map +1 -0
- package/dist/src/structured-output/context.js +112 -0
- package/dist/src/structured-output/context.js.map +1 -0
- package/dist/src/structured-output/exceptions.d.ts +18 -0
- package/dist/src/structured-output/exceptions.d.ts.map +1 -0
- package/dist/src/structured-output/exceptions.js +28 -0
- package/dist/src/structured-output/exceptions.js.map +1 -0
- package/dist/src/structured-output/tool.d.ts +33 -0
- package/dist/src/structured-output/tool.d.ts.map +1 -0
- package/dist/src/structured-output/tool.js +73 -0
- package/dist/src/structured-output/tool.js.map +1 -0
- package/dist/src/structured-output/utils.d.ts +23 -0
- package/dist/src/structured-output/utils.d.ts.map +1 -0
- package/dist/src/structured-output/utils.js +104 -0
- package/dist/src/structured-output/utils.js.map +1 -0
- package/dist/src/telemetry/__tests__/config.test.node.d.ts +2 -0
- package/dist/src/telemetry/__tests__/config.test.node.d.ts.map +1 -0
- package/dist/src/telemetry/__tests__/config.test.node.js +129 -0
- package/dist/src/telemetry/__tests__/config.test.node.js.map +1 -0
- package/dist/src/telemetry/__tests__/json.test.d.ts +2 -0
- package/dist/src/telemetry/__tests__/json.test.d.ts.map +1 -0
- package/dist/src/telemetry/__tests__/json.test.js +89 -0
- package/dist/src/telemetry/__tests__/json.test.js.map +1 -0
- package/dist/src/telemetry/__tests__/tracer.test.node.d.ts +2 -0
- package/dist/src/telemetry/__tests__/tracer.test.node.d.ts.map +1 -0
- package/dist/src/telemetry/__tests__/tracer.test.node.js +611 -0
- package/dist/src/telemetry/__tests__/tracer.test.node.js.map +1 -0
- package/dist/src/telemetry/config.d.ts +61 -0
- package/dist/src/telemetry/config.d.ts.map +1 -0
- package/dist/src/telemetry/config.js +101 -0
- package/dist/src/telemetry/config.js.map +1 -0
- package/dist/src/telemetry/index.d.ts +34 -0
- package/dist/src/telemetry/index.d.ts.map +1 -0
- package/dist/src/telemetry/index.js +33 -0
- package/dist/src/telemetry/index.js.map +1 -0
- package/dist/src/telemetry/json.d.ts +11 -0
- package/dist/src/telemetry/json.d.ts.map +1 -0
- package/dist/src/telemetry/json.js +25 -0
- package/dist/src/telemetry/json.js.map +1 -0
- package/dist/src/telemetry/tracer.d.ts +219 -0
- package/dist/src/telemetry/tracer.d.ts.map +1 -0
- package/dist/src/telemetry/tracer.js +610 -0
- package/dist/src/telemetry/tracer.js.map +1 -0
- package/dist/src/telemetry/types.d.ts +101 -0
- package/dist/src/telemetry/types.d.ts.map +1 -0
- package/dist/src/telemetry/types.js +5 -0
- package/dist/src/telemetry/types.js.map +1 -0
- package/dist/src/tools/tool.d.ts +1 -1
- package/dist/src/tools/tool.js +1 -1
- package/dist/src/tools/zod-tool.d.ts.map +1 -1
- package/dist/src/tools/zod-tool.js +2 -5
- package/dist/src/tools/zod-tool.js.map +1 -1
- package/dist/src/tsconfig.tsbuildinfo +1 -1
- package/dist/src/types/__tests__/media.test.js +216 -1
- package/dist/src/types/__tests__/media.test.js.map +1 -1
- package/dist/src/types/__tests__/messages.test.js +193 -4
- package/dist/src/types/__tests__/messages.test.js.map +1 -1
- package/dist/src/types/agent.d.ts +16 -10
- package/dist/src/types/agent.d.ts.map +1 -1
- package/dist/src/types/agent.js +8 -1
- package/dist/src/types/agent.js.map +1 -1
- package/dist/src/types/json.d.ts +61 -0
- package/dist/src/types/json.d.ts.map +1 -1
- package/dist/src/types/json.js +24 -0
- package/dist/src/types/json.js.map +1 -1
- package/dist/src/types/media.d.ts +84 -4
- package/dist/src/types/media.d.ts.map +1 -1
- package/dist/src/types/media.js +194 -0
- package/dist/src/types/media.js.map +1 -1
- package/dist/src/types/messages.d.ts +152 -13
- package/dist/src/types/messages.d.ts.map +1 -1
- package/dist/src/types/messages.js +235 -8
- package/dist/src/types/messages.js.map +1 -1
- package/dist/src/types/serializable.d.ts +31 -0
- package/dist/src/types/serializable.d.ts.map +1 -0
- package/dist/src/types/serializable.js +19 -0
- package/dist/src/types/serializable.js.map +1 -0
- package/dist/src/utils/zod.d.ts +11 -0
- package/dist/src/utils/zod.d.ts.map +1 -0
- package/dist/src/utils/zod.js +14 -0
- package/dist/src/utils/zod.js.map +1 -0
- package/dist/src/vended-tools/bash/__tests__/bash.test.node.js +2 -2
- package/dist/src/vended-tools/bash/__tests__/bash.test.node.js.map +1 -1
- package/dist/src/vended-tools/file_editor/__tests__/file-editor.test.node.js +4 -4
- package/dist/src/vended-tools/file_editor/__tests__/file-editor.test.node.js.map +1 -1
- package/dist/src/vended-tools/notebook/__tests__/notebook.test.js +2 -2
- package/dist/src/vended-tools/notebook/__tests__/notebook.test.js.map +1 -1
- package/package.json +17 -3
- package/dist/src/agent/__tests__/state.test.d.ts +0 -2
- package/dist/src/agent/__tests__/state.test.d.ts.map +0 -1
- package/dist/src/agent/__tests__/state.test.js.map +0 -1
- package/dist/src/agent/state.d.ts.map +0 -1
- package/dist/src/agent/state.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slim-types.d.ts","sourceRoot":"","sources":["../../../src/__fixtures__/slim-types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EACV,OAAO,EACP,eAAe,EACf,SAAS,EACT,YAAY,EACZ,cAAc,EACd,eAAe,EACf,iBAAiB,EACjB,SAAS,EACV,MAAM,sBAAsB,CAAA;AAC7B,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAE9E;;;;;;;;;;GAUG;AACH,MAAM,MAAM,MAAM,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAA;AAEzC;;GAEG;AACH,MAAM,MAAM,iBAAiB,GACzB,MAAM,CAAC,SAAS,CAAC,GACjB,MAAM,CAAC,YAAY,CAAC,GACpB,MAAM,CAAC,eAAe,CAAC,GACvB,MAAM,CAAC,cAAc,CAAC,GACtB,MAAM,CAAC,eAAe,CAAC,GACvB,MAAM,CAAC,iBAAiB,CAAC,GACzB,MAAM,CAAC,SAAS,CAAC,GACjB,MAAM,CAAC,UAAU,CAAC,GAClB,MAAM,CAAC,UAAU,CAAC,GAClB,MAAM,CAAC,aAAa,CAAC,CAAA;AAEzB;;GAEG;AACH,MAAM,MAAM,uBAAuB,GAAG,MAAM,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,eAAe,CAAC,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAA;AAE7G;;GAEG;AACH,MAAM,MAAM,oBAAoB,GAAG,MAAM,CAAC,eAAe,CAAC,CAAA;AAE1D;;;GAGG;AACH,MAAM,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG;IAAE,OAAO,EAAE,iBAAiB,EAAE,CAAA;CAAE,CAAA;AAE7E;;;;;;;;;;GAUG;AACH,YAAY,EAAE,OAAO,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slim-types.js","sourceRoot":"","sources":["../../../src/__fixtures__/slim-types.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
|
@@ -3,28 +3,32 @@
|
|
|
3
3
|
* This module provides utilities for testing Tool implementations.
|
|
4
4
|
*/
|
|
5
5
|
import type { Tool, ToolContext } from '../tools/tool.js';
|
|
6
|
-
import { ToolResultBlock } from '../types/messages.js';
|
|
7
6
|
import type { JSONValue } from '../types/json.js';
|
|
7
|
+
import type { PlainToolResultBlock } from './slim-types.js';
|
|
8
8
|
/**
|
|
9
9
|
* Helper to create a mock ToolContext for testing.
|
|
10
10
|
*
|
|
11
11
|
* @param toolUse - The tool use request
|
|
12
|
-
* @param
|
|
12
|
+
* @param appState - Optional initial app state
|
|
13
13
|
* @returns Mock ToolContext object
|
|
14
14
|
*/
|
|
15
15
|
export declare function createMockContext(toolUse: {
|
|
16
16
|
name: string;
|
|
17
17
|
toolUseId: string;
|
|
18
18
|
input: JSONValue;
|
|
19
|
-
},
|
|
19
|
+
}, appState?: Record<string, JSONValue>): ToolContext;
|
|
20
|
+
/**
|
|
21
|
+
* Result function type for createMockTool - accepts plain objects or class instances.
|
|
22
|
+
*/
|
|
23
|
+
type ToolResultFn = () => PlainToolResultBlock | AsyncGenerator<never, PlainToolResultBlock, never>;
|
|
20
24
|
/**
|
|
21
25
|
* Helper to create a mock tool for testing.
|
|
22
26
|
*
|
|
23
27
|
* @param name - The name of the mock tool
|
|
24
|
-
* @param resultFn - Function that returns a ToolResultBlock
|
|
28
|
+
* @param resultFn - Function that returns a ToolResultBlock (plain object or class instance) or an AsyncGenerator
|
|
25
29
|
* @returns Mock Tool object
|
|
26
30
|
*/
|
|
27
|
-
export declare function createMockTool(name: string, resultFn:
|
|
31
|
+
export declare function createMockTool(name: string, resultFn: ToolResultFn): Tool;
|
|
28
32
|
/**
|
|
29
33
|
* Helper to create a simple mock tool with minimal configuration for testing.
|
|
30
34
|
* This is a lighter-weight version of createMockTool for scenarios where the tool's
|
|
@@ -34,4 +38,5 @@ export declare function createMockTool(name: string, resultFn: () => ToolResultB
|
|
|
34
38
|
* @returns Mock Tool object
|
|
35
39
|
*/
|
|
36
40
|
export declare function createRandomTool(name?: string): Tool;
|
|
41
|
+
export {};
|
|
37
42
|
//# sourceMappingURL=tool-helpers.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tool-helpers.d.ts","sourceRoot":"","sources":["../../../src/__fixtures__/tool-helpers.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;
|
|
1
|
+
{"version":3,"file":"tool-helpers.d.ts","sourceRoot":"","sources":["../../../src/__fixtures__/tool-helpers.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAEzD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAEjD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAA;AAE3D;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAC/B,OAAO,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,SAAS,CAAA;CAAE,EAC9D,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GACnC,WAAW,CAQb;AAED;;GAEG;AACH,KAAK,YAAY,GAAG,MAAM,oBAAoB,GAAG,cAAc,CAAC,KAAK,EAAE,oBAAoB,EAAE,KAAK,CAAC,CAAA;AAEnG;;;;;;GAMG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,GAAG,IAAI,CA8BzE;AAED;;;;;;;GAOG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAWpD"}
|
|
@@ -3,19 +3,19 @@
|
|
|
3
3
|
* This module provides utilities for testing Tool implementations.
|
|
4
4
|
*/
|
|
5
5
|
import { ToolResultBlock } from '../types/messages.js';
|
|
6
|
-
import {
|
|
6
|
+
import { AppState } from '../app-state.js';
|
|
7
7
|
/**
|
|
8
8
|
* Helper to create a mock ToolContext for testing.
|
|
9
9
|
*
|
|
10
10
|
* @param toolUse - The tool use request
|
|
11
|
-
* @param
|
|
11
|
+
* @param appState - Optional initial app state
|
|
12
12
|
* @returns Mock ToolContext object
|
|
13
13
|
*/
|
|
14
|
-
export function createMockContext(toolUse,
|
|
14
|
+
export function createMockContext(toolUse, appState) {
|
|
15
15
|
return {
|
|
16
16
|
toolUse,
|
|
17
17
|
agent: {
|
|
18
|
-
state: new
|
|
18
|
+
state: new AppState(appState),
|
|
19
19
|
messages: [],
|
|
20
20
|
},
|
|
21
21
|
};
|
|
@@ -24,7 +24,7 @@ export function createMockContext(toolUse, agentState) {
|
|
|
24
24
|
* Helper to create a mock tool for testing.
|
|
25
25
|
*
|
|
26
26
|
* @param name - The name of the mock tool
|
|
27
|
-
* @param resultFn - Function that returns a ToolResultBlock
|
|
27
|
+
* @param resultFn - Function that returns a ToolResultBlock (plain object or class instance) or an AsyncGenerator
|
|
28
28
|
* @returns Mock Tool object
|
|
29
29
|
*/
|
|
30
30
|
export function createMockTool(name, resultFn) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tool-helpers.js","sourceRoot":"","sources":["../../../src/__fixtures__/tool-helpers.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAEtD,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"tool-helpers.js","sourceRoot":"","sources":["../../../src/__fixtures__/tool-helpers.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAEtD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAG1C;;;;;;GAMG;AACH,MAAM,UAAU,iBAAiB,CAC/B,OAA8D,EAC9D,QAAoC;IAEpC,OAAO;QACL,OAAO;QACP,KAAK,EAAE;YACL,KAAK,EAAE,IAAI,QAAQ,CAAC,QAAQ,CAAC;YAC7B,QAAQ,EAAE,EAAE;SACb;KACF,CAAA;AACH,CAAC;AAOD;;;;;;GAMG;AACH,MAAM,UAAU,cAAc,CAAC,IAAY,EAAE,QAAsB;IACjE,OAAO;QACL,IAAI;QACJ,WAAW,EAAE,aAAa,IAAI,EAAE;QAChC,QAAQ,EAAE;YACR,IAAI;YACJ,WAAW,EAAE,aAAa,IAAI,EAAE;YAChC,WAAW,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,EAAE;SAChD;QACD,yCAAyC;QACzC,KAAK,CAAC,CAAC,MAAM,CAAC,QAAQ;YACpB,MAAM,MAAM,GAAG,QAAQ,EAAE,CAAA;YACzB,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,CAAC,aAAa,IAAI,MAAM,EAAE,CAAC;gBACpF,mCAAmC;gBACnC,MAAM,GAAG,GAAG,MAAuD,CAAA;gBACnE,IAAI,IAAI,GAAG,KAAK,CAAA;gBAChB,OAAO,CAAC,IAAI,EAAE,CAAC;oBACb,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,CAAC,IAAI,EAAE,CAAA;oBAChD,IAAI,GAAG,MAAM,IAAI,KAAK,CAAA;oBACtB,IAAI,IAAI,EAAE,CAAC;wBACT,OAAO,KAAK,CAAA;oBACd,CAAC;gBACH,CAAC;gBACD,6DAA6D;gBAC7D,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAA;YACjD,CAAC;iBAAM,CAAC;gBACN,OAAO,MAAyB,CAAA;YAClC,CAAC;QACH,CAAC;KACF,CAAA;AACH,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,gBAAgB,CAAC,IAAa;IAC5C,MAAM,QAAQ,GAAG,IAAI,IAAI,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE,CAAA;IACvD,OAAO,cAAc,CACnB,QAAQ,EACR,GAAG,EAAE,CACH,IAAI,eAAe,CAAC;QAClB,SAAS,EAAE,SAAS;QACpB,MAAM,EAAE,SAAkB;QAC1B,OAAO,EAAE,EAAE;KACZ,CAAC,CACL,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-state.test.d.ts","sourceRoot":"","sources":["../../../src/__tests__/app-state.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import {
|
|
3
|
-
describe('
|
|
2
|
+
import { AppState } from '../app-state.js';
|
|
3
|
+
describe('AppState', () => {
|
|
4
4
|
describe('constructor', () => {
|
|
5
5
|
it('creates empty state when no initial state provided', () => {
|
|
6
|
-
const state = new
|
|
6
|
+
const state = new AppState();
|
|
7
7
|
expect(state.keys()).toEqual([]);
|
|
8
8
|
});
|
|
9
9
|
it('creates state with initial values', () => {
|
|
10
|
-
const state = new
|
|
10
|
+
const state = new AppState({ key1: 'value1', key2: 42 });
|
|
11
11
|
expect(state.get('key1')).toBe('value1');
|
|
12
12
|
expect(state.get('key2')).toBe(42);
|
|
13
13
|
});
|
|
14
14
|
it('stores deep copy of initial state', () => {
|
|
15
15
|
const initial = { nested: { value: 'test' } };
|
|
16
|
-
const state = new
|
|
16
|
+
const state = new AppState(initial);
|
|
17
17
|
// Mutate original
|
|
18
18
|
initial.nested.value = 'changed';
|
|
19
19
|
// State should not be affected
|
|
@@ -21,42 +21,42 @@ describe('AgentState', () => {
|
|
|
21
21
|
});
|
|
22
22
|
it('throws error for function in initial state', () => {
|
|
23
23
|
const invalidState = { func: () => 'test', value: 'keep' };
|
|
24
|
-
expect(() => new
|
|
24
|
+
expect(() => new AppState(invalidState)).toThrow('initialState.func contains a function which cannot be serialized');
|
|
25
25
|
});
|
|
26
26
|
it('throws error for symbol in initial state', () => {
|
|
27
27
|
const sym = Symbol('test');
|
|
28
28
|
const invalidState = { sym, value: 'keep' };
|
|
29
|
-
expect(() => new
|
|
29
|
+
expect(() => new AppState(invalidState)).toThrow('initialState.sym contains a symbol which cannot be serialized');
|
|
30
30
|
});
|
|
31
31
|
it('throws error for undefined in initial state', () => {
|
|
32
32
|
const invalidState = { undef: undefined, value: 'keep' };
|
|
33
|
-
expect(() => new
|
|
33
|
+
expect(() => new AppState(invalidState)).toThrow('initialState.undef is undefined which cannot be serialized');
|
|
34
34
|
});
|
|
35
35
|
it('throws error for nested function in initial state', () => {
|
|
36
36
|
const invalidState = { nested: { func: () => 'test' } };
|
|
37
|
-
expect(() => new
|
|
37
|
+
expect(() => new AppState(invalidState)).toThrow('initialState.nested.func contains a function which cannot be serialized');
|
|
38
38
|
});
|
|
39
39
|
it('throws error for function in array in initial state', () => {
|
|
40
40
|
const invalidState = { arr: [1, () => 'test', 3] };
|
|
41
|
-
expect(() => new
|
|
41
|
+
expect(() => new AppState(invalidState)).toThrow('initialState.arr[1] contains a function which cannot be serialized');
|
|
42
42
|
});
|
|
43
43
|
});
|
|
44
44
|
describe('get', () => {
|
|
45
45
|
it('throws error when key is null or undefined', () => {
|
|
46
|
-
const state = new
|
|
46
|
+
const state = new AppState();
|
|
47
47
|
expect(() => state.get(null)).toThrow('key is required');
|
|
48
48
|
expect(() => state.get(undefined)).toThrow('key is required');
|
|
49
49
|
});
|
|
50
50
|
it('returns undefined when key does not exist', () => {
|
|
51
|
-
const state = new
|
|
51
|
+
const state = new AppState();
|
|
52
52
|
expect(state.get('nonexistent')).toBeUndefined();
|
|
53
53
|
});
|
|
54
54
|
it('returns value when key exists', () => {
|
|
55
|
-
const state = new
|
|
55
|
+
const state = new AppState({ key1: 'value1' });
|
|
56
56
|
expect(state.get('key1')).toBe('value1');
|
|
57
57
|
});
|
|
58
58
|
it('returns deep copy that cannot mutate stored state', () => {
|
|
59
|
-
const state = new
|
|
59
|
+
const state = new AppState({ nested: { value: 'test' } });
|
|
60
60
|
const retrieved = state.get('nested');
|
|
61
61
|
// Mutate retrieved value
|
|
62
62
|
retrieved.value = 'changed';
|
|
@@ -64,7 +64,7 @@ describe('AgentState', () => {
|
|
|
64
64
|
expect(state.get('nested')).toEqual({ value: 'test' });
|
|
65
65
|
});
|
|
66
66
|
it('infers correct type with generic state interface', () => {
|
|
67
|
-
const state = new
|
|
67
|
+
const state = new AppState({ user: { name: 'John', age: 30 }, count: 5, items: ['a', 'b'] });
|
|
68
68
|
// Type inference tests
|
|
69
69
|
const user = state.get('user');
|
|
70
70
|
const count = state.get('count');
|
|
@@ -74,11 +74,11 @@ describe('AgentState', () => {
|
|
|
74
74
|
expect(items).toEqual(['a', 'b']);
|
|
75
75
|
});
|
|
76
76
|
it('returns undefined for non-existent key with typed interface', () => {
|
|
77
|
-
const state = new
|
|
77
|
+
const state = new AppState({ existing: 'value' });
|
|
78
78
|
const result = state.get('existing');
|
|
79
79
|
expect(result).toBe('value');
|
|
80
80
|
// Non-existent key
|
|
81
|
-
const state2 = new
|
|
81
|
+
const state2 = new AppState();
|
|
82
82
|
const missing = state2.get('existing');
|
|
83
83
|
expect(missing).toBeUndefined();
|
|
84
84
|
// @ts-expect-error properties not on the TestsState are an error
|
|
@@ -87,42 +87,42 @@ describe('AgentState', () => {
|
|
|
87
87
|
});
|
|
88
88
|
describe('set', () => {
|
|
89
89
|
it('sets string value successfully', () => {
|
|
90
|
-
const state = new
|
|
90
|
+
const state = new AppState();
|
|
91
91
|
state.set('key1', 'value1');
|
|
92
92
|
expect(state.get('key1')).toBe('value1');
|
|
93
93
|
});
|
|
94
94
|
it('sets number value successfully', () => {
|
|
95
|
-
const state = new
|
|
95
|
+
const state = new AppState();
|
|
96
96
|
state.set('key1', 42);
|
|
97
97
|
expect(state.get('key1')).toBe(42);
|
|
98
98
|
});
|
|
99
99
|
it('sets boolean value successfully', () => {
|
|
100
|
-
const state = new
|
|
100
|
+
const state = new AppState();
|
|
101
101
|
state.set('key1', true);
|
|
102
102
|
expect(state.get('key1')).toBe(true);
|
|
103
103
|
});
|
|
104
104
|
it('sets null value successfully', () => {
|
|
105
|
-
const state = new
|
|
105
|
+
const state = new AppState();
|
|
106
106
|
state.set('key1', null);
|
|
107
107
|
expect(state.get('key1')).toBeNull();
|
|
108
108
|
});
|
|
109
109
|
it('sets object value successfully', () => {
|
|
110
|
-
const state = new
|
|
110
|
+
const state = new AppState();
|
|
111
111
|
state.set('key1', { nested: 'value' });
|
|
112
112
|
expect(state.get('key1')).toEqual({ nested: 'value' });
|
|
113
113
|
});
|
|
114
114
|
it('sets array value successfully', () => {
|
|
115
|
-
const state = new
|
|
115
|
+
const state = new AppState();
|
|
116
116
|
state.set('key1', [1, 2, 3]);
|
|
117
117
|
expect(state.get('key1')).toEqual([1, 2, 3]);
|
|
118
118
|
});
|
|
119
119
|
it('overwrites existing value', () => {
|
|
120
|
-
const state = new
|
|
120
|
+
const state = new AppState({ key1: 'old' });
|
|
121
121
|
state.set('key1', 'new');
|
|
122
122
|
expect(state.get('key1')).toBe('new');
|
|
123
123
|
});
|
|
124
124
|
it('stores deep copy that cannot mutate stored state', () => {
|
|
125
|
-
const state = new
|
|
125
|
+
const state = new AppState();
|
|
126
126
|
const value = { nested: { value: 'test' } };
|
|
127
127
|
state.set('key1', value);
|
|
128
128
|
// Mutate original
|
|
@@ -131,35 +131,35 @@ describe('AgentState', () => {
|
|
|
131
131
|
expect(state.get('key1')).toEqual({ nested: { value: 'test' } });
|
|
132
132
|
});
|
|
133
133
|
it('throws error for function in value', () => {
|
|
134
|
-
const state = new
|
|
134
|
+
const state = new AppState({ existing: 'value' });
|
|
135
135
|
const obj = { func: () => 'test', value: 'keep' };
|
|
136
136
|
expect(() => state.set('key1', obj)).toThrow('value for key "key1".func contains a function which cannot be serialized');
|
|
137
137
|
});
|
|
138
138
|
it('throws error for symbol in value', () => {
|
|
139
|
-
const state = new
|
|
139
|
+
const state = new AppState();
|
|
140
140
|
const sym = Symbol('test');
|
|
141
141
|
expect(() => state.set('key1', { sym })).toThrow('value for key "key1".sym contains a symbol which cannot be serialized');
|
|
142
142
|
});
|
|
143
143
|
it('throws error for nested function in value', () => {
|
|
144
|
-
const state = new
|
|
144
|
+
const state = new AppState();
|
|
145
145
|
const obj = { nested: { func: () => 'test' } };
|
|
146
146
|
expect(() => state.set('key1', obj)).toThrow('value for key "key1".nested.func contains a function which cannot be serialized');
|
|
147
147
|
});
|
|
148
148
|
it('throws error for function in array', () => {
|
|
149
|
-
const state = new
|
|
149
|
+
const state = new AppState();
|
|
150
150
|
const arr = [1, () => 'test', 3];
|
|
151
151
|
expect(() => state.set('key1', arr)).toThrow('value for key "key1"[1] contains a function which cannot be serialized');
|
|
152
152
|
});
|
|
153
153
|
it('throws error for top-level symbol values', () => {
|
|
154
|
-
const state = new
|
|
154
|
+
const state = new AppState();
|
|
155
155
|
expect(() => state.set('key1', Symbol('test'))).toThrow('value for key "key1" contains a symbol which cannot be serialized');
|
|
156
156
|
});
|
|
157
157
|
it('throws error for top-level undefined values', () => {
|
|
158
|
-
const state = new
|
|
158
|
+
const state = new AppState();
|
|
159
159
|
expect(() => state.set('key1', undefined)).toThrow('value for key "key1" is undefined which cannot be serialized');
|
|
160
160
|
});
|
|
161
161
|
it('accepts typed value with generic state interface', () => {
|
|
162
|
-
const state = new
|
|
162
|
+
const state = new AppState();
|
|
163
163
|
state.set('user', { name: 'Alice', age: 25 });
|
|
164
164
|
state.set('count', 10);
|
|
165
165
|
expect(state.get('user')).toEqual({ name: 'Alice', age: 25 });
|
|
@@ -170,17 +170,17 @@ describe('AgentState', () => {
|
|
|
170
170
|
});
|
|
171
171
|
describe('delete', () => {
|
|
172
172
|
it('removes existing key', () => {
|
|
173
|
-
const state = new
|
|
173
|
+
const state = new AppState({ key1: 'value1', key2: 'value2' });
|
|
174
174
|
state.delete('key1');
|
|
175
175
|
expect(state.get('key1')).toBeUndefined();
|
|
176
176
|
expect(state.get('key2')).toBe('value2');
|
|
177
177
|
});
|
|
178
178
|
it('does not throw error for non-existent key', () => {
|
|
179
|
-
const state = new
|
|
179
|
+
const state = new AppState();
|
|
180
180
|
expect(() => state.delete('nonexistent')).not.toThrow();
|
|
181
181
|
});
|
|
182
182
|
it('supports typed usage with generic state interface', () => {
|
|
183
|
-
const state = new
|
|
183
|
+
const state = new AppState({ user: { name: 'Alice' }, count: 5 });
|
|
184
184
|
// Typed delete
|
|
185
185
|
state.delete('user');
|
|
186
186
|
expect(state.get('user')).toBeUndefined();
|
|
@@ -189,43 +189,62 @@ describe('AgentState', () => {
|
|
|
189
189
|
});
|
|
190
190
|
describe('clear', () => {
|
|
191
191
|
it('removes all values', () => {
|
|
192
|
-
const state = new
|
|
192
|
+
const state = new AppState({ key1: 'value1', key2: 'value2' });
|
|
193
193
|
state.clear();
|
|
194
194
|
expect(state.keys()).toEqual([]);
|
|
195
195
|
expect(state.get('key1')).toBeUndefined();
|
|
196
196
|
expect(state.get('key2')).toBeUndefined();
|
|
197
197
|
});
|
|
198
198
|
it('works on empty state', () => {
|
|
199
|
-
const state = new
|
|
199
|
+
const state = new AppState();
|
|
200
200
|
expect(() => state.clear()).not.toThrow();
|
|
201
201
|
expect(state.keys()).toEqual([]);
|
|
202
202
|
});
|
|
203
203
|
});
|
|
204
204
|
describe('getAll', () => {
|
|
205
205
|
it('returns object with all state', () => {
|
|
206
|
-
const state = new
|
|
206
|
+
const state = new AppState({ key1: 'value1', key2: 42 });
|
|
207
207
|
expect(state.getAll()).toEqual({ key1: 'value1', key2: 42 });
|
|
208
208
|
});
|
|
209
209
|
it('returns empty object for empty state', () => {
|
|
210
|
-
const state = new
|
|
210
|
+
const state = new AppState();
|
|
211
211
|
expect(state.getAll()).toEqual({});
|
|
212
212
|
});
|
|
213
213
|
});
|
|
214
214
|
describe('keys', () => {
|
|
215
215
|
it('returns array of all keys', () => {
|
|
216
|
-
const state = new
|
|
216
|
+
const state = new AppState({ key1: 'value1', key2: 'value2' });
|
|
217
217
|
expect(state.keys().sort()).toEqual(['key1', 'key2']);
|
|
218
218
|
});
|
|
219
219
|
it('returns empty array for empty state', () => {
|
|
220
|
-
const state = new
|
|
220
|
+
const state = new AppState();
|
|
221
221
|
expect(state.keys()).toEqual([]);
|
|
222
222
|
});
|
|
223
223
|
it('returns new array each time', () => {
|
|
224
|
-
const state = new
|
|
224
|
+
const state = new AppState({ key1: 'value1' });
|
|
225
225
|
const keys1 = state.keys();
|
|
226
226
|
const keys2 = state.keys();
|
|
227
227
|
expect(keys1).not.toBe(keys2);
|
|
228
228
|
});
|
|
229
229
|
});
|
|
230
|
+
describe('toJSON', () => {
|
|
231
|
+
it('returns deep copy of state', () => {
|
|
232
|
+
const state = new AppState({ key1: 'value1', nested: { deep: true } });
|
|
233
|
+
const json = state.toJSON();
|
|
234
|
+
expect(json).toEqual({ key1: 'value1', nested: { deep: true } });
|
|
235
|
+
});
|
|
236
|
+
});
|
|
237
|
+
describe('loadStateFromJson', () => {
|
|
238
|
+
it('replaces state with json data', () => {
|
|
239
|
+
const state = new AppState({ old: 'data' });
|
|
240
|
+
state.loadStateFromJson({ new: 'data', count: 42 });
|
|
241
|
+
expect(state.getAll()).toEqual({ new: 'data', count: 42 });
|
|
242
|
+
});
|
|
243
|
+
it('clears state when given non-object', () => {
|
|
244
|
+
const state = new AppState({ key: 'value' });
|
|
245
|
+
state.loadStateFromJson(null);
|
|
246
|
+
expect(state.getAll()).toEqual({});
|
|
247
|
+
});
|
|
248
|
+
});
|
|
230
249
|
});
|
|
231
|
-
//# sourceMappingURL=state.test.js.map
|
|
250
|
+
//# sourceMappingURL=app-state.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-state.test.js","sourceRoot":"","sources":["../../../src/__tests__/app-state.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
1
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
2
2
|
import { Client } from '@modelcontextprotocol/sdk/client/index.js';
|
|
3
3
|
import { McpClient } from '../mcp.js';
|
|
4
4
|
import { McpTool } from '../tools/mcp-tool.js';
|
|
5
5
|
import { JsonBlock } from '../types/messages.js';
|
|
6
|
+
import { context, propagation, trace, TraceFlags } from '@opentelemetry/api';
|
|
6
7
|
/**
|
|
7
8
|
* Helper to create a mock async generator that yields a result message.
|
|
8
9
|
* This simulates the behavior of callToolStream returning a stream that ends with a result.
|
|
@@ -27,10 +28,8 @@ vi.mock('@modelcontextprotocol/sdk/client/index.js', () => ({
|
|
|
27
28
|
}),
|
|
28
29
|
}));
|
|
29
30
|
vi.mock('../tools/tool.js', () => ({
|
|
30
|
-
// Mock the abstract base class
|
|
31
31
|
Tool: class {
|
|
32
32
|
},
|
|
33
|
-
// Mock helper to return a valid ToolResultBlock structure without prepending "Error: "
|
|
34
33
|
createErrorResult: (err, toolUseId) => ({
|
|
35
34
|
type: 'toolResultBlock',
|
|
36
35
|
status: 'error',
|
|
@@ -38,20 +37,36 @@ vi.mock('../tools/tool.js', () => ({
|
|
|
38
37
|
content: [{ type: 'textBlock', text: err instanceof Error ? err.message : String(err) }],
|
|
39
38
|
}),
|
|
40
39
|
}));
|
|
41
|
-
vi.mock('../../__fixtures__/environment.js', () => ({ isNode: true }));
|
|
42
40
|
/**
|
|
43
41
|
* Executes a tool stream to completion and returns the final result.
|
|
44
|
-
* We use a Generic <T> and cast the return value to ensure TypeScript
|
|
45
|
-
* knows the result is defined (and matches the Tool's return type).
|
|
46
42
|
*/
|
|
47
43
|
async function runTool(gen) {
|
|
48
44
|
let result = await gen.next();
|
|
49
45
|
while (!result.done) {
|
|
50
46
|
result = await gen.next();
|
|
51
47
|
}
|
|
52
|
-
// Force cast because we know our McpTool always returns a value when done
|
|
53
48
|
return result.value;
|
|
54
49
|
}
|
|
50
|
+
/**
|
|
51
|
+
* Mock an active span with a valid trace ID via trace.getSpan,
|
|
52
|
+
* and stub propagation.inject to populate the carrier with a traceparent.
|
|
53
|
+
*/
|
|
54
|
+
function mockActiveSpan(traceId = '1234567890abcdef1234567890abcdef', traceFlags = TraceFlags.SAMPLED) {
|
|
55
|
+
const mockSpan = {
|
|
56
|
+
spanContext: () => ({
|
|
57
|
+
traceId,
|
|
58
|
+
spanId: '1234567890abcdef',
|
|
59
|
+
traceFlags,
|
|
60
|
+
}),
|
|
61
|
+
};
|
|
62
|
+
vi.spyOn(trace, 'getSpan').mockReturnValue(mockSpan);
|
|
63
|
+
vi.spyOn(propagation, 'inject').mockImplementation((_context, carrier) => {
|
|
64
|
+
if (carrier && typeof carrier === 'object') {
|
|
65
|
+
;
|
|
66
|
+
carrier.traceparent = `00-${traceId}-1234567890abcdef-01`;
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
}
|
|
55
70
|
const mockTransport = {
|
|
56
71
|
connect: vi.fn(),
|
|
57
72
|
close: vi.fn(),
|
|
@@ -61,6 +76,9 @@ describe('MCP Integration', () => {
|
|
|
61
76
|
beforeEach(() => {
|
|
62
77
|
vi.clearAllMocks();
|
|
63
78
|
});
|
|
79
|
+
afterEach(() => {
|
|
80
|
+
vi.restoreAllMocks();
|
|
81
|
+
});
|
|
64
82
|
describe('McpClient', () => {
|
|
65
83
|
let client;
|
|
66
84
|
let sdkClientMock;
|
|
@@ -74,6 +92,70 @@ describe('MCP Integration', () => {
|
|
|
74
92
|
it('initializes SDK client with correct configuration', () => {
|
|
75
93
|
expect(Client).toHaveBeenCalledWith({ name: 'TestApp', version: '0.0.1' });
|
|
76
94
|
});
|
|
95
|
+
it('injects trace context into tool arguments when active span exists', async () => {
|
|
96
|
+
mockActiveSpan();
|
|
97
|
+
const tool = new McpTool({ name: 'calc', description: '', inputSchema: {}, client });
|
|
98
|
+
sdkClientMock.experimental.tasks.callToolStream.mockReturnValue(createMockCallToolStream({ content: [] })());
|
|
99
|
+
await client.callTool(tool, { op: 'add' });
|
|
100
|
+
const callArgs = sdkClientMock.experimental.tasks.callToolStream.mock.calls[0][0];
|
|
101
|
+
expect(callArgs.arguments).toStrictEqual({
|
|
102
|
+
op: 'add',
|
|
103
|
+
_meta: { traceparent: '00-1234567890abcdef1234567890abcdef-1234567890abcdef-01' },
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
it('merges trace context with existing _meta field', async () => {
|
|
107
|
+
mockActiveSpan();
|
|
108
|
+
const tool = new McpTool({ name: 'calc', description: '', inputSchema: {}, client });
|
|
109
|
+
sdkClientMock.experimental.tasks.callToolStream.mockReturnValue(createMockCallToolStream({ content: [] })());
|
|
110
|
+
await client.callTool(tool, { op: 'add', _meta: { progressToken: 'tok-1' } });
|
|
111
|
+
const callArgs = sdkClientMock.experimental.tasks.callToolStream.mock.calls[0][0];
|
|
112
|
+
expect(callArgs.arguments).toStrictEqual({
|
|
113
|
+
op: 'add',
|
|
114
|
+
_meta: {
|
|
115
|
+
progressToken: 'tok-1',
|
|
116
|
+
traceparent: '00-1234567890abcdef1234567890abcdef-1234567890abcdef-01',
|
|
117
|
+
},
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
it('passes args unchanged when no active span exists', async () => {
|
|
121
|
+
const tool = new McpTool({ name: 'calc', description: '', inputSchema: {}, client });
|
|
122
|
+
sdkClientMock.experimental.tasks.callToolStream.mockReturnValue(createMockCallToolStream({ content: [] })());
|
|
123
|
+
await client.callTool(tool, { op: 'add' });
|
|
124
|
+
const callArgs = sdkClientMock.experimental.tasks.callToolStream.mock.calls[0][0];
|
|
125
|
+
expect(callArgs.arguments).toStrictEqual({ op: 'add' });
|
|
126
|
+
});
|
|
127
|
+
it('passes args unchanged when span has empty trace ID', async () => {
|
|
128
|
+
mockActiveSpan('', TraceFlags.NONE);
|
|
129
|
+
const tool = new McpTool({ name: 'calc', description: '', inputSchema: {}, client });
|
|
130
|
+
sdkClientMock.experimental.tasks.callToolStream.mockReturnValue(createMockCallToolStream({ content: [] })());
|
|
131
|
+
await client.callTool(tool, { op: 'add' });
|
|
132
|
+
const callArgs = sdkClientMock.experimental.tasks.callToolStream.mock.calls[0][0];
|
|
133
|
+
expect(callArgs.arguments).toStrictEqual({ op: 'add' });
|
|
134
|
+
});
|
|
135
|
+
it('passes args unchanged when context injection fails', async () => {
|
|
136
|
+
vi.spyOn(context, 'active').mockImplementation(() => {
|
|
137
|
+
throw new Error('Context error');
|
|
138
|
+
});
|
|
139
|
+
const tool = new McpTool({ name: 'calc', description: '', inputSchema: {}, client });
|
|
140
|
+
sdkClientMock.experimental.tasks.callToolStream.mockReturnValue(createMockCallToolStream({ content: [] })());
|
|
141
|
+
await client.callTool(tool, { op: 'add' });
|
|
142
|
+
const callArgs = sdkClientMock.experimental.tasks.callToolStream.mock.calls[0][0];
|
|
143
|
+
expect(callArgs.arguments).toStrictEqual({ op: 'add' });
|
|
144
|
+
});
|
|
145
|
+
it('skips trace context injection when disableMcpInstrumentation is true', async () => {
|
|
146
|
+
mockActiveSpan();
|
|
147
|
+
const noInstrClient = new McpClient({
|
|
148
|
+
applicationName: 'TestApp',
|
|
149
|
+
transport: mockTransport,
|
|
150
|
+
disableMcpInstrumentation: true,
|
|
151
|
+
});
|
|
152
|
+
const noInstrSdkMock = vi.mocked(Client).mock.results.at(-1).value;
|
|
153
|
+
noInstrSdkMock.experimental.tasks.callToolStream.mockReturnValue(createMockCallToolStream({ content: [] })());
|
|
154
|
+
const tool = new McpTool({ name: 'calc', description: '', inputSchema: {}, client: noInstrClient });
|
|
155
|
+
await noInstrClient.callTool(tool, { op: 'add' });
|
|
156
|
+
const callArgs = noInstrSdkMock.experimental.tasks.callToolStream.mock.calls[0][0];
|
|
157
|
+
expect(callArgs.arguments).toStrictEqual({ op: 'add' });
|
|
158
|
+
});
|
|
77
159
|
it('manages connection state lazily', async () => {
|
|
78
160
|
await client.connect();
|
|
79
161
|
expect(sdkClientMock.connect).toHaveBeenCalledTimes(1);
|
|
@@ -124,7 +206,7 @@ describe('MCP Integration', () => {
|
|
|
124
206
|
inputSchema: {},
|
|
125
207
|
client: mockClientWrapper,
|
|
126
208
|
});
|
|
127
|
-
const
|
|
209
|
+
const toolContext = {
|
|
128
210
|
toolUse: { toolUseId: 'id-123', name: 'weather', input: { city: 'NYC' } },
|
|
129
211
|
agent: {},
|
|
130
212
|
};
|
|
@@ -132,8 +214,7 @@ describe('MCP Integration', () => {
|
|
|
132
214
|
vi.mocked(mockClientWrapper.callTool).mockResolvedValue({
|
|
133
215
|
content: [{ type: 'text', text: 'Sunny' }],
|
|
134
216
|
});
|
|
135
|
-
|
|
136
|
-
const result = await runTool(tool.stream(context));
|
|
217
|
+
const result = await runTool(tool.stream(toolContext));
|
|
137
218
|
expect(result).toBeDefined();
|
|
138
219
|
expect(result.status).toBe('success');
|
|
139
220
|
expect(result.content[0].text).toBe('Sunny');
|
|
@@ -143,14 +224,14 @@ describe('MCP Integration', () => {
|
|
|
143
224
|
vi.mocked(mockClientWrapper.callTool).mockResolvedValue({
|
|
144
225
|
content: [{ type: 'data', value: data }],
|
|
145
226
|
});
|
|
146
|
-
const result = await runTool(tool.stream(
|
|
227
|
+
const result = await runTool(tool.stream(toolContext));
|
|
147
228
|
const content = result.content[0];
|
|
148
229
|
expect(content).toBeInstanceOf(JsonBlock);
|
|
149
230
|
expect(content.json).toEqual(expect.objectContaining({ value: data }));
|
|
150
231
|
});
|
|
151
232
|
it('provides default message for empty output', async () => {
|
|
152
233
|
vi.mocked(mockClientWrapper.callTool).mockResolvedValue({ content: [] });
|
|
153
|
-
const result = await runTool(tool.stream(
|
|
234
|
+
const result = await runTool(tool.stream(toolContext));
|
|
154
235
|
expect(result.content[0].text).toContain('completed successfully');
|
|
155
236
|
});
|
|
156
237
|
it('handles protocol-level errors', async () => {
|
|
@@ -158,19 +239,19 @@ describe('MCP Integration', () => {
|
|
|
158
239
|
isError: true,
|
|
159
240
|
content: [{ type: 'text', text: 'Service Unavailable' }],
|
|
160
241
|
});
|
|
161
|
-
const result = await runTool(tool.stream(
|
|
242
|
+
const result = await runTool(tool.stream(toolContext));
|
|
162
243
|
expect(result.status).toBe('error');
|
|
163
244
|
expect(result.content[0].text).toBe('Service Unavailable');
|
|
164
245
|
});
|
|
165
246
|
it('catches and wraps client exceptions', async () => {
|
|
166
247
|
vi.mocked(mockClientWrapper.callTool).mockRejectedValue(new Error('Network Error'));
|
|
167
|
-
const result = await runTool(tool.stream(
|
|
248
|
+
const result = await runTool(tool.stream(toolContext));
|
|
168
249
|
expect(result.status).toBe('error');
|
|
169
250
|
expect(result.content[0].text).toBe('Network Error');
|
|
170
251
|
});
|
|
171
252
|
it('validates SDK response format', async () => {
|
|
172
253
|
vi.mocked(mockClientWrapper.callTool).mockResolvedValue({ content: null });
|
|
173
|
-
const result = await runTool(tool.stream(
|
|
254
|
+
const result = await runTool(tool.stream(toolContext));
|
|
174
255
|
expect(result.status).toBe('error');
|
|
175
256
|
expect(result.content[0].text).toContain('missing content array');
|
|
176
257
|
});
|