@namzu/sdk 0.4.1 → 0.4.3
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/CHANGELOG.md +83 -0
- package/dist/__tests__/replay-public-surface.test.d.ts +2 -0
- package/dist/__tests__/replay-public-surface.test.d.ts.map +1 -0
- package/dist/__tests__/replay-public-surface.test.js +45 -0
- package/dist/__tests__/replay-public-surface.test.js.map +1 -0
- package/dist/advisory/context.test.d.ts +16 -0
- package/dist/advisory/context.test.d.ts.map +1 -0
- package/dist/advisory/context.test.js +92 -0
- package/dist/advisory/context.test.js.map +1 -0
- package/dist/advisory/evaluator.test.d.ts +34 -0
- package/dist/advisory/evaluator.test.d.ts.map +1 -0
- package/dist/advisory/evaluator.test.js +172 -0
- package/dist/advisory/evaluator.test.js.map +1 -0
- package/dist/advisory/executor.test.d.ts +35 -0
- package/dist/advisory/executor.test.d.ts.map +1 -0
- package/dist/advisory/executor.test.js +233 -0
- package/dist/advisory/executor.test.js.map +1 -0
- package/dist/advisory/registry.test.d.ts +16 -0
- package/dist/advisory/registry.test.d.ts.map +1 -0
- package/dist/advisory/registry.test.js +62 -0
- package/dist/advisory/registry.test.js.map +1 -0
- package/dist/agents/SupervisorAgent.d.ts.map +1 -1
- package/dist/agents/SupervisorAgent.js.map +1 -1
- package/dist/bridge/a2a/agent-card.test.d.ts +24 -0
- package/dist/bridge/a2a/agent-card.test.d.ts.map +1 -0
- package/dist/bridge/a2a/agent-card.test.js +118 -0
- package/dist/bridge/a2a/agent-card.test.js.map +1 -0
- package/dist/bridge/a2a/mapper.test.d.ts +29 -0
- package/dist/bridge/a2a/mapper.test.d.ts.map +1 -0
- package/dist/bridge/a2a/mapper.test.js +265 -0
- package/dist/bridge/a2a/mapper.test.js.map +1 -0
- package/dist/bridge/a2a/message.test.d.ts +20 -0
- package/dist/bridge/a2a/message.test.d.ts.map +1 -0
- package/dist/bridge/a2a/message.test.js +116 -0
- package/dist/bridge/a2a/message.test.js.map +1 -0
- package/dist/bridge/a2a/task.d.ts +2 -2
- package/dist/bridge/a2a/task.d.ts.map +1 -1
- package/dist/bridge/a2a/task.js.map +1 -1
- package/dist/bridge/a2a/task.test.d.ts +29 -0
- package/dist/bridge/a2a/task.test.d.ts.map +1 -0
- package/dist/bridge/a2a/task.test.js +198 -0
- package/dist/bridge/a2a/task.test.js.map +1 -0
- package/dist/bridge/mcp/connector/adapter.test.d.ts +27 -0
- package/dist/bridge/mcp/connector/adapter.test.d.ts.map +1 -0
- package/dist/bridge/mcp/connector/adapter.test.js +203 -0
- package/dist/bridge/mcp/connector/adapter.test.js.map +1 -0
- package/dist/bridge/sse/mapper.test.d.ts +27 -0
- package/dist/bridge/sse/mapper.test.d.ts.map +1 -0
- package/dist/bridge/sse/mapper.test.js +271 -0
- package/dist/bridge/sse/mapper.test.js.map +1 -0
- package/dist/bridge/tools/connector/adapter.test.d.ts +28 -0
- package/dist/bridge/tools/connector/adapter.test.d.ts.map +1 -0
- package/dist/bridge/tools/connector/adapter.test.js +182 -0
- package/dist/bridge/tools/connector/adapter.test.js.map +1 -0
- package/dist/bridge/tools/connector/definitions.test.d.ts +23 -0
- package/dist/bridge/tools/connector/definitions.test.d.ts.map +1 -0
- package/dist/bridge/tools/connector/definitions.test.js +158 -0
- package/dist/bridge/tools/connector/definitions.test.js.map +1 -0
- package/dist/bridge/tools/connector/router.test.d.ts +21 -0
- package/dist/bridge/tools/connector/router.test.d.ts.map +1 -0
- package/dist/bridge/tools/connector/router.test.js +139 -0
- package/dist/bridge/tools/connector/router.test.js.map +1 -0
- package/dist/bus/breaker.test.d.ts +41 -0
- package/dist/bus/breaker.test.d.ts.map +1 -0
- package/dist/bus/breaker.test.js +242 -0
- package/dist/bus/breaker.test.js.map +1 -0
- package/dist/bus/index.test.d.ts +25 -0
- package/dist/bus/index.test.d.ts.map +1 -0
- package/dist/bus/index.test.js +151 -0
- package/dist/bus/index.test.js.map +1 -0
- package/dist/bus/lock.test.d.ts +44 -0
- package/dist/bus/lock.test.d.ts.map +1 -0
- package/dist/bus/lock.test.js +226 -0
- package/dist/bus/lock.test.js.map +1 -0
- package/dist/bus/ownership.test.d.ts +26 -0
- package/dist/bus/ownership.test.d.ts.map +1 -0
- package/dist/bus/ownership.test.js +205 -0
- package/dist/bus/ownership.test.js.map +1 -0
- package/dist/config/runtime.d.ts +24 -25
- package/dist/config/runtime.d.ts.map +1 -1
- package/dist/config/runtime.js.map +1 -1
- package/dist/connector/BaseConnector.test.d.ts +21 -0
- package/dist/connector/BaseConnector.test.d.ts.map +1 -0
- package/dist/connector/BaseConnector.test.js +108 -0
- package/dist/connector/BaseConnector.test.js.map +1 -0
- package/dist/connector/builtins/http.test.d.ts +30 -0
- package/dist/connector/builtins/http.test.d.ts.map +1 -0
- package/dist/connector/builtins/http.test.js +232 -0
- package/dist/connector/builtins/http.test.js.map +1 -0
- package/dist/connector/builtins/webhook.test.d.ts +20 -0
- package/dist/connector/builtins/webhook.test.d.ts.map +1 -0
- package/dist/connector/builtins/webhook.test.js +113 -0
- package/dist/connector/builtins/webhook.test.js.map +1 -0
- package/dist/connector/execution/factory.test.d.ts +16 -0
- package/dist/connector/execution/factory.test.d.ts.map +1 -0
- package/dist/connector/execution/factory.test.js +64 -0
- package/dist/connector/execution/factory.test.js.map +1 -0
- package/dist/connector/execution/remote.test.d.ts +16 -0
- package/dist/connector/execution/remote.test.d.ts.map +1 -0
- package/dist/connector/execution/remote.test.js +53 -0
- package/dist/connector/execution/remote.test.js.map +1 -0
- package/dist/connector/mcp/adapter.test.d.ts +34 -0
- package/dist/connector/mcp/adapter.test.d.ts.map +1 -0
- package/dist/connector/mcp/adapter.test.js +199 -0
- package/dist/connector/mcp/adapter.test.js.map +1 -0
- package/dist/contracts/api.d.ts +2 -2
- package/dist/contracts/api.d.ts.map +1 -1
- package/dist/contracts/index.d.ts +1 -2
- package/dist/contracts/index.d.ts.map +1 -1
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/schemas.d.ts +10 -10
- package/dist/index.d.ts +3 -103
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9 -89
- package/dist/index.js.map +1 -1
- package/dist/manager/agent/__tests__/lifecycle.test.js.map +1 -1
- package/dist/manager/agent/lifecycle.d.ts +1 -1
- package/dist/manager/agent/lifecycle.d.ts.map +1 -1
- package/dist/manager/agent/lifecycle.js +1 -1
- package/dist/manager/agent/lifecycle.js.map +1 -1
- package/dist/manager/run/persistence.d.ts +3 -3
- package/dist/manager/run/persistence.d.ts.map +1 -1
- package/dist/manager/run/persistence.js.map +1 -1
- package/dist/manager/thread/__tests__/lifecycle.test.js.map +1 -1
- package/dist/manager/thread/lifecycle.d.ts +1 -1
- package/dist/manager/thread/lifecycle.d.ts.map +1 -1
- package/dist/plugin/loader.d.ts +0 -5
- package/dist/plugin/loader.d.ts.map +1 -1
- package/dist/plugin/loader.js +1 -13
- package/dist/plugin/loader.js.map +1 -1
- package/dist/public-runtime.d.ts +70 -0
- package/dist/public-runtime.d.ts.map +1 -0
- package/dist/public-runtime.js +108 -0
- package/dist/public-runtime.js.map +1 -0
- package/dist/public-tools.d.ts +19 -0
- package/dist/public-tools.d.ts.map +1 -0
- package/dist/public-tools.js +34 -0
- package/dist/public-tools.js.map +1 -0
- package/dist/public-types.d.ts +55 -0
- package/dist/public-types.d.ts.map +1 -0
- package/dist/public-types.js +14 -0
- package/dist/public-types.js.map +1 -0
- package/dist/rag/chunking.test.d.ts +20 -0
- package/dist/rag/chunking.test.d.ts.map +1 -0
- package/dist/rag/chunking.test.js +92 -0
- package/dist/rag/chunking.test.js.map +1 -0
- package/dist/rag/context-assembler.test.d.ts +19 -0
- package/dist/rag/context-assembler.test.d.ts.map +1 -0
- package/dist/rag/context-assembler.test.js +98 -0
- package/dist/rag/context-assembler.test.js.map +1 -0
- package/dist/rag/embedding.test.d.ts +19 -0
- package/dist/rag/embedding.test.d.ts.map +1 -0
- package/dist/rag/embedding.test.js +115 -0
- package/dist/rag/embedding.test.js.map +1 -0
- package/dist/rag/ingestion.test.d.ts +22 -0
- package/dist/rag/ingestion.test.d.ts.map +1 -0
- package/dist/rag/ingestion.test.js +99 -0
- package/dist/rag/ingestion.test.js.map +1 -0
- package/dist/rag/knowledge-base.test.d.ts +17 -0
- package/dist/rag/knowledge-base.test.d.ts.map +1 -0
- package/dist/rag/knowledge-base.test.js +77 -0
- package/dist/rag/knowledge-base.test.js.map +1 -0
- package/dist/rag/rag-tool.d.ts +1 -1
- package/dist/rag/rag-tool.test.d.ts +21 -0
- package/dist/rag/rag-tool.test.d.ts.map +1 -0
- package/dist/rag/rag-tool.test.js +149 -0
- package/dist/rag/rag-tool.test.js.map +1 -0
- package/dist/rag/retriever.test.d.ts +26 -0
- package/dist/rag/retriever.test.d.ts.map +1 -0
- package/dist/rag/retriever.test.js +180 -0
- package/dist/rag/retriever.test.js.map +1 -0
- package/dist/rag/vector-store.test.d.ts +38 -0
- package/dist/rag/vector-store.test.d.ts.map +1 -0
- package/dist/rag/vector-store.test.js +175 -0
- package/dist/rag/vector-store.test.js.map +1 -0
- package/dist/registry/ManagedRegistry.test.d.ts +21 -0
- package/dist/registry/ManagedRegistry.test.d.ts.map +1 -0
- package/dist/registry/ManagedRegistry.test.js +98 -0
- package/dist/registry/ManagedRegistry.test.js.map +1 -0
- package/dist/registry/Registry.test.d.ts +18 -0
- package/dist/registry/Registry.test.d.ts.map +1 -0
- package/dist/registry/Registry.test.js +79 -0
- package/dist/registry/Registry.test.js.map +1 -0
- package/dist/registry/agent/definitions.test.d.ts +15 -0
- package/dist/registry/agent/definitions.test.d.ts.map +1 -0
- package/dist/registry/agent/definitions.test.js +84 -0
- package/dist/registry/agent/definitions.test.js.map +1 -0
- package/dist/registry/connector/definitions.test.d.ts +13 -0
- package/dist/registry/connector/definitions.test.d.ts.map +1 -0
- package/dist/registry/connector/definitions.test.js +41 -0
- package/dist/registry/connector/definitions.test.js.map +1 -0
- package/dist/registry/connector/scoped.test.d.ts +21 -0
- package/dist/registry/connector/scoped.test.d.ts.map +1 -0
- package/dist/registry/connector/scoped.test.js +115 -0
- package/dist/registry/connector/scoped.test.js.map +1 -0
- package/dist/registry/plugin/index.test.d.ts +12 -0
- package/dist/registry/plugin/index.test.d.ts.map +1 -0
- package/dist/registry/plugin/index.test.js +69 -0
- package/dist/registry/plugin/index.test.js.map +1 -0
- package/dist/registry/tool/execute.test.d.ts +42 -0
- package/dist/registry/tool/execute.test.d.ts.map +1 -0
- package/dist/registry/tool/execute.test.js +281 -0
- package/dist/registry/tool/execute.test.js.map +1 -0
- package/dist/run/LimitChecker.d.ts +0 -1
- package/dist/run/LimitChecker.d.ts.map +1 -1
- package/dist/run/LimitChecker.js +0 -6
- package/dist/run/LimitChecker.js.map +1 -1
- package/dist/run/reporter.d.ts +2 -2
- package/dist/run/reporter.d.ts.map +1 -1
- package/dist/run/reporter.js.map +1 -1
- package/dist/runtime/query/__tests__/checkpoint.test.d.ts +2 -0
- package/dist/runtime/query/__tests__/checkpoint.test.d.ts.map +1 -0
- package/dist/runtime/query/__tests__/checkpoint.test.js +150 -0
- package/dist/runtime/query/__tests__/checkpoint.test.js.map +1 -0
- package/dist/runtime/query/checkpoint.d.ts +23 -0
- package/dist/runtime/query/checkpoint.d.ts.map +1 -1
- package/dist/runtime/query/checkpoint.js +49 -0
- package/dist/runtime/query/checkpoint.js.map +1 -1
- package/dist/runtime/query/context.d.ts +0 -2
- package/dist/runtime/query/context.d.ts.map +1 -1
- package/dist/runtime/query/context.js +0 -4
- package/dist/runtime/query/context.js.map +1 -1
- package/dist/runtime/query/index.d.ts +3 -3
- package/dist/runtime/query/index.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/advisory.test.d.ts +42 -0
- package/dist/runtime/query/iteration/phases/advisory.test.d.ts.map +1 -0
- package/dist/runtime/query/iteration/phases/advisory.test.js +334 -0
- package/dist/runtime/query/iteration/phases/advisory.test.js.map +1 -0
- package/dist/runtime/query/replay/__tests__/mutate.test.d.ts +2 -0
- package/dist/runtime/query/replay/__tests__/mutate.test.d.ts.map +1 -0
- package/dist/runtime/query/replay/__tests__/mutate.test.js +123 -0
- package/dist/runtime/query/replay/__tests__/mutate.test.js.map +1 -0
- package/dist/runtime/query/replay/__tests__/prepare.test.d.ts +2 -0
- package/dist/runtime/query/replay/__tests__/prepare.test.d.ts.map +1 -0
- package/dist/runtime/query/replay/__tests__/prepare.test.js +171 -0
- package/dist/runtime/query/replay/__tests__/prepare.test.js.map +1 -0
- package/dist/runtime/query/replay/list.d.ts +24 -0
- package/dist/runtime/query/replay/list.d.ts.map +1 -0
- package/dist/runtime/query/replay/list.js +21 -0
- package/dist/runtime/query/replay/list.js.map +1 -0
- package/dist/runtime/query/replay/mutate.d.ts +17 -0
- package/dist/runtime/query/replay/mutate.d.ts.map +1 -0
- package/dist/runtime/query/replay/mutate.js +62 -0
- package/dist/runtime/query/replay/mutate.js.map +1 -0
- package/dist/runtime/query/replay/prepare.d.ts +56 -0
- package/dist/runtime/query/replay/prepare.d.ts.map +1 -0
- package/dist/runtime/query/replay/prepare.js +65 -0
- package/dist/runtime/query/replay/prepare.js.map +1 -0
- package/dist/runtime/query/result.d.ts +2 -2
- package/dist/runtime/query/result.d.ts.map +1 -1
- package/dist/session/__tests__/integration/_fixtures.d.ts +4 -4
- package/dist/session/__tests__/integration/_fixtures.d.ts.map +1 -1
- package/dist/session/__tests__/integration/_fixtures.js.map +1 -1
- package/dist/session/__tests__/integration/archive-gate.test.js.map +1 -1
- package/dist/session/__tests__/integration/capacity-caps.test.js.map +1 -1
- package/dist/session/__tests__/integration/e2e-spawn.test.js.map +1 -1
- package/dist/session/__tests__/integration/handoff-broadcast-e2e.test.js.map +1 -1
- package/dist/session/__tests__/integration/handoff-single-e2e.test.js.map +1 -1
- package/dist/session/__tests__/integration/prev-artifact-dag.test.js.map +1 -1
- package/dist/session/__tests__/integration/retention-archive.test.js.map +1 -1
- package/dist/session/__tests__/integration/spawn-rollback.test.js.map +1 -1
- package/dist/session/__tests__/integration/summary-materialization-e2e.test.js +1 -1
- package/dist/session/__tests__/integration/summary-materialization-e2e.test.js.map +1 -1
- package/dist/session/errors.d.ts +1 -1
- package/dist/session/errors.d.ts.map +1 -1
- package/dist/session/events/index.d.ts +3 -3
- package/dist/session/events/index.d.ts.map +1 -1
- package/dist/session/events/index.js +3 -2
- package/dist/session/events/index.js.map +1 -1
- package/dist/session/handoff/__tests__/broadcast.test.js.map +1 -1
- package/dist/session/handoff/__tests__/capacity.test.js.map +1 -1
- package/dist/session/handoff/__tests__/single.test.js.map +1 -1
- package/dist/session/handoff/assignment.d.ts +1 -1
- package/dist/session/handoff/assignment.d.ts.map +1 -1
- package/dist/session/handoff/broadcast.d.ts.map +1 -1
- package/dist/session/handoff/broadcast.js.map +1 -1
- package/dist/session/handoff/single.d.ts.map +1 -1
- package/dist/session/handoff/single.js.map +1 -1
- package/dist/session/index.d.ts +0 -1
- package/dist/session/index.d.ts.map +1 -1
- package/dist/session/index.js +7 -6
- package/dist/session/index.js.map +1 -1
- package/dist/session/intervention/__tests__/prev-artifact.test.js.map +1 -1
- package/dist/session/intervention/prev-artifact.d.ts +1 -1
- package/dist/session/intervention/prev-artifact.d.ts.map +1 -1
- package/dist/session/retention/__tests__/archive.test.js.map +1 -1
- package/dist/session/retention/__tests__/disk-backend.test.js.map +1 -1
- package/dist/session/retention/archive.d.ts +1 -1
- package/dist/session/retention/archive.d.ts.map +1 -1
- package/dist/session/retention/backend.d.ts +4 -4
- package/dist/session/retention/backend.d.ts.map +1 -1
- package/dist/session/retention/disk-backend.d.ts +1 -1
- package/dist/session/retention/disk-backend.d.ts.map +1 -1
- package/dist/session/retention/index.d.ts +3 -3
- package/dist/session/retention/index.d.ts.map +1 -1
- package/dist/session/retention/index.js +4 -2
- package/dist/session/retention/index.js.map +1 -1
- package/dist/session/status/__tests__/derive.test.d.ts +2 -0
- package/dist/session/status/__tests__/derive.test.d.ts.map +1 -0
- package/dist/session/{hierarchy/__tests__/session.test.js → status/__tests__/derive.test.js} +2 -2
- package/dist/session/status/__tests__/derive.test.js.map +1 -0
- package/dist/session/status/derive.d.ts +33 -0
- package/dist/session/status/derive.d.ts.map +1 -0
- package/dist/session/{hierarchy/session.js → status/derive.js} +6 -1
- package/dist/session/status/derive.js.map +1 -0
- package/dist/session/summary/__tests__/materialize.test.js +2 -1
- package/dist/session/summary/__tests__/materialize.test.js.map +1 -1
- package/dist/session/summary/errors.d.ts +43 -0
- package/dist/session/summary/errors.d.ts.map +1 -0
- package/dist/session/summary/errors.js +37 -0
- package/dist/session/summary/errors.js.map +1 -0
- package/dist/session/summary/index.d.ts +4 -3
- package/dist/session/summary/index.d.ts.map +1 -1
- package/dist/session/summary/index.js +5 -4
- package/dist/session/summary/index.js.map +1 -1
- package/dist/session/summary/materialize.d.ts +2 -2
- package/dist/session/summary/materialize.d.ts.map +1 -1
- package/dist/session/summary/materialize.js +2 -1
- package/dist/session/summary/materialize.js.map +1 -1
- package/dist/session/workspace/__tests__/git-worktree.test.js.map +1 -1
- package/dist/session/workspace/driver.d.ts +2 -2
- package/dist/session/workspace/driver.d.ts.map +1 -1
- package/dist/session/workspace/git-worktree.d.ts +1 -1
- package/dist/session/workspace/git-worktree.d.ts.map +1 -1
- package/dist/session/workspace/git-worktree.js.map +1 -1
- package/dist/session/workspace/index.d.ts +1 -1
- package/dist/session/workspace/index.d.ts.map +1 -1
- package/dist/session/workspace/index.js +3 -2
- package/dist/session/workspace/index.js.map +1 -1
- package/dist/store/run/disk.d.ts +4 -4
- package/dist/store/run/disk.d.ts.map +1 -1
- package/dist/store/run/disk.js.map +1 -1
- package/dist/store/session/__tests__/disk.test.js.map +1 -1
- package/dist/store/session/__tests__/memory.test.js.map +1 -1
- package/dist/store/session/disk.d.ts +6 -6
- package/dist/store/session/disk.d.ts.map +1 -1
- package/dist/store/session/disk.js +1 -1
- package/dist/store/session/disk.js.map +1 -1
- package/dist/store/session/index.d.ts +1 -1
- package/dist/store/session/index.d.ts.map +1 -1
- package/dist/store/session/index.js +2 -1
- package/dist/store/session/index.js.map +1 -1
- package/dist/store/session/linkage.d.ts +1 -1
- package/dist/store/session/linkage.d.ts.map +1 -1
- package/dist/store/session/memory.d.ts +5 -5
- package/dist/store/session/memory.d.ts.map +1 -1
- package/dist/store/session/memory.js +1 -1
- package/dist/store/session/memory.js.map +1 -1
- package/dist/store/thread/disk.d.ts +1 -1
- package/dist/store/thread/disk.d.ts.map +1 -1
- package/dist/store/thread/memory.d.ts +1 -1
- package/dist/store/thread/memory.d.ts.map +1 -1
- package/dist/telemetry/attributes.d.ts +0 -1
- package/dist/telemetry/attributes.d.ts.map +1 -1
- package/dist/telemetry/attributes.js +0 -3
- package/dist/telemetry/attributes.js.map +1 -1
- package/dist/telemetry/runtime-accessors.d.ts +1 -2
- package/dist/telemetry/runtime-accessors.d.ts.map +1 -1
- package/dist/telemetry/runtime-accessors.js +1 -4
- package/dist/telemetry/runtime-accessors.js.map +1 -1
- package/dist/test-setup.d.ts +22 -0
- package/dist/test-setup.d.ts.map +1 -0
- package/dist/test-setup.js +23 -0
- package/dist/test-setup.js.map +1 -0
- package/dist/tools/builtins/bash.d.ts +1 -1
- package/dist/tools/builtins/computer-use.d.ts +4 -4
- package/dist/tools/builtins/edit.d.ts +1 -1
- package/dist/tools/builtins/glob.d.ts +1 -1
- package/dist/tools/builtins/grep.d.ts +1 -1
- package/dist/tools/builtins/ls.d.ts +1 -1
- package/dist/tools/builtins/read-file.d.ts +1 -1
- package/dist/tools/builtins/search-tools.d.ts +1 -1
- package/dist/tools/builtins/write-file.d.ts +1 -1
- package/dist/types/agent/task.d.ts +2 -2
- package/dist/types/agent/task.d.ts.map +1 -1
- package/dist/{session/hierarchy/project.d.ts → types/project/entity.d.ts} +4 -4
- package/dist/types/project/entity.d.ts.map +1 -0
- package/dist/types/project/entity.js +2 -0
- package/dist/types/project/entity.js.map +1 -0
- package/dist/types/project/index.d.ts +2 -0
- package/dist/types/project/index.d.ts.map +1 -0
- package/dist/types/project/index.js +4 -0
- package/dist/types/project/index.js.map +1 -0
- package/dist/types/retention/archive-backend-ref.d.ts.map +1 -0
- package/dist/types/retention/archive-backend-ref.js.map +1 -0
- package/dist/types/retention/index.d.ts +4 -0
- package/dist/types/retention/index.d.ts.map +1 -0
- package/dist/types/retention/index.js +4 -0
- package/dist/types/retention/index.js.map +1 -0
- package/dist/types/retention/policy.d.ts.map +1 -0
- package/dist/types/retention/policy.js.map +1 -0
- package/dist/types/run/entity.d.ts +56 -0
- package/dist/types/run/entity.d.ts.map +1 -0
- package/dist/types/run/entity.js +2 -0
- package/dist/types/run/entity.js.map +1 -0
- package/dist/types/run/events.d.ts +2 -2
- package/dist/types/run/events.d.ts.map +1 -1
- package/dist/types/run/index.d.ts +7 -1
- package/dist/types/run/index.d.ts.map +1 -1
- package/dist/types/run/index.js +8 -9
- package/dist/types/run/index.js.map +1 -1
- package/dist/{session/hierarchy → types/run}/lineage.d.ts +1 -1
- package/dist/types/run/lineage.d.ts.map +1 -0
- package/dist/types/run/lineage.js.map +1 -0
- package/dist/types/run/replay.d.ts +53 -0
- package/dist/types/run/replay.d.ts.map +1 -0
- package/dist/types/run/replay.js +15 -0
- package/dist/types/run/replay.js.map +1 -0
- package/dist/types/run/schema-version.d.ts.map +1 -0
- package/dist/types/run/schema-version.js.map +1 -0
- package/dist/{session/events/types.d.ts → types/run/subsession-events.d.ts} +5 -5
- package/dist/types/run/subsession-events.d.ts.map +1 -0
- package/dist/types/run/subsession-events.js +2 -0
- package/dist/types/run/subsession-events.js.map +1 -0
- package/dist/{session/hierarchy → types/session}/actor.d.ts +1 -1
- package/dist/types/session/actor.d.ts.map +1 -0
- package/dist/{session/hierarchy → types/session}/actor.js.map +1 -1
- package/dist/types/session/entity.d.ts +51 -0
- package/dist/types/session/entity.d.ts.map +1 -0
- package/dist/types/session/entity.js +2 -0
- package/dist/types/session/entity.js.map +1 -0
- package/dist/types/session/index.d.ts +4 -0
- package/dist/types/session/index.d.ts.map +1 -1
- package/dist/{store → types}/session/messages.d.ts +2 -2
- package/dist/{store → types}/session/messages.d.ts.map +1 -1
- package/dist/types/session/messages.js.map +1 -0
- package/dist/types/session/store.d.ts +6 -6
- package/dist/types/session/store.d.ts.map +1 -1
- package/dist/{session/hierarchy → types/session}/sub-session.d.ts +9 -9
- package/dist/types/session/sub-session.d.ts.map +1 -0
- package/dist/types/session/sub-session.js.map +1 -0
- package/dist/{session → types}/summary/deliverable.d.ts +2 -2
- package/dist/types/summary/deliverable.d.ts.map +1 -0
- package/dist/types/summary/deliverable.js.map +1 -0
- package/dist/types/summary/index.d.ts +4 -0
- package/dist/types/summary/index.d.ts.map +1 -0
- package/dist/types/summary/index.js +4 -0
- package/dist/types/summary/index.js.map +1 -0
- package/dist/{session → types}/summary/ref.d.ts +9 -36
- package/dist/types/summary/ref.d.ts.map +1 -0
- package/dist/types/summary/ref.js +28 -0
- package/dist/types/summary/ref.js.map +1 -0
- package/dist/{session/hierarchy/tenant.d.ts → types/tenant/entity.d.ts} +2 -2
- package/dist/types/tenant/entity.d.ts.map +1 -0
- package/dist/types/tenant/entity.js +2 -0
- package/dist/types/tenant/entity.js.map +1 -0
- package/dist/types/tenant/index.d.ts +2 -0
- package/dist/types/tenant/index.d.ts.map +1 -0
- package/dist/types/tenant/index.js +4 -0
- package/dist/types/tenant/index.js.map +1 -0
- package/dist/{session/hierarchy/thread.d.ts → types/thread/entity.d.ts} +31 -7
- package/dist/types/thread/entity.d.ts.map +1 -0
- package/dist/types/thread/entity.js +2 -0
- package/dist/types/thread/entity.js.map +1 -0
- package/dist/types/thread/index.d.ts +1 -0
- package/dist/types/thread/index.d.ts.map +1 -1
- package/dist/types/thread/store.d.ts +1 -1
- package/dist/types/thread/store.d.ts.map +1 -1
- package/dist/types/workspace/index.d.ts +2 -0
- package/dist/types/workspace/index.d.ts.map +1 -0
- package/dist/types/workspace/index.js +7 -0
- package/dist/types/workspace/index.js.map +1 -0
- package/dist/{session → types}/workspace/ref.d.ts +1 -1
- package/dist/types/workspace/ref.d.ts.map +1 -0
- package/dist/types/workspace/ref.js.map +1 -0
- package/dist/utils/logger.d.ts +1 -1
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +5 -0
- package/dist/utils/logger.js.map +1 -1
- package/package.json +4 -1
- package/src/__tests__/replay-public-surface.test.ts +54 -0
- package/src/advisory/context.test.ts +109 -0
- package/src/advisory/evaluator.test.ts +192 -0
- package/src/advisory/executor.test.ts +272 -0
- package/src/advisory/registry.test.ts +75 -0
- package/src/agents/SupervisorAgent.ts +1 -1
- package/src/bridge/a2a/agent-card.test.ts +140 -0
- package/src/bridge/a2a/mapper.test.ts +293 -0
- package/src/bridge/a2a/message.test.ts +138 -0
- package/src/bridge/a2a/task.test.ts +235 -0
- package/src/bridge/a2a/task.ts +4 -4
- package/src/bridge/mcp/connector/adapter.test.ts +230 -0
- package/src/bridge/sse/mapper.test.ts +422 -0
- package/src/bridge/tools/connector/adapter.test.ts +224 -0
- package/src/bridge/tools/connector/definitions.test.ts +183 -0
- package/src/bridge/tools/connector/router.test.ts +159 -0
- package/src/bus/breaker.test.ts +274 -0
- package/src/bus/index.test.ts +183 -0
- package/src/bus/lock.test.ts +265 -0
- package/src/bus/ownership.test.ts +243 -0
- package/src/config/runtime.ts +0 -2
- package/src/connector/BaseConnector.test.ts +130 -0
- package/src/connector/builtins/http.test.ts +290 -0
- package/src/connector/builtins/webhook.test.ts +138 -0
- package/src/connector/execution/factory.test.ts +75 -0
- package/src/connector/execution/remote.test.ts +63 -0
- package/src/connector/mcp/adapter.test.ts +249 -0
- package/src/contracts/api.ts +2 -2
- package/src/contracts/index.ts +1 -3
- package/src/index.ts +11 -362
- package/src/manager/agent/__tests__/lifecycle.test.ts +2 -2
- package/src/manager/agent/lifecycle.ts +5 -5
- package/src/manager/run/persistence.ts +4 -4
- package/src/manager/thread/__tests__/lifecycle.test.ts +1 -1
- package/src/manager/thread/lifecycle.ts +2 -2
- package/src/plugin/loader.ts +0 -16
- package/src/public-runtime.ts +373 -0
- package/src/public-tools.ts +63 -0
- package/src/public-types.ts +156 -0
- package/src/rag/chunking.test.ts +107 -0
- package/src/rag/context-assembler.test.ts +114 -0
- package/src/rag/embedding.test.ts +130 -0
- package/src/rag/ingestion.test.ts +114 -0
- package/src/rag/knowledge-base.test.ts +106 -0
- package/src/rag/rag-tool.test.ts +167 -0
- package/src/rag/retriever.test.ts +210 -0
- package/src/rag/vector-store.test.ts +196 -0
- package/src/registry/ManagedRegistry.test.ts +118 -0
- package/src/registry/Registry.test.ts +91 -0
- package/src/registry/agent/definitions.test.ts +100 -0
- package/src/registry/connector/definitions.test.ts +51 -0
- package/src/registry/connector/scoped.test.ts +129 -0
- package/src/registry/plugin/index.test.ts +85 -0
- package/src/registry/tool/execute.test.ts +330 -0
- package/src/run/LimitChecker.ts +0 -9
- package/src/run/reporter.ts +3 -3
- package/src/runtime/query/__tests__/checkpoint.test.ts +169 -0
- package/src/runtime/query/checkpoint.ts +54 -0
- package/src/runtime/query/context.ts +0 -5
- package/src/runtime/query/index.ts +4 -4
- package/src/runtime/query/iteration/phases/advisory.test.ts +412 -0
- package/src/runtime/query/replay/__tests__/mutate.test.ts +134 -0
- package/src/runtime/query/replay/__tests__/prepare.test.ts +207 -0
- package/src/runtime/query/replay/list.ts +32 -0
- package/src/runtime/query/replay/mutate.ts +76 -0
- package/src/runtime/query/replay/prepare.ts +114 -0
- package/src/runtime/query/result.ts +2 -2
- package/src/session/__tests__/integration/_fixtures.ts +2 -2
- package/src/session/__tests__/integration/archive-gate.test.ts +1 -1
- package/src/session/__tests__/integration/capacity-caps.test.ts +1 -1
- package/src/session/__tests__/integration/e2e-spawn.test.ts +1 -1
- package/src/session/__tests__/integration/handoff-broadcast-e2e.test.ts +1 -1
- package/src/session/__tests__/integration/handoff-single-e2e.test.ts +1 -1
- package/src/session/__tests__/integration/prev-artifact-dag.test.ts +4 -1
- package/src/session/__tests__/integration/retention-archive.test.ts +1 -1
- package/src/session/__tests__/integration/spawn-rollback.test.ts +2 -2
- package/src/session/__tests__/integration/summary-materialization-e2e.test.ts +1 -1
- package/src/session/errors.ts +1 -1
- package/src/session/events/index.ts +5 -4
- package/src/session/handoff/__tests__/broadcast.test.ts +1 -1
- package/src/session/handoff/__tests__/capacity.test.ts +1 -1
- package/src/session/handoff/__tests__/single.test.ts +1 -1
- package/src/session/handoff/assignment.ts +1 -1
- package/src/session/handoff/broadcast.ts +2 -2
- package/src/session/handoff/single.ts +2 -2
- package/src/session/index.ts +7 -6
- package/src/session/intervention/__tests__/prev-artifact.test.ts +4 -1
- package/src/session/intervention/prev-artifact.ts +1 -1
- package/src/session/retention/__tests__/archive.test.ts +3 -3
- package/src/session/retention/__tests__/disk-backend.test.ts +4 -4
- package/src/session/retention/archive.ts +2 -2
- package/src/session/retention/backend.ts +4 -4
- package/src/session/retention/disk-backend.ts +4 -4
- package/src/session/retention/index.ts +6 -4
- package/src/session/{hierarchy/__tests__/session.test.ts → status/__tests__/derive.test.ts} +3 -2
- package/src/session/{hierarchy/session.ts → status/derive.ts} +9 -55
- package/src/session/summary/__tests__/materialize.test.ts +4 -7
- package/src/session/summary/errors.ts +51 -0
- package/src/session/summary/index.ts +7 -10
- package/src/session/summary/materialize.ts +4 -5
- package/src/session/workspace/__tests__/git-worktree.test.ts +1 -1
- package/src/session/workspace/driver.ts +2 -2
- package/src/session/workspace/git-worktree.ts +1 -1
- package/src/session/workspace/index.ts +7 -6
- package/src/store/run/disk.ts +4 -4
- package/src/store/session/__tests__/disk.test.ts +2 -2
- package/src/store/session/__tests__/memory.test.ts +2 -2
- package/src/store/session/disk.ts +12 -12
- package/src/store/session/index.ts +3 -2
- package/src/store/session/linkage.ts +1 -1
- package/src/store/session/memory.ts +6 -6
- package/src/store/thread/disk.ts +1 -1
- package/src/store/thread/memory.ts +1 -1
- package/src/telemetry/attributes.ts +0 -4
- package/src/telemetry/runtime-accessors.ts +1 -5
- package/src/test-setup.ts +24 -0
- package/src/types/agent/task.ts +2 -2
- package/src/{session/hierarchy/project.ts → types/project/entity.ts} +3 -3
- package/src/types/project/index.ts +4 -0
- package/src/types/retention/index.ts +6 -0
- package/src/types/run/entity.ts +63 -0
- package/src/types/run/events.ts +6 -6
- package/src/types/run/index.ts +16 -9
- package/src/{session/hierarchy → types/run}/lineage.ts +1 -1
- package/src/types/run/replay.ts +61 -0
- package/src/{session/events/types.ts → types/run/subsession-events.ts} +4 -4
- package/src/{session/hierarchy → types/session}/actor.ts +1 -1
- package/src/types/session/entity.ts +59 -0
- package/src/types/session/index.ts +15 -0
- package/src/{store → types}/session/messages.ts +2 -2
- package/src/types/session/store.ts +6 -6
- package/src/{session/hierarchy → types/session}/sub-session.ts +9 -9
- package/src/{session → types}/summary/deliverable.ts +2 -2
- package/src/types/summary/index.ts +18 -0
- package/src/{session → types}/summary/ref.ts +9 -44
- package/src/{session/hierarchy/tenant.ts → types/tenant/entity.ts} +1 -1
- package/src/types/tenant/index.ts +4 -0
- package/src/{session/hierarchy/thread.ts → types/thread/entity.ts} +30 -6
- package/src/types/thread/index.ts +1 -0
- package/src/types/thread/store.ts +1 -1
- package/src/types/workspace/index.ts +12 -0
- package/src/{session → types}/workspace/ref.ts +1 -1
- package/src/utils/logger.ts +6 -1
- package/dist/contracts/ids.d.ts +0 -2
- package/dist/contracts/ids.d.ts.map +0 -1
- package/dist/contracts/ids.js +0 -2
- package/dist/contracts/ids.js.map +0 -1
- package/dist/session/events/schema-version.d.ts.map +0 -1
- package/dist/session/events/schema-version.js.map +0 -1
- package/dist/session/events/types.d.ts.map +0 -1
- package/dist/session/events/types.js +0 -2
- package/dist/session/events/types.js.map +0 -1
- package/dist/session/hierarchy/__tests__/session.test.d.ts +0 -2
- package/dist/session/hierarchy/__tests__/session.test.d.ts.map +0 -1
- package/dist/session/hierarchy/__tests__/session.test.js.map +0 -1
- package/dist/session/hierarchy/actor.d.ts.map +0 -1
- package/dist/session/hierarchy/index.d.ts +0 -9
- package/dist/session/hierarchy/index.d.ts.map +0 -1
- package/dist/session/hierarchy/index.js +0 -4
- package/dist/session/hierarchy/index.js.map +0 -1
- package/dist/session/hierarchy/lineage.d.ts.map +0 -1
- package/dist/session/hierarchy/lineage.js.map +0 -1
- package/dist/session/hierarchy/project.d.ts.map +0 -1
- package/dist/session/hierarchy/project.js +0 -2
- package/dist/session/hierarchy/project.js.map +0 -1
- package/dist/session/hierarchy/session.d.ts +0 -71
- package/dist/session/hierarchy/session.d.ts.map +0 -1
- package/dist/session/hierarchy/session.js.map +0 -1
- package/dist/session/hierarchy/sub-session.d.ts.map +0 -1
- package/dist/session/hierarchy/sub-session.js.map +0 -1
- package/dist/session/hierarchy/tenant.d.ts.map +0 -1
- package/dist/session/hierarchy/tenant.js +0 -2
- package/dist/session/hierarchy/tenant.js.map +0 -1
- package/dist/session/hierarchy/thread.d.ts.map +0 -1
- package/dist/session/hierarchy/thread.js +0 -2
- package/dist/session/hierarchy/thread.js.map +0 -1
- package/dist/session/retention/archive-backend-ref.d.ts.map +0 -1
- package/dist/session/retention/archive-backend-ref.js.map +0 -1
- package/dist/session/retention/policy.d.ts.map +0 -1
- package/dist/session/retention/policy.js.map +0 -1
- package/dist/session/summary/deliverable.d.ts.map +0 -1
- package/dist/session/summary/deliverable.js.map +0 -1
- package/dist/session/summary/ref.d.ts.map +0 -1
- package/dist/session/summary/ref.js +0 -51
- package/dist/session/summary/ref.js.map +0 -1
- package/dist/session/workspace/ref.d.ts.map +0 -1
- package/dist/session/workspace/ref.js.map +0 -1
- package/dist/store/session/messages.js.map +0 -1
- package/dist/tools/builtins/__tests__/structuredOutput.example.d.ts +0 -140
- package/dist/tools/builtins/__tests__/structuredOutput.example.d.ts.map +0 -1
- package/dist/tools/builtins/__tests__/structuredOutput.example.js +0 -183
- package/dist/tools/builtins/__tests__/structuredOutput.example.js.map +0 -1
- package/dist/types/run/state.d.ts +0 -30
- package/dist/types/run/state.d.ts.map +0 -1
- package/dist/types/run/state.js +0 -2
- package/dist/types/run/state.js.map +0 -1
- package/src/contracts/ids.ts +0 -1
- package/src/session/hierarchy/index.ts +0 -18
- package/src/tools/builtins/__tests__/structuredOutput.example.ts +0 -221
- package/src/types/run/state.ts +0 -35
- /package/dist/{session → types}/retention/archive-backend-ref.d.ts +0 -0
- /package/dist/{session → types}/retention/archive-backend-ref.js +0 -0
- /package/dist/{session → types}/retention/policy.d.ts +0 -0
- /package/dist/{session → types}/retention/policy.js +0 -0
- /package/dist/{session/hierarchy → types/run}/lineage.js +0 -0
- /package/dist/{session/events → types/run}/schema-version.d.ts +0 -0
- /package/dist/{session/events → types/run}/schema-version.js +0 -0
- /package/dist/{session/hierarchy → types/session}/actor.js +0 -0
- /package/dist/{store → types}/session/messages.js +0 -0
- /package/dist/{session/hierarchy → types/session}/sub-session.js +0 -0
- /package/dist/{session → types}/summary/deliverable.js +0 -0
- /package/dist/{session → types}/workspace/ref.js +0 -0
- /package/src/{session → types}/retention/archive-backend-ref.ts +0 -0
- /package/src/{session → types}/retention/policy.ts +0 -0
- /package/src/{session/events → types/run}/schema-version.ts +0 -0
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Current-code invariants asserted (2026-04-21, ses_006 Phase 4):
|
|
3
|
+
*
|
|
4
|
+
* - `DefaultRetriever.retrieve(query, scope, kbId)` dispatches by
|
|
5
|
+
* `effectiveConfig.mode` (query.config overrides instance config).
|
|
6
|
+
* - Query expansion: if `recentMessages` is present and non-empty,
|
|
7
|
+
* appends the last 3 messages joined with spaces after a
|
|
8
|
+
* `\n\nContext: ` marker. Otherwise passes `query.text` verbatim.
|
|
9
|
+
* - `vector` mode: embeds the (expanded) query once, forwards
|
|
10
|
+
* `{embedding, topK, tenantId, knowledgeBaseId, minScore}` to the
|
|
11
|
+
* store, returns store results unchanged.
|
|
12
|
+
* - `keyword` mode: fetches `topK * 2` results from vector search with
|
|
13
|
+
* `minScore: 0`, then rescores via BM25 against the query's
|
|
14
|
+
* tokenized form. Filters score > 0, sorts desc, slices to topK.
|
|
15
|
+
* Tokenization: lowercase, strip non-`\w\s`, split by whitespace,
|
|
16
|
+
* drop tokens length ≤ 1.
|
|
17
|
+
* - `hybrid` mode: runs vector + keyword in parallel, merges by
|
|
18
|
+
* `chunk.id`, weights vector by `alpha` and keyword by `1 - alpha`
|
|
19
|
+
* (default alpha = 0.7). Sorts desc, slices to topK.
|
|
20
|
+
* - Result shape: `{chunks, query, expandedQuery?, mode, durationMs}`.
|
|
21
|
+
* `expandedQuery` is omitted when equal to original `query.text`.
|
|
22
|
+
* - Unknown mode would hit the exhaustive throw (unreachable via
|
|
23
|
+
* types; not asserted).
|
|
24
|
+
*/
|
|
25
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
26
|
+
import { DefaultRetriever } from './retriever.js';
|
|
27
|
+
const TENANT = 't_1';
|
|
28
|
+
const KB = 'kb_1';
|
|
29
|
+
const scope = { tenantId: TENANT };
|
|
30
|
+
function chunk(id, content) {
|
|
31
|
+
return {
|
|
32
|
+
id: id,
|
|
33
|
+
documentId: 'doc_1',
|
|
34
|
+
knowledgeBaseId: KB,
|
|
35
|
+
tenantId: TENANT,
|
|
36
|
+
content,
|
|
37
|
+
index: 0,
|
|
38
|
+
tokenCount: 0,
|
|
39
|
+
embedding: [1, 0, 0],
|
|
40
|
+
metadata: {},
|
|
41
|
+
createdAt: 0,
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
function r(id, content, score) {
|
|
45
|
+
return { chunk: chunk(id, content), score };
|
|
46
|
+
}
|
|
47
|
+
function makeStore(searchResults) {
|
|
48
|
+
return {
|
|
49
|
+
search: vi.fn(async () => searchResults),
|
|
50
|
+
upsert: vi.fn(),
|
|
51
|
+
delete: vi.fn(),
|
|
52
|
+
deleteByDocument: vi.fn(),
|
|
53
|
+
deleteByKnowledgeBase: vi.fn(),
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
function makeEmbedder() {
|
|
57
|
+
return {
|
|
58
|
+
id: 'mock',
|
|
59
|
+
model: 'x',
|
|
60
|
+
dimensions: 3,
|
|
61
|
+
embed: vi.fn(async (texts) => texts.map(() => [1, 0, 0])),
|
|
62
|
+
embedQuery: vi.fn(async () => [1, 0, 0]),
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
describe('DefaultRetriever — vector mode', () => {
|
|
66
|
+
it('forwards embedded query + topK + tenant + minScore to store', async () => {
|
|
67
|
+
const store = makeStore([r('a', 'x', 0.9)]);
|
|
68
|
+
const emb = makeEmbedder();
|
|
69
|
+
const retriever = new DefaultRetriever(store, emb, {
|
|
70
|
+
mode: 'vector',
|
|
71
|
+
topK: 3,
|
|
72
|
+
minScore: 0.2,
|
|
73
|
+
});
|
|
74
|
+
await retriever.retrieve({ text: 'hi' }, scope, KB);
|
|
75
|
+
expect(store.search).toHaveBeenCalledWith(expect.objectContaining({
|
|
76
|
+
embedding: [1, 0, 0],
|
|
77
|
+
topK: 3,
|
|
78
|
+
tenantId: TENANT,
|
|
79
|
+
knowledgeBaseId: KB,
|
|
80
|
+
minScore: 0.2,
|
|
81
|
+
}));
|
|
82
|
+
});
|
|
83
|
+
it('returns mode + durationMs + chunks without mutation', async () => {
|
|
84
|
+
const results = [r('a', 'x', 0.9)];
|
|
85
|
+
const store = makeStore(results);
|
|
86
|
+
const retriever = new DefaultRetriever(store, makeEmbedder(), {
|
|
87
|
+
mode: 'vector',
|
|
88
|
+
topK: 5,
|
|
89
|
+
});
|
|
90
|
+
const out = await retriever.retrieve({ text: 'hi' }, scope);
|
|
91
|
+
expect(out.mode).toBe('vector');
|
|
92
|
+
expect(out.chunks).toEqual(results);
|
|
93
|
+
expect(typeof out.durationMs).toBe('number');
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
describe('DefaultRetriever — query expansion', () => {
|
|
97
|
+
it('when recentMessages exists, appends "Context: " + last 3 joined', async () => {
|
|
98
|
+
const store = makeStore([]);
|
|
99
|
+
const emb = makeEmbedder();
|
|
100
|
+
const retriever = new DefaultRetriever(store, emb, { mode: 'vector', topK: 3 });
|
|
101
|
+
const out = await retriever.retrieve({ text: 'query', recentMessages: ['m1', 'm2', 'm3', 'm4'] }, scope);
|
|
102
|
+
expect(out.expandedQuery).toBe('query\n\nContext: m2 m3 m4');
|
|
103
|
+
expect(emb.embedQuery).toHaveBeenCalledWith('query\n\nContext: m2 m3 m4');
|
|
104
|
+
});
|
|
105
|
+
it('when no recentMessages, expandedQuery is undefined (original == expanded)', async () => {
|
|
106
|
+
const store = makeStore([]);
|
|
107
|
+
const retriever = new DefaultRetriever(store, makeEmbedder(), {
|
|
108
|
+
mode: 'vector',
|
|
109
|
+
topK: 3,
|
|
110
|
+
});
|
|
111
|
+
const out = await retriever.retrieve({ text: 'plain' }, scope);
|
|
112
|
+
expect(out.expandedQuery).toBeUndefined();
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
describe('DefaultRetriever — keyword mode', () => {
|
|
116
|
+
it('fetches 2*topK from store, rescores via BM25, slices to topK', async () => {
|
|
117
|
+
// 6 candidate chunks (topK * 2 with topK=3) — retriever requests 2*topK with minScore 0.
|
|
118
|
+
const store = makeStore([
|
|
119
|
+
r('a', 'apple orange', 0.1),
|
|
120
|
+
r('b', 'banana apple apple', 0.1),
|
|
121
|
+
r('c', 'unrelated text', 0.1),
|
|
122
|
+
r('d', 'apple apple apple', 0.1),
|
|
123
|
+
r('e', 'nothing here', 0.1),
|
|
124
|
+
r('f', 'apple', 0.1),
|
|
125
|
+
]);
|
|
126
|
+
const retriever = new DefaultRetriever(store, makeEmbedder(), {
|
|
127
|
+
mode: 'keyword',
|
|
128
|
+
topK: 3,
|
|
129
|
+
});
|
|
130
|
+
const out = await retriever.retrieve({ text: 'apple' }, scope);
|
|
131
|
+
expect(out.chunks.length).toBeLessThanOrEqual(3);
|
|
132
|
+
expect(out.chunks.every((c) => c.score > 0)).toBe(true);
|
|
133
|
+
// Tokenization: 'nothing' + 'here' — doesn't contain 'apple' → score 0 → filtered.
|
|
134
|
+
expect(out.chunks.every((c) => c.chunk.id !== 'e')).toBe(true);
|
|
135
|
+
});
|
|
136
|
+
it('query store is called with minScore: 0 + topK*2', async () => {
|
|
137
|
+
const store = makeStore([r('a', 'apple', 0.5)]);
|
|
138
|
+
const retriever = new DefaultRetriever(store, makeEmbedder(), {
|
|
139
|
+
mode: 'keyword',
|
|
140
|
+
topK: 2,
|
|
141
|
+
});
|
|
142
|
+
await retriever.retrieve({ text: 'apple' }, scope);
|
|
143
|
+
expect(store.search).toHaveBeenCalledWith(expect.objectContaining({ topK: 4, minScore: 0 }));
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
describe('DefaultRetriever — hybrid mode', () => {
|
|
147
|
+
it('merges by chunk.id, weighted by alpha (default 0.7)', async () => {
|
|
148
|
+
const store = makeStore([r('a', 'apple', 1), r('b', 'banana', 0.5)]);
|
|
149
|
+
const retriever = new DefaultRetriever(store, makeEmbedder(), {
|
|
150
|
+
mode: 'hybrid',
|
|
151
|
+
topK: 5,
|
|
152
|
+
});
|
|
153
|
+
const out = await retriever.retrieve({ text: 'apple' }, scope);
|
|
154
|
+
// Vector side: a=0.7, b=0.35. Keyword side (BM25): a matches → >0; b=0.
|
|
155
|
+
// Hybrid: a stays high; b gets only vector weight.
|
|
156
|
+
expect(out.chunks[0]?.chunk.id).toBe('a');
|
|
157
|
+
});
|
|
158
|
+
it('chunks in only one side still appear with partial weight', async () => {
|
|
159
|
+
const store = makeStore([r('a', 'apple', 1)]);
|
|
160
|
+
const retriever = new DefaultRetriever(store, makeEmbedder(), {
|
|
161
|
+
mode: 'hybrid',
|
|
162
|
+
topK: 5,
|
|
163
|
+
});
|
|
164
|
+
const out = await retriever.retrieve({ text: 'apple' }, scope);
|
|
165
|
+
expect(out.chunks.length).toBe(1);
|
|
166
|
+
expect(out.chunks[0]?.score).toBeGreaterThan(0);
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
describe('DefaultRetriever — config merge', () => {
|
|
170
|
+
it('query.config overrides instance config per-call', async () => {
|
|
171
|
+
const store = makeStore([r('a', 'x', 0.9)]);
|
|
172
|
+
const retriever = new DefaultRetriever(store, makeEmbedder(), {
|
|
173
|
+
mode: 'vector',
|
|
174
|
+
topK: 5,
|
|
175
|
+
});
|
|
176
|
+
await retriever.retrieve({ text: 'hi', config: { topK: 1 } }, scope);
|
|
177
|
+
expect(store.search).toHaveBeenCalledWith(expect.objectContaining({ topK: 1 }));
|
|
178
|
+
});
|
|
179
|
+
});
|
|
180
|
+
//# sourceMappingURL=retriever.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retriever.test.js","sourceRoot":"","sources":["../../src/rag/retriever.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Current-code invariants asserted (2026-04-21, ses_006 Phase 4):
|
|
3
|
+
*
|
|
4
|
+
* This file doubles as the VectorStore contract — the tests here run
|
|
5
|
+
* against `InMemoryVectorStore` as the reference implementation, and
|
|
6
|
+
* are the spec a future `@namzu/vector-store-conformance` package will
|
|
7
|
+
* be built around (D4 ratification + Q5 refinement: contract first,
|
|
8
|
+
* not "whatever the reference happens to do").
|
|
9
|
+
*
|
|
10
|
+
* **VectorStore contract (derived from current code, 2026-04-21):**
|
|
11
|
+
*
|
|
12
|
+
* - `upsert(chunks[])`: stores each chunk keyed by `chunk.id`. Re-upsert
|
|
13
|
+
* of a chunk with the same id REPLACES — no merge, no error. Tenant
|
|
14
|
+
* scoping is carried on each chunk, not enforced at upsert (the
|
|
15
|
+
* caller is trusted).
|
|
16
|
+
* - `search(query)`: returns `VectorSearchResult[]`:
|
|
17
|
+
* - Filters by `tenantId` (EXACT match).
|
|
18
|
+
* - If `knowledgeBaseId` is set, filters by that too.
|
|
19
|
+
* - Skips chunks with `embedding === undefined`.
|
|
20
|
+
* - Applies `filter` as metadata-equality AND across the whole
|
|
21
|
+
* filter object.
|
|
22
|
+
* - Computes similarity via `cosineSimilarity(query, chunk.embedding)`.
|
|
23
|
+
* - If `minScore` is set, drops scores below it.
|
|
24
|
+
* - Sorts descending by score and returns the top `topK` results.
|
|
25
|
+
* - `delete(chunkIds[])`: deletes by exact chunk id. Unknown ids are
|
|
26
|
+
* silently ignored.
|
|
27
|
+
* - `deleteByDocument(documentId)`: NOT tenant-scoped in the
|
|
28
|
+
* current API — deletes every chunk with matching `documentId`
|
|
29
|
+
* ACROSS tenants. This is an asymmetry with `search` /
|
|
30
|
+
* `deleteByKnowledgeBase` and is intentional to pin (Codex #9 flag).
|
|
31
|
+
* - `deleteByKnowledgeBase(kbId, tenantId)`: tenant-scoped deletion
|
|
32
|
+
* by knowledge base.
|
|
33
|
+
* - `cosineSimilarity(a, b)`: returns 0 when arrays differ in length
|
|
34
|
+
* OR when either has zero norm. Otherwise returns the standard
|
|
35
|
+
* dot-product / (‖a‖·‖b‖) result.
|
|
36
|
+
*/
|
|
37
|
+
export {};
|
|
38
|
+
//# sourceMappingURL=vector-store.test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vector-store.test.d.ts","sourceRoot":"","sources":["../../src/rag/vector-store.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG"}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Current-code invariants asserted (2026-04-21, ses_006 Phase 4):
|
|
3
|
+
*
|
|
4
|
+
* This file doubles as the VectorStore contract — the tests here run
|
|
5
|
+
* against `InMemoryVectorStore` as the reference implementation, and
|
|
6
|
+
* are the spec a future `@namzu/vector-store-conformance` package will
|
|
7
|
+
* be built around (D4 ratification + Q5 refinement: contract first,
|
|
8
|
+
* not "whatever the reference happens to do").
|
|
9
|
+
*
|
|
10
|
+
* **VectorStore contract (derived from current code, 2026-04-21):**
|
|
11
|
+
*
|
|
12
|
+
* - `upsert(chunks[])`: stores each chunk keyed by `chunk.id`. Re-upsert
|
|
13
|
+
* of a chunk with the same id REPLACES — no merge, no error. Tenant
|
|
14
|
+
* scoping is carried on each chunk, not enforced at upsert (the
|
|
15
|
+
* caller is trusted).
|
|
16
|
+
* - `search(query)`: returns `VectorSearchResult[]`:
|
|
17
|
+
* - Filters by `tenantId` (EXACT match).
|
|
18
|
+
* - If `knowledgeBaseId` is set, filters by that too.
|
|
19
|
+
* - Skips chunks with `embedding === undefined`.
|
|
20
|
+
* - Applies `filter` as metadata-equality AND across the whole
|
|
21
|
+
* filter object.
|
|
22
|
+
* - Computes similarity via `cosineSimilarity(query, chunk.embedding)`.
|
|
23
|
+
* - If `minScore` is set, drops scores below it.
|
|
24
|
+
* - Sorts descending by score and returns the top `topK` results.
|
|
25
|
+
* - `delete(chunkIds[])`: deletes by exact chunk id. Unknown ids are
|
|
26
|
+
* silently ignored.
|
|
27
|
+
* - `deleteByDocument(documentId)`: NOT tenant-scoped in the
|
|
28
|
+
* current API — deletes every chunk with matching `documentId`
|
|
29
|
+
* ACROSS tenants. This is an asymmetry with `search` /
|
|
30
|
+
* `deleteByKnowledgeBase` and is intentional to pin (Codex #9 flag).
|
|
31
|
+
* - `deleteByKnowledgeBase(kbId, tenantId)`: tenant-scoped deletion
|
|
32
|
+
* by knowledge base.
|
|
33
|
+
* - `cosineSimilarity(a, b)`: returns 0 when arrays differ in length
|
|
34
|
+
* OR when either has zero norm. Otherwise returns the standard
|
|
35
|
+
* dot-product / (‖a‖·‖b‖) result.
|
|
36
|
+
*/
|
|
37
|
+
import { describe, expect, it } from 'vitest';
|
|
38
|
+
import { InMemoryVectorStore, cosineSimilarity } from './vector-store.js';
|
|
39
|
+
const T1 = 'tenant_1';
|
|
40
|
+
const T2 = 'tenant_2';
|
|
41
|
+
const KB1 = 'kb_1';
|
|
42
|
+
const KB2 = 'kb_2';
|
|
43
|
+
const D1 = 'doc_1';
|
|
44
|
+
const D2 = 'doc_2';
|
|
45
|
+
function chunk(id, overrides = {}) {
|
|
46
|
+
return {
|
|
47
|
+
id: id,
|
|
48
|
+
documentId: D1,
|
|
49
|
+
knowledgeBaseId: KB1,
|
|
50
|
+
tenantId: T1,
|
|
51
|
+
content: `content of ${id}`,
|
|
52
|
+
index: 0,
|
|
53
|
+
tokenCount: 10,
|
|
54
|
+
embedding: [1, 0, 0],
|
|
55
|
+
metadata: {},
|
|
56
|
+
createdAt: Date.now(),
|
|
57
|
+
...overrides,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
const baseQuery = {
|
|
61
|
+
embedding: [1, 0, 0],
|
|
62
|
+
topK: 10,
|
|
63
|
+
tenantId: T1,
|
|
64
|
+
};
|
|
65
|
+
describe('InMemoryVectorStore — upsert', () => {
|
|
66
|
+
it('stores chunks by id; re-upsert replaces', async () => {
|
|
67
|
+
const s = new InMemoryVectorStore();
|
|
68
|
+
await s.upsert([chunk('c1', { content: 'v1' })]);
|
|
69
|
+
await s.upsert([chunk('c1', { content: 'v2' })]);
|
|
70
|
+
const results = await s.search(baseQuery);
|
|
71
|
+
expect(results).toHaveLength(1);
|
|
72
|
+
expect(results[0]?.chunk.content).toBe('v2');
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
describe('InMemoryVectorStore — search', () => {
|
|
76
|
+
it('enforces tenant isolation on the query path', async () => {
|
|
77
|
+
const s = new InMemoryVectorStore();
|
|
78
|
+
await s.upsert([
|
|
79
|
+
chunk('a', { tenantId: T1, embedding: [1, 0, 0] }),
|
|
80
|
+
chunk('b', { tenantId: T2, embedding: [1, 0, 0] }),
|
|
81
|
+
]);
|
|
82
|
+
const results = await s.search({ ...baseQuery, tenantId: T1 });
|
|
83
|
+
expect(results.map((r) => r.chunk.id)).toEqual(['a']);
|
|
84
|
+
});
|
|
85
|
+
it('filters by knowledgeBaseId when provided', async () => {
|
|
86
|
+
const s = new InMemoryVectorStore();
|
|
87
|
+
await s.upsert([chunk('a', { knowledgeBaseId: KB1 }), chunk('b', { knowledgeBaseId: KB2 })]);
|
|
88
|
+
const results = await s.search({ ...baseQuery, knowledgeBaseId: KB1 });
|
|
89
|
+
expect(results.map((r) => r.chunk.id)).toEqual(['a']);
|
|
90
|
+
});
|
|
91
|
+
it('skips chunks with no embedding', async () => {
|
|
92
|
+
const s = new InMemoryVectorStore();
|
|
93
|
+
await s.upsert([chunk('a', { embedding: [1, 0, 0] }), chunk('b', { embedding: undefined })]);
|
|
94
|
+
const results = await s.search(baseQuery);
|
|
95
|
+
expect(results.map((r) => r.chunk.id)).toEqual(['a']);
|
|
96
|
+
});
|
|
97
|
+
it('applies AND-of-equalities across filter keys', async () => {
|
|
98
|
+
const s = new InMemoryVectorStore();
|
|
99
|
+
await s.upsert([
|
|
100
|
+
chunk('a', { metadata: { lang: 'en', year: 2026 } }),
|
|
101
|
+
chunk('b', { metadata: { lang: 'en', year: 2024 } }),
|
|
102
|
+
chunk('c', { metadata: { lang: 'tr', year: 2026 } }),
|
|
103
|
+
]);
|
|
104
|
+
const results = await s.search({
|
|
105
|
+
...baseQuery,
|
|
106
|
+
filter: { lang: 'en', year: 2026 },
|
|
107
|
+
});
|
|
108
|
+
expect(results.map((r) => r.chunk.id)).toEqual(['a']);
|
|
109
|
+
});
|
|
110
|
+
it('applies minScore cutoff', async () => {
|
|
111
|
+
const s = new InMemoryVectorStore();
|
|
112
|
+
await s.upsert([
|
|
113
|
+
chunk('same', { embedding: [1, 0, 0] }),
|
|
114
|
+
chunk('orthogonal', { embedding: [0, 1, 0] }),
|
|
115
|
+
]);
|
|
116
|
+
const results = await s.search({ ...baseQuery, minScore: 0.5 });
|
|
117
|
+
expect(results.map((r) => r.chunk.id)).toEqual(['same']);
|
|
118
|
+
});
|
|
119
|
+
it('sorts descending by score and slices to topK', async () => {
|
|
120
|
+
const s = new InMemoryVectorStore();
|
|
121
|
+
await s.upsert([
|
|
122
|
+
chunk('strong', { embedding: [1, 0, 0] }),
|
|
123
|
+
chunk('medium', { embedding: [0.5, 0.5, 0] }),
|
|
124
|
+
chunk('weak', { embedding: [0.1, 0.9, 0] }),
|
|
125
|
+
]);
|
|
126
|
+
const results = await s.search({ ...baseQuery, topK: 2 });
|
|
127
|
+
expect(results.map((r) => r.chunk.id)).toEqual(['strong', 'medium']);
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
describe('InMemoryVectorStore — delete', () => {
|
|
131
|
+
it('delete(chunkIds) removes each id; unknown ids are silent', async () => {
|
|
132
|
+
const s = new InMemoryVectorStore();
|
|
133
|
+
await s.upsert([chunk('a'), chunk('b')]);
|
|
134
|
+
await s.delete(['a', 'missing']);
|
|
135
|
+
expect((await s.search(baseQuery)).map((r) => r.chunk.id)).toEqual(['b']);
|
|
136
|
+
});
|
|
137
|
+
it('deleteByDocument removes every chunk of the document ACROSS tenants (asymmetry per Codex #9)', async () => {
|
|
138
|
+
const s = new InMemoryVectorStore();
|
|
139
|
+
await s.upsert([
|
|
140
|
+
chunk('a', { documentId: D1, tenantId: T1 }),
|
|
141
|
+
chunk('b', { documentId: D1, tenantId: T2 }),
|
|
142
|
+
chunk('c', { documentId: D2, tenantId: T1 }),
|
|
143
|
+
]);
|
|
144
|
+
await s.deleteByDocument(D1);
|
|
145
|
+
// Both D1 chunks gone even though we didn't pass a tenant.
|
|
146
|
+
expect((await s.search({ ...baseQuery, tenantId: T1 })).map((r) => r.chunk.id)).toEqual(['c']);
|
|
147
|
+
expect(await s.search({ ...baseQuery, tenantId: T2 })).toEqual([]);
|
|
148
|
+
});
|
|
149
|
+
it('deleteByKnowledgeBase is tenant-scoped', async () => {
|
|
150
|
+
const s = new InMemoryVectorStore();
|
|
151
|
+
await s.upsert([
|
|
152
|
+
chunk('a', { knowledgeBaseId: KB1, tenantId: T1 }),
|
|
153
|
+
chunk('b', { knowledgeBaseId: KB1, tenantId: T2 }),
|
|
154
|
+
]);
|
|
155
|
+
await s.deleteByKnowledgeBase(KB1, T1);
|
|
156
|
+
expect(await s.search({ ...baseQuery, tenantId: T1 })).toEqual([]);
|
|
157
|
+
expect((await s.search({ ...baseQuery, tenantId: T2 })).map((r) => r.chunk.id)).toEqual(['b']);
|
|
158
|
+
});
|
|
159
|
+
});
|
|
160
|
+
describe('cosineSimilarity', () => {
|
|
161
|
+
it('is 1 for identical non-zero vectors', () => {
|
|
162
|
+
expect(cosineSimilarity([1, 2, 3], [1, 2, 3])).toBeCloseTo(1);
|
|
163
|
+
});
|
|
164
|
+
it('is 0 for orthogonal vectors', () => {
|
|
165
|
+
expect(cosineSimilarity([1, 0], [0, 1])).toBe(0);
|
|
166
|
+
});
|
|
167
|
+
it('is 0 when vectors differ in length', () => {
|
|
168
|
+
expect(cosineSimilarity([1, 0], [1, 0, 0])).toBe(0);
|
|
169
|
+
});
|
|
170
|
+
it('is 0 when either vector has zero norm', () => {
|
|
171
|
+
expect(cosineSimilarity([0, 0], [1, 1])).toBe(0);
|
|
172
|
+
expect(cosineSimilarity([1, 1], [0, 0])).toBe(0);
|
|
173
|
+
});
|
|
174
|
+
});
|
|
175
|
+
//# sourceMappingURL=vector-store.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vector-store.test.js","sourceRoot":"","sources":["../../src/rag/vector-store.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Current-code invariants asserted (2026-04-21, ses_006 Phase 3):
|
|
3
|
+
*
|
|
4
|
+
* - `ManagedRegistry` extends `Registry` with a component-named
|
|
5
|
+
* logger + two optional id-extraction strategies: `idField` or
|
|
6
|
+
* `computeId`. `computeId` takes precedence when both are set.
|
|
7
|
+
* - `register(id, item)` (2-arg): throws when `item` is missing;
|
|
8
|
+
* warn-logs + overwrites on duplicate id (no typed error).
|
|
9
|
+
* - `register(item)` (1-arg): extracts id via computeId/idField;
|
|
10
|
+
* throws when neither is configured.
|
|
11
|
+
* - `register(items[])`: batch-registers (recursively calls the
|
|
12
|
+
* single-arg path for each). Any failure in a single register
|
|
13
|
+
* throws and aborts the batch (no partial-success semantics).
|
|
14
|
+
* - `getOrThrow(id)`: returns the item; throws
|
|
15
|
+
* `new Error("Not found: <id>. Available: <csv of known ids>")`
|
|
16
|
+
* — a plain `Error`, NOT a typed `XYZNotFoundError` (Codex #1).
|
|
17
|
+
* - No start / stop lifecycle exists (design §2.3 claim was
|
|
18
|
+
* fictional).
|
|
19
|
+
*/
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=ManagedRegistry.test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ManagedRegistry.test.d.ts","sourceRoot":"","sources":["../../src/registry/ManagedRegistry.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Current-code invariants asserted (2026-04-21, ses_006 Phase 3):
|
|
3
|
+
*
|
|
4
|
+
* - `ManagedRegistry` extends `Registry` with a component-named
|
|
5
|
+
* logger + two optional id-extraction strategies: `idField` or
|
|
6
|
+
* `computeId`. `computeId` takes precedence when both are set.
|
|
7
|
+
* - `register(id, item)` (2-arg): throws when `item` is missing;
|
|
8
|
+
* warn-logs + overwrites on duplicate id (no typed error).
|
|
9
|
+
* - `register(item)` (1-arg): extracts id via computeId/idField;
|
|
10
|
+
* throws when neither is configured.
|
|
11
|
+
* - `register(items[])`: batch-registers (recursively calls the
|
|
12
|
+
* single-arg path for each). Any failure in a single register
|
|
13
|
+
* throws and aborts the batch (no partial-success semantics).
|
|
14
|
+
* - `getOrThrow(id)`: returns the item; throws
|
|
15
|
+
* `new Error("Not found: <id>. Available: <csv of known ids>")`
|
|
16
|
+
* — a plain `Error`, NOT a typed `XYZNotFoundError` (Codex #1).
|
|
17
|
+
* - No start / stop lifecycle exists (design §2.3 claim was
|
|
18
|
+
* fictional).
|
|
19
|
+
*/
|
|
20
|
+
import { describe, expect, it, vi } from 'vitest';
|
|
21
|
+
import { ManagedRegistry } from './ManagedRegistry.js';
|
|
22
|
+
function makeLogger() {
|
|
23
|
+
const self = {
|
|
24
|
+
info: vi.fn(),
|
|
25
|
+
warn: vi.fn(),
|
|
26
|
+
error: vi.fn(),
|
|
27
|
+
debug: vi.fn(),
|
|
28
|
+
child: vi.fn(),
|
|
29
|
+
};
|
|
30
|
+
self.child = vi.fn(() => self);
|
|
31
|
+
return self;
|
|
32
|
+
}
|
|
33
|
+
describe('ManagedRegistry', () => {
|
|
34
|
+
describe('register (2-arg form)', () => {
|
|
35
|
+
it('throws when called with (id) only', () => {
|
|
36
|
+
const r = new ManagedRegistry({ componentName: 't' });
|
|
37
|
+
// biome-ignore lint/suspicious/noExplicitAny: exercises the no-item-arg path
|
|
38
|
+
expect(() => r.register('a')).toThrow(/requires an item argument/);
|
|
39
|
+
});
|
|
40
|
+
it('warn-logs then overwrites on duplicate id', () => {
|
|
41
|
+
const logger = makeLogger();
|
|
42
|
+
const r = new ManagedRegistry({ componentName: 't', logger });
|
|
43
|
+
const a = { id: 'a', info: { id: 'a' }, value: 1 };
|
|
44
|
+
const b = { id: 'a', info: { id: 'a' }, value: 2 };
|
|
45
|
+
r.register('a', a);
|
|
46
|
+
r.register('a', b);
|
|
47
|
+
expect(r.get('a')?.value).toBe(2);
|
|
48
|
+
expect(logger.warn).toHaveBeenCalledWith(expect.stringContaining('"a" already registered'));
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
describe('register (single-item form)', () => {
|
|
52
|
+
it('uses idField when computeId is not set', () => {
|
|
53
|
+
const r = new ManagedRegistry({ componentName: 't', idField: 'id' });
|
|
54
|
+
r.register({ id: 'a', info: { id: 'nested' }, value: 1 });
|
|
55
|
+
expect(r.get('a')).toBeDefined();
|
|
56
|
+
expect(r.get('nested')).toBeUndefined();
|
|
57
|
+
});
|
|
58
|
+
it('computeId takes precedence over idField when both are set', () => {
|
|
59
|
+
const r = new ManagedRegistry({
|
|
60
|
+
componentName: 't',
|
|
61
|
+
idField: 'id',
|
|
62
|
+
computeId: (item) => item.info.id,
|
|
63
|
+
});
|
|
64
|
+
r.register({ id: 'top', info: { id: 'nested' }, value: 1 });
|
|
65
|
+
expect(r.get('nested')).toBeDefined();
|
|
66
|
+
expect(r.get('top')).toBeUndefined();
|
|
67
|
+
});
|
|
68
|
+
it('throws when neither idField nor computeId is configured', () => {
|
|
69
|
+
const r = new ManagedRegistry({ componentName: 't' });
|
|
70
|
+
expect(() => r.register({ id: 'a', info: { id: 'a' }, value: 1 })).toThrow(/requires idField or computeId/);
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
describe('register (array form)', () => {
|
|
74
|
+
it('batch-registers via the single-item path', () => {
|
|
75
|
+
const r = new ManagedRegistry({ componentName: 't', idField: 'id' });
|
|
76
|
+
r.register([
|
|
77
|
+
{ id: 'a', info: { id: 'a' }, value: 1 },
|
|
78
|
+
{ id: 'b', info: { id: 'b' }, value: 2 },
|
|
79
|
+
]);
|
|
80
|
+
expect(r.listIds()).toEqual(['a', 'b']);
|
|
81
|
+
});
|
|
82
|
+
});
|
|
83
|
+
describe('getOrThrow', () => {
|
|
84
|
+
it('returns the item when present', () => {
|
|
85
|
+
const r = new ManagedRegistry({ componentName: 't', idField: 'id' });
|
|
86
|
+
const a = { id: 'a', info: { id: 'a' }, value: 1 };
|
|
87
|
+
r.register(a);
|
|
88
|
+
expect(r.getOrThrow('a')).toBe(a);
|
|
89
|
+
});
|
|
90
|
+
it('throws a plain Error naming the missing id + available ids', () => {
|
|
91
|
+
const r = new ManagedRegistry({ componentName: 't', idField: 'id' });
|
|
92
|
+
r.register({ id: 'a', info: { id: 'a' }, value: 1 });
|
|
93
|
+
r.register({ id: 'b', info: { id: 'b' }, value: 2 });
|
|
94
|
+
expect(() => r.getOrThrow('missing')).toThrow(/Not found: "missing"\. Available: a, b/);
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
//# sourceMappingURL=ManagedRegistry.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ManagedRegistry.test.js","sourceRoot":"","sources":["../../src/registry/ManagedRegistry.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Current-code invariants asserted (2026-04-21, ses_006 Phase 3):
|
|
3
|
+
*
|
|
4
|
+
* - `register(id, item)` silently overwrites an existing entry —
|
|
5
|
+
* NO duplicate-error is thrown (Codex #1 verified the design
|
|
6
|
+
* §2.3 "typed DuplicateRegistrationError" claim was fiction).
|
|
7
|
+
* - `get(id)` returns `undefined` for an unknown id (NOT a typed
|
|
8
|
+
* error). `getAll`, `listIds`, `has`, `size` reflect the current
|
|
9
|
+
* `Map` state; iteration order follows insertion order.
|
|
10
|
+
* - `unregister(id)` returns true if the entry existed (and was
|
|
11
|
+
* deleted), false otherwise.
|
|
12
|
+
* - `clear()` empties the map.
|
|
13
|
+
* - The generic `Registry<T>` has no component name, no logger, no
|
|
14
|
+
* lifecycle. All enrichment (logs, idField inference, lifecycle)
|
|
15
|
+
* happens in `ManagedRegistry`, not here.
|
|
16
|
+
*/
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=Registry.test.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Registry.test.d.ts","sourceRoot":"","sources":["../../src/registry/Registry.test.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG"}
|