@ai-setting/roy-agent-core 1.3.9 → 1.3.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/config/index.js +1647 -0
- package/dist/index.js +12579 -89691
- package/package.json +19 -56
- package/src/config/config-component.test.ts +0 -627
- package/src/config/config-component.ts +0 -906
- package/src/config/config-parser.test.ts +0 -319
- package/src/config/config-parser.ts +0 -203
- package/src/config/decentralized-config.test.ts +0 -740
- package/src/config/env-key.ts +0 -210
- package/src/config/env-source.test.ts +0 -252
- package/src/config/env-source.ts +0 -301
- package/src/config/file-source.test.ts +0 -357
- package/src/config/file-source.ts +0 -421
- package/src/config/index.ts +0 -24
- package/src/config/protocol-resolver.test.ts +0 -217
- package/src/config/protocol-resolver.ts +0 -228
- package/src/env/agent/agent-component.abort.test.ts +0 -511
- package/src/env/agent/agent-component.record-session.test.ts +0 -349
- package/src/env/agent/agent-component.test.ts +0 -1389
- package/src/env/agent/agent-component.tool-error.test.ts +0 -327
- package/src/env/agent/agent-component.ts +0 -1711
- package/src/env/agent/agent-config-registration.test.ts +0 -226
- package/src/env/agent/agent-config-registration.ts +0 -46
- package/src/env/agent/agent-reminder-plugin.integration.test.ts +0 -243
- package/src/env/agent/index.ts +0 -10
- package/src/env/agent/summary-agent.parse-hint.test.ts +0 -360
- package/src/env/agent/summary-agent.ts +0 -508
- package/src/env/agent/types.ts +0 -536
- package/src/env/commands/commands-component.test.ts +0 -364
- package/src/env/commands/commands-component.ts +0 -604
- package/src/env/commands/commands-config-registration.test.ts +0 -198
- package/src/env/commands/commands-config-registration.ts +0 -38
- package/src/env/commands/index.ts +0 -21
- package/src/env/commands/parser.test.ts +0 -203
- package/src/env/commands/parser.ts +0 -115
- package/src/env/commands/types.ts +0 -184
- package/src/env/commands-prompt-integration.test.ts +0 -243
- package/src/env/component-env.test.ts +0 -119
- package/src/env/component.ts +0 -335
- package/src/env/constants.test.ts +0 -72
- package/src/env/constants.ts +0 -123
- package/src/env/debug/debug-component.test.ts +0 -114
- package/src/env/debug/debug-component.ts +0 -547
- package/src/env/debug/formatters/index.ts +0 -9
- package/src/env/debug/formatters/repl-formatter.test.ts +0 -139
- package/src/env/debug/formatters/repl-formatter.ts +0 -358
- package/src/env/debug/formatters/trace-formatter.test.ts +0 -119
- package/src/env/debug/formatters/trace-formatter.ts +0 -191
- package/src/env/debug/formatters/tree-formatter.test.ts +0 -107
- package/src/env/debug/formatters/tree-formatter.ts +0 -325
- package/src/env/debug/index.ts +0 -38
- package/src/env/debug/parser/regex-parser.test.ts +0 -201
- package/src/env/debug/parser/regex-parser.ts +0 -196
- package/src/env/debug/parser/span-builder.test.ts +0 -241
- package/src/env/debug/parser/span-builder.ts +0 -386
- package/src/env/debug/reader/log-reader.test.ts +0 -170
- package/src/env/debug/reader/log-reader.ts +0 -186
- package/src/env/debug/reader/span-db-reader.test.ts +0 -118
- package/src/env/debug/reader/span-db-reader.ts +0 -201
- package/src/env/debug/types.test.ts +0 -187
- package/src/env/debug/types.ts +0 -171
- package/src/env/environment-init.test.ts +0 -183
- package/src/env/environment-lifecycle.test.ts +0 -516
- package/src/env/environment-service.test.ts +0 -332
- package/src/env/environment.handle-query.test.ts +0 -96
- package/src/env/environment.test.ts +0 -232
- package/src/env/environment.ts +0 -708
- package/src/env/errors.test.ts +0 -165
- package/src/env/errors.ts +0 -157
- package/src/env/event-source/event-source-agent-handler.test.ts +0 -193
- package/src/env/event-source/event-source-agent-handler.ts +0 -111
- package/src/env/event-source/event-source-component.process-cleanup.test.ts +0 -236
- package/src/env/event-source/event-source-component.stop.test.ts +0 -346
- package/src/env/event-source/event-source-component.test.ts +0 -1207
- package/src/env/event-source/event-source-component.ts +0 -1379
- package/src/env/event-source/event-source-config-registration.test.ts +0 -242
- package/src/env/event-source/event-source-config-registration.ts +0 -37
- package/src/env/event-source/event-source-integration.test.ts +0 -320
- package/src/env/event-source/event-source-platform.test.ts +0 -630
- package/src/env/event-source/types.ts +0 -298
- package/src/env/hook/global-hook-manager.ts +0 -162
- package/src/env/hook/hook-manager.test.ts +0 -374
- package/src/env/hook/hook-manager.ts +0 -309
- package/src/env/hook/index.ts +0 -38
- package/src/env/hook/types.ts +0 -138
- package/src/env/index.ts +0 -144
- package/src/env/interface.ts +0 -203
- package/src/env/llm/hooks.test.ts +0 -293
- package/src/env/llm/hooks.ts +0 -316
- package/src/env/llm/index.ts +0 -61
- package/src/env/llm/invoke-threshold-check.test.ts +0 -88
- package/src/env/llm/invoke-timeout.test.ts +0 -54
- package/src/env/llm/invoke.test.ts +0 -71
- package/src/env/llm/invoke.ts +0 -1039
- package/src/env/llm/llm-config.test.ts +0 -523
- package/src/env/llm/llm.test.ts +0 -233
- package/src/env/llm/llm.ts +0 -568
- package/src/env/llm/provider.test.ts +0 -182
- package/src/env/llm/provider.ts +0 -108
- package/src/env/llm/transform.test.ts +0 -251
- package/src/env/llm/transform.ts +0 -286
- package/src/env/llm/types.test.ts +0 -580
- package/src/env/llm/types.ts +0 -424
- package/src/env/log-trace/decorator-otel.test.ts +0 -182
- package/src/env/log-trace/decorator.ts +0 -230
- package/src/env/log-trace/index.ts +0 -79
- package/src/env/log-trace/log-trace-component.test.ts +0 -242
- package/src/env/log-trace/log-trace-component.ts +0 -497
- package/src/env/log-trace/log-trace-config-registration.test.ts +0 -348
- package/src/env/log-trace/log-trace-config-registration.ts +0 -45
- package/src/env/log-trace/logger.test.ts +0 -149
- package/src/env/log-trace/logger.ts +0 -522
- package/src/env/log-trace/opentelemetry/cli-propagation.test.ts +0 -147
- package/src/env/log-trace/opentelemetry/cli-propagation.ts +0 -194
- package/src/env/log-trace/opentelemetry/integration.test.ts +0 -668
- package/src/env/log-trace/opentelemetry/mod.ts +0 -25
- package/src/env/log-trace/opentelemetry/propagation-env.test.ts +0 -181
- package/src/env/log-trace/opentelemetry/propagation-env.ts +0 -136
- package/src/env/log-trace/opentelemetry/propagation.test.ts +0 -259
- package/src/env/log-trace/opentelemetry/propagation.ts +0 -215
- package/src/env/log-trace/opentelemetry/tracer-provider-context.test.ts +0 -166
- package/src/env/log-trace/opentelemetry/tracer-provider.test.ts +0 -379
- package/src/env/log-trace/opentelemetry/tracer-provider.ts +0 -612
- package/src/env/log-trace/span-storage.test.ts +0 -145
- package/src/env/log-trace/span-storage.ts +0 -230
- package/src/env/log-trace/trace-context.test.ts +0 -187
- package/src/env/log-trace/trace-context.ts +0 -162
- package/src/env/log-trace/types.test.ts +0 -63
- package/src/env/log-trace/types.ts +0 -172
- package/src/env/mcp/README.md +0 -244
- package/src/env/mcp/__integration__/mcp-component.integration.test.ts +0 -373
- package/src/env/mcp/config.test.ts +0 -74
- package/src/env/mcp/config.ts +0 -116
- package/src/env/mcp/index.ts +0 -41
- package/src/env/mcp/loader.test.ts +0 -161
- package/src/env/mcp/loader.ts +0 -209
- package/src/env/mcp/mcp-component.test.ts +0 -111
- package/src/env/mcp/mcp-component.ts +0 -358
- package/src/env/mcp/mcp-config-registration.test.ts +0 -304
- package/src/env/mcp/mcp-config-registration.ts +0 -50
- package/src/env/mcp/scanner.test.ts +0 -170
- package/src/env/mcp/scanner.ts +0 -246
- package/src/env/mcp/tool/adapter.test.ts +0 -520
- package/src/env/mcp/tool/adapter.ts +0 -521
- package/src/env/mcp/tool/index.ts +0 -5
- package/src/env/mcp/types.test.ts +0 -171
- package/src/env/mcp/types.ts +0 -79
- package/src/env/memory/README.md +0 -177
- package/src/env/memory/built-in/index.ts +0 -59
- package/src/env/memory/built-in/recall-memory.ts +0 -103
- package/src/env/memory/built-in/record-memory.ts +0 -148
- package/src/env/memory/index.ts +0 -20
- package/src/env/memory/memory-component.test.ts +0 -239
- package/src/env/memory/memory-component.ts +0 -503
- package/src/env/memory/memory-config-registration.test.ts +0 -67
- package/src/env/memory/memory-config-registration.ts +0 -48
- package/src/env/memory/memory-config.ts +0 -45
- package/src/env/memory/memory-file.test.ts +0 -268
- package/src/env/memory/plugin/index.ts +0 -48
- package/src/env/memory/plugin/memory-agent.test.ts +0 -249
- package/src/env/memory/plugin/memory-agent.ts +0 -365
- package/src/env/memory/plugin/memory-manager.ts +0 -198
- package/src/env/memory/plugin/memory-plugin-agent.test.ts +0 -145
- package/src/env/memory/plugin/memory-plugin.ts +0 -210
- package/src/env/memory/plugin/plugin-simplified.test.ts +0 -51
- package/src/env/memory/plugin/recall-memory.test.ts +0 -106
- package/src/env/memory/plugin/recall-memory.ts +0 -53
- package/src/env/memory/plugin/types.ts +0 -101
- package/src/env/memory/tools/memory-agent-tools.ts +0 -228
- package/src/env/memory/types.ts +0 -85
- package/src/env/paths.ts +0 -118
- package/src/env/prompt/index.ts +0 -18
- package/src/env/prompt/memory-prompts.test.ts +0 -91
- package/src/env/prompt/prompt-component.test.ts +0 -491
- package/src/env/prompt/prompt-component.ts +0 -619
- package/src/env/prompt/prompt-config-registration.test.ts +0 -213
- package/src/env/prompt/prompt-config-registration.ts +0 -39
- package/src/env/prompt/prompts-index.ts +0 -504
- package/src/env/prompt/renderer.ts +0 -67
- package/src/env/prompt/types.ts +0 -136
- package/src/env/session/hooks.ts +0 -18
- package/src/env/session/index.ts +0 -37
- package/src/env/session/search-query-parser.test.ts +0 -425
- package/src/env/session/search-query-parser.ts +0 -171
- package/src/env/session/session-checkpoint.test.ts +0 -523
- package/src/env/session/session-component.extract-recent-messages.test.ts +0 -209
- package/src/env/session/session-component.test.ts +0 -132
- package/src/env/session/session-component.ts +0 -1249
- package/src/env/session/session-config-registration.test.ts +0 -138
- package/src/env/session/session-config-registration.ts +0 -52
- package/src/env/session/session-message-converter.test.ts +0 -763
- package/src/env/session/session-message-converter.ts +0 -415
- package/src/env/session/session-message-e2e.test.ts +0 -448
- package/src/env/session/session-search.test.ts +0 -391
- package/src/env/session/session-store.test.ts +0 -362
- package/src/env/session/session-store.ts +0 -141
- package/src/env/session/storage/index.ts +0 -6
- package/src/env/session/storage/memory.ts +0 -502
- package/src/env/session/storage/sqlite.ts +0 -794
- package/src/env/session/types.ts +0 -742
- package/src/env/skill/config.ts +0 -39
- package/src/env/skill/index.ts +0 -6
- package/src/env/skill/parser.test.ts +0 -116
- package/src/env/skill/parser.ts +0 -77
- package/src/env/skill/scanner.test.ts +0 -211
- package/src/env/skill/scanner.ts +0 -119
- package/src/env/skill/skill-component.test.ts +0 -234
- package/src/env/skill/skill-component.ts +0 -352
- package/src/env/skill/skill-config-registration.test.ts +0 -60
- package/src/env/skill/skill-config-registration.ts +0 -43
- package/src/env/skill/tool/index.ts +0 -1
- package/src/env/skill/tool/skill-tool.test.ts +0 -100
- package/src/env/skill/tool/skill-tool.ts +0 -72
- package/src/env/skill/types.ts +0 -64
- package/src/env/task/delegate/delegate-tool.test.ts +0 -498
- package/src/env/task/delegate/delegate-tool.ts +0 -1014
- package/src/env/task/delegate/index.ts +0 -18
- package/src/env/task/delegate/stop-tool.test.ts +0 -140
- package/src/env/task/delegate/stop-tool.ts +0 -119
- package/src/env/task/delegate/task-events.test.ts +0 -178
- package/src/env/task/delegate/task-events.ts +0 -143
- package/src/env/task/hooks/contexts.test.ts +0 -92
- package/src/env/task/hooks/contexts.ts +0 -192
- package/src/env/task/hooks/index.ts +0 -23
- package/src/env/task/hooks/task-hook-points.test.ts +0 -32
- package/src/env/task/hooks/task-hook-points.ts +0 -54
- package/src/env/task/index.ts +0 -7
- package/src/env/task/plugins/index.ts +0 -13
- package/src/env/task/plugins/task-plugin.test.ts +0 -74
- package/src/env/task/plugins/task-plugin.ts +0 -89
- package/src/env/task/plugins/task-tag-plugin.test.ts +0 -377
- package/src/env/task/plugins/task-tag-plugin.ts +0 -319
- package/src/env/task/plugins/task-workflow-extractor.integration.test.ts +0 -226
- package/src/env/task/plugins/workflow-extractor-agent.test.ts +0 -107
- package/src/env/task/plugins/workflow-extractor-agent.ts +0 -225
- package/src/env/task/storage/index.ts +0 -6
- package/src/env/task/storage/sqlite-task-store.test.ts +0 -283
- package/src/env/task/storage/sqlite-task-store.ts +0 -903
- package/src/env/task/storage/task-search.test.ts +0 -291
- package/src/env/task/tag-service.test.ts +0 -198
- package/src/env/task/tag-service.ts +0 -264
- package/src/env/task/task-component.test.ts +0 -193
- package/src/env/task/task-component.ts +0 -658
- package/src/env/task/task-config-registration.test.ts +0 -57
- package/src/env/task/task-config-registration.ts +0 -37
- package/src/env/task/task-types.test.ts +0 -137
- package/src/env/task/tools/complete-tool.ts +0 -44
- package/src/env/task/tools/create-tool.ts +0 -49
- package/src/env/task/tools/delete-tool.ts +0 -43
- package/src/env/task/tools/get-tool.ts +0 -59
- package/src/env/task/tools/index.ts +0 -10
- package/src/env/task/tools/list-tool.ts +0 -40
- package/src/env/task/tools/operation/create-tool.ts +0 -48
- package/src/env/task/tools/operation/delete-tool.ts +0 -43
- package/src/env/task/tools/operation/get-tool.ts +0 -43
- package/src/env/task/tools/operation/index.ts +0 -9
- package/src/env/task/tools/operation/list-tool.ts +0 -40
- package/src/env/task/tools/operation/operation-tools.test.ts +0 -274
- package/src/env/task/tools/operation/operation-types.ts +0 -75
- package/src/env/task/tools/operation/update-tool.ts +0 -47
- package/src/env/task/tools/task-tools.test.ts +0 -203
- package/src/env/task/tools/task-types.test.ts +0 -75
- package/src/env/task/tools/task-types.ts +0 -68
- package/src/env/task/tools/update-tool.ts +0 -70
- package/src/env/task/types.ts +0 -160
- package/src/env/tool/built-in/bash.ts +0 -201
- package/src/env/tool/built-in/echo.ts +0 -29
- package/src/env/tool/built-in/edit-file.test.ts +0 -136
- package/src/env/tool/built-in/edit-file.ts +0 -92
- package/src/env/tool/built-in/glob.test.ts +0 -94
- package/src/env/tool/built-in/glob.ts +0 -65
- package/src/env/tool/built-in/grep.test.ts +0 -122
- package/src/env/tool/built-in/grep.ts +0 -108
- package/src/env/tool/built-in/index.ts +0 -44
- package/src/env/tool/built-in/read-file.test.ts +0 -84
- package/src/env/tool/built-in/read-file.ts +0 -75
- package/src/env/tool/built-in/write-file.test.ts +0 -119
- package/src/env/tool/built-in/write-file.ts +0 -68
- package/src/env/tool/index.ts +0 -24
- package/src/env/tool/registry.test.ts +0 -257
- package/src/env/tool/registry.ts +0 -167
- package/src/env/tool/tool-component.test.ts +0 -559
- package/src/env/tool/tool-component.ts +0 -563
- package/src/env/tool/tool-config-registration.test.ts +0 -249
- package/src/env/tool/tool-config-registration.ts +0 -46
- package/src/env/tool/types.ts +0 -267
- package/src/env/tool/validator.test.ts +0 -143
- package/src/env/tool/validator.ts +0 -44
- package/src/env/types.ts +0 -180
- package/src/env/workflow/ask-user-tool-registration.test.ts +0 -216
- package/src/env/workflow/complex-workflow.integration.test.ts +0 -1900
- package/src/env/workflow/decorators/decorator-node.ts +0 -229
- package/src/env/workflow/decorators/decorator.test.ts +0 -196
- package/src/env/workflow/decorators/edge.ts +0 -82
- package/src/env/workflow/decorators/index.ts +0 -31
- package/src/env/workflow/decorators/node-as.ts +0 -98
- package/src/env/workflow/decorators/workflow.ts +0 -54
- package/src/env/workflow/engine/dag-manager.test.ts +0 -570
- package/src/env/workflow/engine/dag-manager.ts +0 -594
- package/src/env/workflow/engine/engine.ts +0 -1422
- package/src/env/workflow/engine/event-bus.test.ts +0 -359
- package/src/env/workflow/engine/event-bus.ts +0 -156
- package/src/env/workflow/engine/executor-agent-session.test.ts +0 -84
- package/src/env/workflow/engine/executor.test.ts +0 -619
- package/src/env/workflow/engine/executor.ts +0 -593
- package/src/env/workflow/engine/index.ts +0 -24
- package/src/env/workflow/engine/node-registry.test.ts +0 -560
- package/src/env/workflow/engine/node-registry.ts +0 -289
- package/src/env/workflow/engine/resume-removed.test.ts +0 -22
- package/src/env/workflow/engine/scheduler.test.ts +0 -715
- package/src/env/workflow/engine/scheduler.ts +0 -318
- package/src/env/workflow/engine/workflow-engine.test.ts +0 -815
- package/src/env/workflow/extractor/workflow-converter.ts +0 -306
- package/src/env/workflow/fixtures.ts +0 -380
- package/src/env/workflow/index.ts +0 -38
- package/src/env/workflow/integration/run-resume-unified.test.ts +0 -186
- package/src/env/workflow/integration/service-integration.test.ts +0 -267
- package/src/env/workflow/metadata/keys.ts +0 -12
- package/src/env/workflow/nodes/agent-component-adapter.test.ts +0 -318
- package/src/env/workflow/nodes/agent-component-adapter.ts +0 -448
- package/src/env/workflow/nodes/agent-node.test.ts +0 -371
- package/src/env/workflow/nodes/agent-node.ts +0 -598
- package/src/env/workflow/nodes/ask-user-node.ts +0 -113
- package/src/env/workflow/nodes/condition-node.ts +0 -200
- package/src/env/workflow/nodes/index.ts +0 -9
- package/src/env/workflow/nodes/merge-node.ts +0 -141
- package/src/env/workflow/nodes/skill-node.test.ts +0 -253
- package/src/env/workflow/nodes/skill-node.ts +0 -393
- package/src/env/workflow/nodes/tool-node.test.ts +0 -251
- package/src/env/workflow/nodes/tool-node.ts +0 -493
- package/src/env/workflow/nodes/workflow-llm-history.test.ts +0 -455
- package/src/env/workflow/nodes/workflow-node.test.ts +0 -315
- package/src/env/workflow/nodes/workflow-node.ts +0 -311
- package/src/env/workflow/service/index.ts +0 -27
- package/src/env/workflow/service/registry.test.ts +0 -133
- package/src/env/workflow/service/registry.ts +0 -71
- package/src/env/workflow/service/workflow-service.test.ts +0 -310
- package/src/env/workflow/service/workflow-service.ts +0 -393
- package/src/env/workflow/storage/index.ts +0 -28
- package/src/env/workflow/storage/mock-repositories.ts +0 -385
- package/src/env/workflow/storage/sqlite.test.ts +0 -179
- package/src/env/workflow/storage/sqlite.ts +0 -163
- package/src/env/workflow/storage/workflow-repo.test.ts +0 -780
- package/src/env/workflow/storage/workflow-repo.ts +0 -342
- package/src/env/workflow/tools/ask-user-tool.ts +0 -82
- package/src/env/workflow/tools/index.ts +0 -26
- package/src/env/workflow/tools/run-workflow.test.ts +0 -352
- package/src/env/workflow/tools/run-workflow.ts +0 -214
- package/src/env/workflow/types/context.ts +0 -18
- package/src/env/workflow/types/decorators-types.ts +0 -198
- package/src/env/workflow/types/event.test.ts +0 -515
- package/src/env/workflow/types/event.ts +0 -193
- package/src/env/workflow/types/index.ts +0 -49
- package/src/env/workflow/types/run.test.ts +0 -437
- package/src/env/workflow/types/run.ts +0 -173
- package/src/env/workflow/types/workflow-hil.ts +0 -114
- package/src/env/workflow/types/workflow-message.test.ts +0 -138
- package/src/env/workflow/types/workflow-message.ts +0 -196
- package/src/env/workflow/types/workflow-session.test.ts +0 -95
- package/src/env/workflow/types/workflow-session.ts +0 -59
- package/src/env/workflow/types/workflow.test.ts +0 -495
- package/src/env/workflow/types/workflow.ts +0 -195
- package/src/env/workflow/types_compat.ts +0 -51
- package/src/env/workflow/utils/create-workflow.ts +0 -47
- package/src/env/workflow/utils/execution-state.ts +0 -245
- package/src/env/workflow/utils/index.ts +0 -18
- package/src/env/workflow/utils/node-registry-helper.ts +0 -58
- package/src/env/workflow/utils/recovery-validator.test.ts +0 -460
- package/src/env/workflow/utils/recovery-validator.ts +0 -377
- package/src/env/workflow/utils/session-parser.test.ts +0 -111
- package/src/env/workflow/utils/session-parser.ts +0 -94
- package/src/env/workflow/utils/session-recovery.test.ts +0 -334
- package/src/env/workflow/utils/session-recovery.ts +0 -188
- package/src/env/workflow/utils/template-resolver.test.ts +0 -258
- package/src/env/workflow/utils/template-resolver.ts +0 -436
- package/src/env/workflow/utils/validation-rules.ts +0 -149
- package/src/env/workflow/workflow-component.ts +0 -544
- package/src/index.ts +0 -422
- package/src/utils/id.ts +0 -21
|
@@ -1,359 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach, vi } from 'vitest';
|
|
2
|
-
import { EventBus } from './event-bus';
|
|
3
|
-
import type { WorkflowEvent } from '../types/event';
|
|
4
|
-
|
|
5
|
-
// Helper to create test events
|
|
6
|
-
function createTestEvent(type: WorkflowEvent['type'], runId = 'run_123') {
|
|
7
|
-
return {
|
|
8
|
-
type,
|
|
9
|
-
run_id: runId,
|
|
10
|
-
timestamp: Date.now(),
|
|
11
|
-
} as WorkflowEvent;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
describe('EventBus', () => {
|
|
15
|
-
let eventBus: EventBus;
|
|
16
|
-
|
|
17
|
-
beforeEach(() => {
|
|
18
|
-
eventBus = new EventBus();
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
describe('on() - Subscribe to specific event type', () => {
|
|
22
|
-
it('should subscribe to a specific event type and receive events', async () => {
|
|
23
|
-
const handler = vi.fn();
|
|
24
|
-
const unsubscribe = eventBus.on('workflow.started', handler);
|
|
25
|
-
|
|
26
|
-
const event = createTestEvent('workflow.started');
|
|
27
|
-
await eventBus.publish(event);
|
|
28
|
-
|
|
29
|
-
expect(handler).toHaveBeenCalledTimes(1);
|
|
30
|
-
expect(handler).toHaveBeenCalledWith(event);
|
|
31
|
-
unsubscribe();
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
it('should support multiple handlers for the same event type', async () => {
|
|
35
|
-
const handler1 = vi.fn();
|
|
36
|
-
const handler2 = vi.fn();
|
|
37
|
-
|
|
38
|
-
eventBus.on('workflow.started', handler1);
|
|
39
|
-
eventBus.on('workflow.started', handler2);
|
|
40
|
-
|
|
41
|
-
const event = createTestEvent('workflow.started');
|
|
42
|
-
await eventBus.publish(event);
|
|
43
|
-
|
|
44
|
-
expect(handler1).toHaveBeenCalledTimes(1);
|
|
45
|
-
expect(handler2).toHaveBeenCalledTimes(1);
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
it('should not receive events after unsubscribe', async () => {
|
|
49
|
-
const handler = vi.fn();
|
|
50
|
-
const unsubscribe = eventBus.on('workflow.started', handler);
|
|
51
|
-
|
|
52
|
-
const event1 = createTestEvent('workflow.started');
|
|
53
|
-
await eventBus.publish(event1);
|
|
54
|
-
expect(handler).toHaveBeenCalledTimes(1);
|
|
55
|
-
|
|
56
|
-
unsubscribe();
|
|
57
|
-
|
|
58
|
-
const event2 = createTestEvent('workflow.started');
|
|
59
|
-
await eventBus.publish(event2);
|
|
60
|
-
expect(handler).toHaveBeenCalledTimes(1); // Should not increase
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it('should return unsubscribe function from on()', () => {
|
|
64
|
-
const handler = vi.fn();
|
|
65
|
-
const unsubscribe = eventBus.on('workflow.started', handler);
|
|
66
|
-
|
|
67
|
-
expect(typeof unsubscribe).toBe('function');
|
|
68
|
-
unsubscribe();
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
describe('once() - Subscribe once (auto-unsubscribe)', () => {
|
|
73
|
-
it('should only call handler once and then auto-unsubscribe', async () => {
|
|
74
|
-
const handler = vi.fn();
|
|
75
|
-
eventBus.once('workflow.started', handler);
|
|
76
|
-
|
|
77
|
-
const event1 = createTestEvent('workflow.started');
|
|
78
|
-
const event2 = createTestEvent('workflow.started');
|
|
79
|
-
|
|
80
|
-
await eventBus.publish(event1);
|
|
81
|
-
await eventBus.publish(event2);
|
|
82
|
-
|
|
83
|
-
expect(handler).toHaveBeenCalledTimes(1);
|
|
84
|
-
expect(handler).toHaveBeenCalledWith(event1);
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
it('should return unsubscribe function from once()', () => {
|
|
88
|
-
const handler = vi.fn();
|
|
89
|
-
const unsubscribe = eventBus.once('workflow.started', handler);
|
|
90
|
-
|
|
91
|
-
expect(typeof unsubscribe).toBe('function');
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('should handle multiple once() subscriptions independently', async () => {
|
|
95
|
-
const handler1 = vi.fn();
|
|
96
|
-
const handler2 = vi.fn();
|
|
97
|
-
|
|
98
|
-
eventBus.once('workflow.started', handler1);
|
|
99
|
-
eventBus.once('workflow.started', handler2);
|
|
100
|
-
|
|
101
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
102
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
103
|
-
|
|
104
|
-
expect(handler1).toHaveBeenCalledTimes(1);
|
|
105
|
-
expect(handler2).toHaveBeenCalledTimes(1);
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
describe('off() - Unsubscribe', () => {
|
|
110
|
-
it('should remove handler when off() is called', async () => {
|
|
111
|
-
const handler = vi.fn();
|
|
112
|
-
eventBus.on('workflow.started', handler);
|
|
113
|
-
eventBus.off('workflow.started', handler);
|
|
114
|
-
|
|
115
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
116
|
-
|
|
117
|
-
expect(handler).not.toHaveBeenCalled();
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
it('should only remove the specified handler', async () => {
|
|
121
|
-
const handler1 = vi.fn();
|
|
122
|
-
const handler2 = vi.fn();
|
|
123
|
-
|
|
124
|
-
eventBus.on('workflow.started', handler1);
|
|
125
|
-
eventBus.on('workflow.started', handler2);
|
|
126
|
-
eventBus.off('workflow.started', handler1);
|
|
127
|
-
|
|
128
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
129
|
-
|
|
130
|
-
expect(handler1).not.toHaveBeenCalled();
|
|
131
|
-
expect(handler2).toHaveBeenCalledTimes(1);
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
it('should handle off() for non-existent handler gracefully', () => {
|
|
135
|
-
const handler = vi.fn();
|
|
136
|
-
// Should not throw
|
|
137
|
-
expect(() => eventBus.off('workflow.started', handler)).not.toThrow();
|
|
138
|
-
});
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
describe('onAny() - Wildcard subscriptions', () => {
|
|
142
|
-
it('should receive all events when using onAny()', async () => {
|
|
143
|
-
const handler = vi.fn();
|
|
144
|
-
|
|
145
|
-
eventBus.onAny(handler);
|
|
146
|
-
|
|
147
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
148
|
-
await eventBus.publish(createTestEvent('workflow.completed'));
|
|
149
|
-
await eventBus.publish(createTestEvent('node.started'));
|
|
150
|
-
|
|
151
|
-
expect(handler).toHaveBeenCalledTimes(3);
|
|
152
|
-
});
|
|
153
|
-
|
|
154
|
-
it('should return unsubscribe function from onAny()', () => {
|
|
155
|
-
const handler = vi.fn();
|
|
156
|
-
const unsubscribe = eventBus.onAny(handler);
|
|
157
|
-
|
|
158
|
-
expect(typeof unsubscribe).toBe('function');
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
it('should not receive events after unsubscribe', async () => {
|
|
162
|
-
const handler = vi.fn();
|
|
163
|
-
const unsubscribe = eventBus.onAny(handler);
|
|
164
|
-
|
|
165
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
166
|
-
unsubscribe();
|
|
167
|
-
await eventBus.publish(createTestEvent('workflow.completed'));
|
|
168
|
-
|
|
169
|
-
expect(handler).toHaveBeenCalledTimes(1);
|
|
170
|
-
});
|
|
171
|
-
|
|
172
|
-
it('should work together with specific event subscriptions', async () => {
|
|
173
|
-
const anyHandler = vi.fn();
|
|
174
|
-
const specificHandler = vi.fn();
|
|
175
|
-
|
|
176
|
-
eventBus.onAny(anyHandler);
|
|
177
|
-
eventBus.on('workflow.started', specificHandler);
|
|
178
|
-
|
|
179
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
180
|
-
await eventBus.publish(createTestEvent('workflow.completed'));
|
|
181
|
-
|
|
182
|
-
expect(anyHandler).toHaveBeenCalledTimes(2);
|
|
183
|
-
expect(specificHandler).toHaveBeenCalledTimes(1);
|
|
184
|
-
});
|
|
185
|
-
});
|
|
186
|
-
|
|
187
|
-
describe('publish() - Publish events to subscribers', () => {
|
|
188
|
-
it('should publish event to all matching subscribers', async () => {
|
|
189
|
-
const handler1 = vi.fn();
|
|
190
|
-
const handler2 = vi.fn();
|
|
191
|
-
|
|
192
|
-
eventBus.on('workflow.started', handler1);
|
|
193
|
-
eventBus.on('workflow.started', handler2);
|
|
194
|
-
|
|
195
|
-
const event = createTestEvent('workflow.started');
|
|
196
|
-
await eventBus.publish(event);
|
|
197
|
-
|
|
198
|
-
expect(handler1).toHaveBeenCalledWith(event);
|
|
199
|
-
expect(handler2).toHaveBeenCalledWith(event);
|
|
200
|
-
});
|
|
201
|
-
|
|
202
|
-
it('should handle async handlers', async () => {
|
|
203
|
-
const handler = vi.fn().mockImplementation(async () => {
|
|
204
|
-
await new Promise((resolve) => setTimeout(resolve, 10));
|
|
205
|
-
});
|
|
206
|
-
|
|
207
|
-
eventBus.on('workflow.started', handler);
|
|
208
|
-
|
|
209
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
210
|
-
|
|
211
|
-
expect(handler).toHaveBeenCalled();
|
|
212
|
-
});
|
|
213
|
-
|
|
214
|
-
it('should not block publish when handlers are async', async () => {
|
|
215
|
-
const handler = vi.fn().mockImplementation(async () => {
|
|
216
|
-
await new Promise((resolve) => setTimeout(resolve, 50));
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
eventBus.on('workflow.started', handler);
|
|
220
|
-
|
|
221
|
-
const start = Date.now();
|
|
222
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
223
|
-
const duration = Date.now() - start;
|
|
224
|
-
|
|
225
|
-
// publish should not wait for handler to complete
|
|
226
|
-
expect(duration).toBeLessThan(40);
|
|
227
|
-
});
|
|
228
|
-
});
|
|
229
|
-
|
|
230
|
-
describe('Error handling in handlers', () => {
|
|
231
|
-
it('should not crash the bus when a handler throws', async () => {
|
|
232
|
-
const errorHandler = vi.fn().mockImplementation(() => {
|
|
233
|
-
throw new Error('Handler error');
|
|
234
|
-
});
|
|
235
|
-
const normalHandler = vi.fn();
|
|
236
|
-
|
|
237
|
-
eventBus.on('workflow.started', errorHandler);
|
|
238
|
-
eventBus.on('workflow.started', normalHandler);
|
|
239
|
-
|
|
240
|
-
// Should not throw - the publish method should catch errors internally
|
|
241
|
-
let threw = false;
|
|
242
|
-
try {
|
|
243
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
244
|
-
} catch {
|
|
245
|
-
threw = true;
|
|
246
|
-
}
|
|
247
|
-
expect(threw).toBe(false);
|
|
248
|
-
expect(normalHandler).toHaveBeenCalled();
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
it('should not crash the bus when a handler rejects', async () => {
|
|
252
|
-
const errorHandler = vi.fn().mockImplementation(async () => {
|
|
253
|
-
throw new Error('Async handler error');
|
|
254
|
-
});
|
|
255
|
-
const normalHandler = vi.fn();
|
|
256
|
-
|
|
257
|
-
eventBus.on('workflow.started', errorHandler);
|
|
258
|
-
eventBus.on('workflow.started', normalHandler);
|
|
259
|
-
|
|
260
|
-
// Should not throw - the publish method should catch errors internally
|
|
261
|
-
let threw = false;
|
|
262
|
-
try {
|
|
263
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
264
|
-
// Wait a bit for async handlers to potentially throw
|
|
265
|
-
await new Promise(resolve => setTimeout(resolve, 20));
|
|
266
|
-
} catch {
|
|
267
|
-
threw = true;
|
|
268
|
-
}
|
|
269
|
-
expect(threw).toBe(false);
|
|
270
|
-
expect(normalHandler).toHaveBeenCalled();
|
|
271
|
-
});
|
|
272
|
-
|
|
273
|
-
it('should continue to other handlers after one fails', async () => {
|
|
274
|
-
const errorHandler = vi.fn().mockImplementation(() => {
|
|
275
|
-
throw new Error('Handler error');
|
|
276
|
-
});
|
|
277
|
-
const normalHandler = vi.fn();
|
|
278
|
-
|
|
279
|
-
eventBus.on('workflow.started', errorHandler);
|
|
280
|
-
eventBus.on('workflow.started', normalHandler);
|
|
281
|
-
|
|
282
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
283
|
-
|
|
284
|
-
expect(errorHandler).toHaveBeenCalled();
|
|
285
|
-
expect(normalHandler).toHaveBeenCalled();
|
|
286
|
-
});
|
|
287
|
-
});
|
|
288
|
-
|
|
289
|
-
describe('clear() - Clear all subscriptions', () => {
|
|
290
|
-
it('should remove all handlers when clear() is called', async () => {
|
|
291
|
-
const handler1 = vi.fn();
|
|
292
|
-
const handler2 = vi.fn();
|
|
293
|
-
const wildcardHandler = vi.fn();
|
|
294
|
-
|
|
295
|
-
eventBus.on('workflow.started', handler1);
|
|
296
|
-
eventBus.on('workflow.completed', handler2);
|
|
297
|
-
eventBus.onAny(wildcardHandler);
|
|
298
|
-
|
|
299
|
-
eventBus.clear();
|
|
300
|
-
|
|
301
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
302
|
-
await eventBus.publish(createTestEvent('workflow.completed'));
|
|
303
|
-
|
|
304
|
-
expect(handler1).not.toHaveBeenCalled();
|
|
305
|
-
expect(handler2).not.toHaveBeenCalled();
|
|
306
|
-
expect(wildcardHandler).not.toHaveBeenCalled();
|
|
307
|
-
});
|
|
308
|
-
|
|
309
|
-
it('should allow new subscriptions after clear()', async () => {
|
|
310
|
-
const oldHandler = vi.fn();
|
|
311
|
-
const newHandler = vi.fn();
|
|
312
|
-
|
|
313
|
-
eventBus.on('workflow.started', oldHandler);
|
|
314
|
-
eventBus.clear();
|
|
315
|
-
eventBus.on('workflow.started', newHandler);
|
|
316
|
-
|
|
317
|
-
await eventBus.publish(createTestEvent('workflow.started'));
|
|
318
|
-
|
|
319
|
-
expect(oldHandler).not.toHaveBeenCalled();
|
|
320
|
-
expect(newHandler).toHaveBeenCalledTimes(1);
|
|
321
|
-
});
|
|
322
|
-
});
|
|
323
|
-
|
|
324
|
-
describe('getStats() - Get statistics', () => {
|
|
325
|
-
it('should return correct stats after subscriptions', () => {
|
|
326
|
-
eventBus.on('workflow.started', vi.fn());
|
|
327
|
-
eventBus.on('workflow.started', vi.fn());
|
|
328
|
-
eventBus.on('workflow.completed', vi.fn());
|
|
329
|
-
eventBus.onAny(vi.fn());
|
|
330
|
-
|
|
331
|
-
const stats = eventBus.getStats();
|
|
332
|
-
|
|
333
|
-
expect(stats.eventTypes).toBe(2); // workflow.started and workflow.completed
|
|
334
|
-
expect(stats.wildcardHandlers).toBe(1);
|
|
335
|
-
expect(stats.totalHandlers).toBe(4); // 3 specific + 1 wildcard
|
|
336
|
-
});
|
|
337
|
-
|
|
338
|
-
it('should return zero stats for new EventBus', () => {
|
|
339
|
-
const stats = eventBus.getStats();
|
|
340
|
-
|
|
341
|
-
expect(stats.eventTypes).toBe(0);
|
|
342
|
-
expect(stats.wildcardHandlers).toBe(0);
|
|
343
|
-
expect(stats.totalHandlers).toBe(0);
|
|
344
|
-
});
|
|
345
|
-
|
|
346
|
-
it('should update stats after clearing', () => {
|
|
347
|
-
eventBus.on('workflow.started', vi.fn());
|
|
348
|
-
eventBus.onAny(vi.fn());
|
|
349
|
-
|
|
350
|
-
eventBus.clear();
|
|
351
|
-
|
|
352
|
-
const stats = eventBus.getStats();
|
|
353
|
-
|
|
354
|
-
expect(stats.eventTypes).toBe(0);
|
|
355
|
-
expect(stats.wildcardHandlers).toBe(0);
|
|
356
|
-
expect(stats.totalHandlers).toBe(0);
|
|
357
|
-
});
|
|
358
|
-
});
|
|
359
|
-
});
|
|
@@ -1,156 +0,0 @@
|
|
|
1
|
-
import type { WorkflowEvent } from '../types/event';
|
|
2
|
-
|
|
3
|
-
export type EventHandler = (event: WorkflowEvent) => void | Promise<void>;
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* EventBus for workflow events.
|
|
7
|
-
* Custom event bus implementation with support for wildcard subscriptions.
|
|
8
|
-
*/
|
|
9
|
-
export class EventBus {
|
|
10
|
-
private handlers: Map<string, Set<EventHandler>> = new Map();
|
|
11
|
-
private wildcardHandlers: Set<EventHandler> = new Set();
|
|
12
|
-
|
|
13
|
-
constructor() {
|
|
14
|
-
// No-op - keep for potential future use
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Subscribe to a specific event type.
|
|
19
|
-
* @returns Unsubscribe function
|
|
20
|
-
*/
|
|
21
|
-
on(eventType: string, handler: EventHandler): () => void {
|
|
22
|
-
let handlers = this.handlers.get(eventType);
|
|
23
|
-
if (!handlers) {
|
|
24
|
-
handlers = new Set();
|
|
25
|
-
this.handlers.set(eventType, handlers);
|
|
26
|
-
}
|
|
27
|
-
handlers.add(handler);
|
|
28
|
-
return () => this.off(eventType, handler);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Subscribe to an event type only once (auto-unsubscribe after first call).
|
|
33
|
-
* @returns Unsubscribe function
|
|
34
|
-
*/
|
|
35
|
-
once(eventType: string, handler: EventHandler): () => void {
|
|
36
|
-
// Use a flag to track if handler has been executed
|
|
37
|
-
let executed = false;
|
|
38
|
-
|
|
39
|
-
const wrappedHandler: EventHandler = async (event) => {
|
|
40
|
-
// Skip if already executed (prevent double execution)
|
|
41
|
-
if (executed) {
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
executed = true;
|
|
45
|
-
|
|
46
|
-
// Execute the original handler
|
|
47
|
-
try {
|
|
48
|
-
await handler(event);
|
|
49
|
-
} catch (error) {
|
|
50
|
-
// Silently catch handler errors
|
|
51
|
-
console.error('Event handler error:', error);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
// Then unsubscribe
|
|
55
|
-
this.off(eventType, wrappedHandler);
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
// Subscribe the wrapped handler
|
|
59
|
-
return this.on(eventType, wrappedHandler);
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
/**
|
|
63
|
-
* Unsubscribe from an event type.
|
|
64
|
-
*/
|
|
65
|
-
off(eventType: string, handler: EventHandler): void {
|
|
66
|
-
const handlers = this.handlers.get(eventType);
|
|
67
|
-
if (handlers) {
|
|
68
|
-
handlers.delete(handler);
|
|
69
|
-
if (handlers.size === 0) {
|
|
70
|
-
this.handlers.delete(eventType);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* Subscribe to all events (wildcard subscription).
|
|
77
|
-
* @returns Unsubscribe function
|
|
78
|
-
*/
|
|
79
|
-
onAny(handler: EventHandler): () => void {
|
|
80
|
-
this.wildcardHandlers.add(handler);
|
|
81
|
-
return () => {
|
|
82
|
-
this.wildcardHandlers.delete(handler);
|
|
83
|
-
};
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
/**
|
|
87
|
-
* Publish an event to all subscribers.
|
|
88
|
-
* Handler errors are caught and do not crash the bus.
|
|
89
|
-
*
|
|
90
|
-
* @param event - The event to publish
|
|
91
|
-
* @param waitForHandlers - If true, waits for all async handlers to complete (default: false)
|
|
92
|
-
*/
|
|
93
|
-
async publish(event: WorkflowEvent, waitForHandlers: boolean = false): Promise<void> {
|
|
94
|
-
// Get specific handlers for this event type
|
|
95
|
-
const handlers = this.handlers.get(event.type);
|
|
96
|
-
|
|
97
|
-
// Collect all handler promises
|
|
98
|
-
const handlerPromises: Promise<void>[] = [];
|
|
99
|
-
|
|
100
|
-
// Execute specific handlers
|
|
101
|
-
if (handlers) {
|
|
102
|
-
for (const handler of handlers) {
|
|
103
|
-
const promise = this.executeHandler(handler, event);
|
|
104
|
-
handlerPromises.push(promise);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
// Execute wildcard handlers
|
|
109
|
-
for (const handler of this.wildcardHandlers) {
|
|
110
|
-
const promise = this.executeHandler(handler, event);
|
|
111
|
-
handlerPromises.push(promise);
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
// Optionally wait for all handlers to complete
|
|
115
|
-
if (waitForHandlers && handlerPromises.length > 0) {
|
|
116
|
-
await Promise.allSettled(handlerPromises);
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
/**
|
|
121
|
-
* Execute a handler safely, catching any errors.
|
|
122
|
-
*/
|
|
123
|
-
private async executeHandler(handler: EventHandler, event: WorkflowEvent): Promise<void> {
|
|
124
|
-
try {
|
|
125
|
-
await handler(event);
|
|
126
|
-
} catch (error) {
|
|
127
|
-
// Silently catch handler errors to prevent crash
|
|
128
|
-
console.error('Event handler error:', error);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
/**
|
|
133
|
-
* Clear all subscriptions.
|
|
134
|
-
*/
|
|
135
|
-
clear(): void {
|
|
136
|
-
this.handlers.clear();
|
|
137
|
-
this.wildcardHandlers.clear();
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
/**
|
|
141
|
-
* Get statistics about the event bus.
|
|
142
|
-
*/
|
|
143
|
-
getStats(): { eventTypes: number; wildcardHandlers: number; totalHandlers: number } {
|
|
144
|
-
let totalHandlers = 0;
|
|
145
|
-
for (const handlers of this.handlers.values()) {
|
|
146
|
-
totalHandlers += handlers.size;
|
|
147
|
-
}
|
|
148
|
-
totalHandlers += this.wildcardHandlers.size;
|
|
149
|
-
|
|
150
|
-
return {
|
|
151
|
-
eventTypes: this.handlers.size,
|
|
152
|
-
wildcardHandlers: this.wildcardHandlers.size,
|
|
153
|
-
totalHandlers,
|
|
154
|
-
};
|
|
155
|
-
}
|
|
156
|
-
}
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach, vi } from 'vitest';
|
|
2
|
-
import { Executor, ExecutorOptions } from './executor';
|
|
3
|
-
import { EventBus } from './event-bus';
|
|
4
|
-
import type { NodeRegistry } from './node-registry';
|
|
5
|
-
|
|
6
|
-
describe('Executor - agentSessionId in messages', () => {
|
|
7
|
-
let executor: Executor;
|
|
8
|
-
let mockSessionComponent: any;
|
|
9
|
-
let addedMessages: any[] = [];
|
|
10
|
-
|
|
11
|
-
beforeEach(() => {
|
|
12
|
-
addedMessages = [];
|
|
13
|
-
mockSessionComponent = {
|
|
14
|
-
addMessage: vi.fn(async (sessionId: string, message: any) => {
|
|
15
|
-
addedMessages.push({ sessionId, message });
|
|
16
|
-
}),
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
executor = new Executor(
|
|
20
|
-
{} as NodeRegistry,
|
|
21
|
-
new EventBus(),
|
|
22
|
-
{} as ExecutorOptions,
|
|
23
|
-
mockSessionComponent
|
|
24
|
-
);
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
describe('writeNodeCall', () => {
|
|
28
|
-
it('should include agentSessionId in metadata when provided', async () => {
|
|
29
|
-
await executor.writeNodeCall(
|
|
30
|
-
'session-1',
|
|
31
|
-
'agent_node',
|
|
32
|
-
'agent',
|
|
33
|
-
{ input: 'test' },
|
|
34
|
-
'agent_agent_node_123'
|
|
35
|
-
);
|
|
36
|
-
|
|
37
|
-
expect(addedMessages).toHaveLength(1);
|
|
38
|
-
const metadata = addedMessages[0].message.metadata;
|
|
39
|
-
expect(metadata.agentSessionId).toBe('agent_agent_node_123');
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
it('should not include agentSessionId in metadata when not provided', async () => {
|
|
43
|
-
await executor.writeNodeCall(
|
|
44
|
-
'session-1',
|
|
45
|
-
'tool_node',
|
|
46
|
-
'tool',
|
|
47
|
-
{ input: 'test' }
|
|
48
|
-
);
|
|
49
|
-
|
|
50
|
-
expect(addedMessages).toHaveLength(1);
|
|
51
|
-
const metadata = addedMessages[0].message.metadata;
|
|
52
|
-
expect(metadata.agentSessionId).toBeUndefined();
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
describe('writeNodeInterrupt', () => {
|
|
57
|
-
it('should include agentSessionId in metadata when provided', async () => {
|
|
58
|
-
await executor.writeNodeInterrupt(
|
|
59
|
-
'session-1',
|
|
60
|
-
'ask_user',
|
|
61
|
-
'ask_user',
|
|
62
|
-
'Continue?',
|
|
63
|
-
'agent_agent_node_456'
|
|
64
|
-
);
|
|
65
|
-
|
|
66
|
-
expect(addedMessages).toHaveLength(1);
|
|
67
|
-
const metadata = addedMessages[0].message.metadata;
|
|
68
|
-
expect(metadata.agentSessionId).toBe('agent_agent_node_456');
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
it('should not include agentSessionId in metadata when not provided', async () => {
|
|
72
|
-
await executor.writeNodeInterrupt(
|
|
73
|
-
'session-1',
|
|
74
|
-
'ask_user',
|
|
75
|
-
'ask_user',
|
|
76
|
-
'Continue?'
|
|
77
|
-
);
|
|
78
|
-
|
|
79
|
-
expect(addedMessages).toHaveLength(1);
|
|
80
|
-
const metadata = addedMessages[0].message.metadata;
|
|
81
|
-
expect(metadata.agentSessionId).toBeUndefined();
|
|
82
|
-
});
|
|
83
|
-
});
|
|
84
|
-
});
|