@ai-setting/roy-agent-core 1.3.10 → 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,186 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview Log Reader
|
|
3
|
-
*
|
|
4
|
-
* Reads log files with support for streaming and filtering.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import * as fs from 'fs';
|
|
8
|
-
import * as readline from 'readline';
|
|
9
|
-
import * as path from 'path';
|
|
10
|
-
import { glob } from 'glob';
|
|
11
|
-
import type { ParserOptions } from '../types';
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Default XDG log directory
|
|
15
|
-
*/
|
|
16
|
-
const DEFAULT_LOG_DIR = '.local/share/roy-agent/logs';
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Get XDG data home directory
|
|
20
|
-
*/
|
|
21
|
-
export function getXDGDataHome(): string {
|
|
22
|
-
return process.env.XDG_DATA_HOME ||
|
|
23
|
-
path.join(process.env.HOME || '/home/' + (process.env.USER || 'user'), '.local', 'share');
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Log Reader for reading and parsing log files
|
|
28
|
-
*/
|
|
29
|
-
export class LogReader {
|
|
30
|
-
private logDir: string;
|
|
31
|
-
|
|
32
|
-
constructor(options?: { logDir?: string }) {
|
|
33
|
-
this.logDir = options?.logDir ||
|
|
34
|
-
path.join(getXDGDataHome(), 'roy-agent', 'logs');
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Get the full path to a log file
|
|
39
|
-
*/
|
|
40
|
-
getLogPath(filename?: string): string {
|
|
41
|
-
if (!filename) {
|
|
42
|
-
return path.join(this.logDir, 'app.log');
|
|
43
|
-
}
|
|
44
|
-
// If absolute path, use directly
|
|
45
|
-
if (path.isAbsolute(filename)) {
|
|
46
|
-
return filename;
|
|
47
|
-
}
|
|
48
|
-
return path.join(this.logDir, filename);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Find log files matching a pattern
|
|
53
|
-
*
|
|
54
|
-
* Uses forward slashes for glob patterns to ensure cross-platform compatibility.
|
|
55
|
-
* The glob library requires forward slashes regardless of OS.
|
|
56
|
-
*/
|
|
57
|
-
async findLogFiles(pattern: string = '*.log'): Promise<string[]> {
|
|
58
|
-
try {
|
|
59
|
-
// Use forward slashes for glob pattern to ensure Windows compatibility
|
|
60
|
-
const normalizedDir = this.logDir.replace(/\\/g, "/");
|
|
61
|
-
const fullPattern = `${normalizedDir}/${pattern}`;
|
|
62
|
-
const files = await glob(fullPattern);
|
|
63
|
-
return files.sort(); // Sort by name
|
|
64
|
-
} catch {
|
|
65
|
-
return [];
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Get default log directory
|
|
71
|
-
*/
|
|
72
|
-
getDefaultLogDir(): string {
|
|
73
|
-
return this.logDir;
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
/**
|
|
77
|
-
* Read lines from a log file with optional filtering
|
|
78
|
-
*/
|
|
79
|
-
async *readLines(
|
|
80
|
-
filepath: string,
|
|
81
|
-
options?: ParserOptions
|
|
82
|
-
): AsyncGenerator<string> {
|
|
83
|
-
const sinceTime = options?.since ? this.parseTime(options.since) : null;
|
|
84
|
-
const untilTime = options?.until ? this.parseTime(options.until) : null;
|
|
85
|
-
|
|
86
|
-
// Check if file exists
|
|
87
|
-
if (!fs.existsSync(filepath)) {
|
|
88
|
-
return;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
const fileStream = fs.createReadStream(filepath, { encoding: 'utf-8' });
|
|
92
|
-
const rl = readline.createInterface({
|
|
93
|
-
input: fileStream,
|
|
94
|
-
crlfDelay: Infinity,
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
try {
|
|
98
|
-
for await (const line of rl) {
|
|
99
|
-
if (!line.trim()) continue;
|
|
100
|
-
|
|
101
|
-
// Filter by time if specified
|
|
102
|
-
if (sinceTime || untilTime) {
|
|
103
|
-
const lineTime = this.extractTimestamp(line);
|
|
104
|
-
if (lineTime) {
|
|
105
|
-
if (sinceTime && lineTime < sinceTime) continue;
|
|
106
|
-
if (untilTime && lineTime > untilTime) continue;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
yield line;
|
|
111
|
-
}
|
|
112
|
-
} finally {
|
|
113
|
-
rl.close();
|
|
114
|
-
fileStream.destroy();
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
/**
|
|
119
|
-
* Extract timestamp from a log line
|
|
120
|
-
*/
|
|
121
|
-
extractTimestamp(line: string): number | null {
|
|
122
|
-
// Match format: 2026-04-08 19:12:36.134 or 2026-04-08T19:12:36.134
|
|
123
|
-
const match = line.match(/^(\d{4}-\d{2}-\d{2})[T ](\d{2}:\d{2}:\d{2})/);
|
|
124
|
-
if (!match) return null;
|
|
125
|
-
|
|
126
|
-
const datePart = match[1];
|
|
127
|
-
const timePart = match[2]; // Keep original format (10:00:00)
|
|
128
|
-
const isoString = `${datePart}T${timePart}`;
|
|
129
|
-
|
|
130
|
-
const timestamp = new Date(isoString).getTime();
|
|
131
|
-
return isNaN(timestamp) ? null : timestamp;
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
/**
|
|
135
|
-
* Parse time string to timestamp
|
|
136
|
-
* Supports ISO format and relative time like "1h", "30m"
|
|
137
|
-
*/
|
|
138
|
-
parseTime(timeStr: string): number {
|
|
139
|
-
const now = Date.now();
|
|
140
|
-
|
|
141
|
-
// Normalize the time string (replace T with space for parsing)
|
|
142
|
-
const normalizedStr = timeStr.replace('T', ' ');
|
|
143
|
-
|
|
144
|
-
// Try parsing as absolute time
|
|
145
|
-
const absoluteTime = new Date(normalizedStr).getTime();
|
|
146
|
-
if (!isNaN(absoluteTime) && absoluteTime > 0) {
|
|
147
|
-
return absoluteTime;
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
// Also try original format
|
|
151
|
-
const originalTime = new Date(timeStr).getTime();
|
|
152
|
-
if (!isNaN(originalTime) && originalTime > 0) {
|
|
153
|
-
return originalTime;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
// Parse relative time
|
|
157
|
-
const relativeMatch = timeStr.match(/^(\d+)([hms])$/);
|
|
158
|
-
if (relativeMatch) {
|
|
159
|
-
const value = parseInt(relativeMatch[1], 10);
|
|
160
|
-
const unit = relativeMatch[2];
|
|
161
|
-
|
|
162
|
-
switch (unit) {
|
|
163
|
-
case 'h': return now - value * 60 * 60 * 1000;
|
|
164
|
-
case 'm': return now - value * 60 * 1000;
|
|
165
|
-
case 's': return now - value * 1000;
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
// Default to current time if parsing fails
|
|
170
|
-
return now;
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
/**
|
|
174
|
-
* Read file content directly (for small files)
|
|
175
|
-
*/
|
|
176
|
-
async readFile(filepath: string): Promise<string> {
|
|
177
|
-
return fs.promises.readFile(filepath, 'utf-8');
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
/**
|
|
181
|
-
* Check if a log file exists
|
|
182
|
-
*/
|
|
183
|
-
exists(filepath: string): boolean {
|
|
184
|
-
return fs.existsSync(filepath);
|
|
185
|
-
}
|
|
186
|
-
}
|
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview SpanDbReader Test
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { describe, test, expect, beforeAll, afterAll } from 'bun:test';
|
|
6
|
-
import { SpanDbReader } from './span-db-reader';
|
|
7
|
-
import { SQLiteSpanStorage } from '../../log-trace/span-storage';
|
|
8
|
-
import type { Span } from '../../log-trace/types';
|
|
9
|
-
import { SpanKind, SpanStatus } from '../../log-trace/types';
|
|
10
|
-
import * as fs from 'fs';
|
|
11
|
-
import * as path from 'path';
|
|
12
|
-
|
|
13
|
-
// Test data
|
|
14
|
-
const testSpan1: Span = {
|
|
15
|
-
traceId: 'trace_test_001',
|
|
16
|
-
spanId: 'span_1',
|
|
17
|
-
name: 'testFunction',
|
|
18
|
-
kind: SpanKind.INTERNAL,
|
|
19
|
-
status: SpanStatus.OK,
|
|
20
|
-
startTime: Date.now() - 1000,
|
|
21
|
-
endTime: Date.now(),
|
|
22
|
-
attributes: { arg1: 'value1', arg2: 123 },
|
|
23
|
-
children: [],
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
const testSpan2: Span = {
|
|
27
|
-
traceId: 'trace_test_002',
|
|
28
|
-
spanId: 'span_2',
|
|
29
|
-
name: 'anotherFunction',
|
|
30
|
-
kind: SpanKind.INTERNAL,
|
|
31
|
-
status: SpanStatus.OK,
|
|
32
|
-
startTime: Date.now() - 500,
|
|
33
|
-
endTime: Date.now() - 100,
|
|
34
|
-
attributes: {},
|
|
35
|
-
children: [],
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
describe('SpanDbReader', () => {
|
|
39
|
-
let storage: SQLiteSpanStorage;
|
|
40
|
-
let reader: SpanDbReader;
|
|
41
|
-
let tempDbPath: string;
|
|
42
|
-
|
|
43
|
-
beforeAll(async () => {
|
|
44
|
-
// 清除环境变量中的 trace context,避免继承外部上下文
|
|
45
|
-
delete process.env['TRACEPARENT'];
|
|
46
|
-
delete process.env['TRACE_ID'];
|
|
47
|
-
delete process.env['LOG_TRACE_REQUEST_ID'];
|
|
48
|
-
|
|
49
|
-
// Create temporary database file
|
|
50
|
-
tempDbPath = `/tmp/test_span_db_${Date.now()}.sqlite`;
|
|
51
|
-
storage = new SQLiteSpanStorage(tempDbPath);
|
|
52
|
-
await storage.initialize();
|
|
53
|
-
|
|
54
|
-
// Insert test data
|
|
55
|
-
storage.save(testSpan1);
|
|
56
|
-
storage.save(testSpan2);
|
|
57
|
-
|
|
58
|
-
// Create reader with storage
|
|
59
|
-
reader = new SpanDbReader({ storage });
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
afterAll(() => {
|
|
63
|
-
reader.close();
|
|
64
|
-
storage.close();
|
|
65
|
-
// Cleanup temp file
|
|
66
|
-
if (fs.existsSync(tempDbPath)) {
|
|
67
|
-
fs.unlinkSync(tempDbPath);
|
|
68
|
-
}
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
test('should list trace IDs', async () => {
|
|
72
|
-
const summary = await reader.listTraceIds(10);
|
|
73
|
-
|
|
74
|
-
expect(summary.count).toBeGreaterThanOrEqual(2);
|
|
75
|
-
expect(summary.traceIds.length).toBeGreaterThanOrEqual(2);
|
|
76
|
-
|
|
77
|
-
const traceIds = summary.traceIds.map(t => t.traceId);
|
|
78
|
-
expect(traceIds).toContain('trace_test_001');
|
|
79
|
-
expect(traceIds).toContain('trace_test_002');
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
test('should get trace entries by traceId', async () => {
|
|
83
|
-
const entries = await reader.getTraceEntries('trace_test_001');
|
|
84
|
-
|
|
85
|
-
expect(entries.length).toBeGreaterThanOrEqual(2); // enter and quit
|
|
86
|
-
expect(entries[0].traceId).toBe('trace_test_001');
|
|
87
|
-
expect(entries[0].function).toBe('testFunction');
|
|
88
|
-
expect(entries[0].action).toBe('enter');
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
test('should return empty array for non-existent trace', async () => {
|
|
92
|
-
const entries = await reader.getTraceEntries('non_existent_trace');
|
|
93
|
-
expect(entries).toHaveLength(0);
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
test('should limit trace list', async () => {
|
|
97
|
-
const summary = await reader.listTraceIds(1);
|
|
98
|
-
expect(summary.traceIds.length).toBeLessThanOrEqual(1);
|
|
99
|
-
});
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
describe('SpanDbReader with dbPath', () => {
|
|
103
|
-
test('should initialize from dbPath', async () => {
|
|
104
|
-
const tempPath = `/tmp/test_span_db_${Date.now()}.sqlite`;
|
|
105
|
-
const reader = new SpanDbReader({ dbPath: tempPath });
|
|
106
|
-
|
|
107
|
-
await reader.initialize();
|
|
108
|
-
|
|
109
|
-
expect(reader.getStorage()).toBeTruthy();
|
|
110
|
-
|
|
111
|
-
reader.close();
|
|
112
|
-
|
|
113
|
-
// Cleanup
|
|
114
|
-
if (fs.existsSync(tempPath)) {
|
|
115
|
-
fs.unlinkSync(tempPath);
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
});
|
|
@@ -1,201 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview Span DB Reader - Read spans from SQLite database
|
|
3
|
-
*
|
|
4
|
-
* This reader fetches trace data directly from SQLite span storage,
|
|
5
|
-
* which is used for persisting spans in production environments.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import type { TraceEntry, TraceIdInfo, TraceSummary } from '../types';
|
|
9
|
-
import type { Span, SpanStorage } from '../../log-trace/types';
|
|
10
|
-
|
|
11
|
-
// ============================================================================
|
|
12
|
-
// SpanDbReader
|
|
13
|
-
// ============================================================================
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Options for SpanDbReader
|
|
17
|
-
*/
|
|
18
|
-
export interface SpanDbReaderOptions {
|
|
19
|
-
/** Database path (for file-based SQLite) */
|
|
20
|
-
dbPath?: string;
|
|
21
|
-
/** Storage instance to use directly */
|
|
22
|
-
storage?: SpanStorage;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* Span Database Reader
|
|
27
|
-
*
|
|
28
|
-
* Reads span data from SQLite storage for trace debugging and analysis.
|
|
29
|
-
*/
|
|
30
|
-
export class SpanDbReader {
|
|
31
|
-
private storage: SpanStorage | null = null;
|
|
32
|
-
private dbPath: string | null = null;
|
|
33
|
-
private sqliteDb: any = null;
|
|
34
|
-
|
|
35
|
-
constructor(options?: SpanDbReaderOptions) {
|
|
36
|
-
if (options?.storage) {
|
|
37
|
-
this.storage = options.storage;
|
|
38
|
-
} else if (options?.dbPath) {
|
|
39
|
-
this.dbPath = options.dbPath;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Initialize the reader with storage
|
|
45
|
-
*/
|
|
46
|
-
async initialize(): Promise<void> {
|
|
47
|
-
if (this.storage) {
|
|
48
|
-
await this.storage.initialize();
|
|
49
|
-
} else if (this.dbPath) {
|
|
50
|
-
// Lazy load SQLite storage
|
|
51
|
-
await this.initSqliteStorage();
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Initialize SQLite storage directly
|
|
57
|
-
*/
|
|
58
|
-
private async initSqliteStorage(): Promise<void> {
|
|
59
|
-
try {
|
|
60
|
-
// Dynamic import to avoid hard dependency
|
|
61
|
-
const { SQLiteSpanStorage } = await import('../../log-trace/span-storage');
|
|
62
|
-
this.storage = new SQLiteSpanStorage(this.dbPath!);
|
|
63
|
-
await this.storage.initialize();
|
|
64
|
-
} catch (error) {
|
|
65
|
-
throw new Error(`Failed to initialize SQLite storage: ${error}`);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Get trace entries for a specific traceId
|
|
71
|
-
*/
|
|
72
|
-
async getTraceEntries(traceId: string): Promise<TraceEntry[]> {
|
|
73
|
-
if (!this.storage) {
|
|
74
|
-
throw new Error('Storage not initialized. Call initialize() first.');
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
const spans = this.storage.findByTraceId(traceId);
|
|
78
|
-
if (spans.length === 0) {
|
|
79
|
-
return [];
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
// Convert spans to TraceEntry format
|
|
83
|
-
return this.spansToEntries(spans);
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
/**
|
|
87
|
-
* List all trace IDs
|
|
88
|
-
*/
|
|
89
|
-
async listTraceIds(limit: number = 20): Promise<TraceSummary> {
|
|
90
|
-
if (!this.storage) {
|
|
91
|
-
throw new Error('Storage not initialized. Call initialize() first.');
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
const traceInfos = this.storage.listTraces(limit);
|
|
95
|
-
|
|
96
|
-
const traceIds: TraceIdInfo[] = traceInfos.map(info => ({
|
|
97
|
-
traceId: info.traceId,
|
|
98
|
-
firstTime: new Date(info.startTime).toISOString(),
|
|
99
|
-
lastTime: info.endTime ? new Date(info.endTime).toISOString() : undefined,
|
|
100
|
-
count: info.spanCount,
|
|
101
|
-
}));
|
|
102
|
-
|
|
103
|
-
return {
|
|
104
|
-
traceIds,
|
|
105
|
-
count: traceInfos.length,
|
|
106
|
-
};
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
/**
|
|
110
|
-
* Convert spans to TraceEntry format
|
|
111
|
-
*
|
|
112
|
-
* Now properly extracts spanId and parentSpanId for tree building
|
|
113
|
-
*/
|
|
114
|
-
private spansToEntries(spans: Span[]): TraceEntry[] {
|
|
115
|
-
const entries: TraceEntry[] = [];
|
|
116
|
-
|
|
117
|
-
// Create entries for each span (enter event)
|
|
118
|
-
for (const span of spans) {
|
|
119
|
-
entries.push({
|
|
120
|
-
traceId: span.traceId,
|
|
121
|
-
timestamp: new Date(span.startTime).toISOString(),
|
|
122
|
-
function: span.name,
|
|
123
|
-
action: 'enter',
|
|
124
|
-
params: this.attributesToParams(span.attributes),
|
|
125
|
-
spanId: span.spanId,
|
|
126
|
-
parentSpanId: span.parentSpanId,
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
if (span.endTime) {
|
|
130
|
-
entries.push({
|
|
131
|
-
traceId: span.traceId,
|
|
132
|
-
timestamp: new Date(span.endTime).toISOString(),
|
|
133
|
-
function: span.name,
|
|
134
|
-
action: 'quit',
|
|
135
|
-
result: span.result,
|
|
136
|
-
error: span.error,
|
|
137
|
-
durationMs: span.endTime - span.startTime,
|
|
138
|
-
spanId: span.spanId,
|
|
139
|
-
parentSpanId: span.parentSpanId,
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
// Sort by timestamp
|
|
145
|
-
entries.sort((a, b) => a.timestamp.localeCompare(b.timestamp));
|
|
146
|
-
|
|
147
|
-
return entries;
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
/**
|
|
151
|
-
* Convert span attributes to params format
|
|
152
|
-
*/
|
|
153
|
-
private attributesToParams(attributes: Record<string, unknown> | undefined): unknown[] {
|
|
154
|
-
if (!attributes) return [];
|
|
155
|
-
return Object.entries(attributes).map(([key, value]) => ({
|
|
156
|
-
key,
|
|
157
|
-
value,
|
|
158
|
-
}));
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
/**
|
|
162
|
-
* Get the underlying storage
|
|
163
|
-
*/
|
|
164
|
-
getStorage(): SpanStorage | null {
|
|
165
|
-
return this.storage;
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
/**
|
|
169
|
-
* Close the reader and cleanup resources
|
|
170
|
-
*/
|
|
171
|
-
close(): void {
|
|
172
|
-
if (this.storage) {
|
|
173
|
-
this.storage.close();
|
|
174
|
-
this.storage = null;
|
|
175
|
-
}
|
|
176
|
-
if (this.sqliteDb) {
|
|
177
|
-
this.sqliteDb.close();
|
|
178
|
-
this.sqliteDb = null;
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
// ============================================================================
|
|
184
|
-
// Utility Functions
|
|
185
|
-
// ============================================================================
|
|
186
|
-
|
|
187
|
-
/**
|
|
188
|
-
* Create a SpanDbReader from a database path
|
|
189
|
-
*/
|
|
190
|
-
export async function createSpanDbReader(dbPath: string): Promise<SpanDbReader> {
|
|
191
|
-
const reader = new SpanDbReader({ dbPath });
|
|
192
|
-
await reader.initialize();
|
|
193
|
-
return reader;
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
/**
|
|
197
|
-
* Create a SpanDbReader from an existing storage instance
|
|
198
|
-
*/
|
|
199
|
-
export function createSpanDbReaderFromStorage(storage: SpanStorage): SpanDbReader {
|
|
200
|
-
return new SpanDbReader({ storage });
|
|
201
|
-
}
|
|
@@ -1,187 +0,0 @@
|
|
|
1
|
-
import { describe, expect, test } from 'bun:test';
|
|
2
|
-
import type {
|
|
3
|
-
TraceEntry,
|
|
4
|
-
TraceTreeNode,
|
|
5
|
-
ParserOptions,
|
|
6
|
-
LogDiscoveryOptions,
|
|
7
|
-
TraceIdInfo,
|
|
8
|
-
ParsedLogLine,
|
|
9
|
-
} from './types';
|
|
10
|
-
|
|
11
|
-
describe('Debug Types', () => {
|
|
12
|
-
describe('TraceEntry', () => {
|
|
13
|
-
test('should have correct structure for enter action', () => {
|
|
14
|
-
const entry: TraceEntry = {
|
|
15
|
-
traceId: 'req_123_abc',
|
|
16
|
-
timestamp: '2026-04-08T19:12:36.134',
|
|
17
|
-
function: 'llm.component.invoke',
|
|
18
|
-
action: 'enter',
|
|
19
|
-
params: [
|
|
20
|
-
{ messages: [{ role: 'system', content: 'You are Roy...' }] },
|
|
21
|
-
{ providerId: 'minimax', model: 'MiniMax-M2.7' },
|
|
22
|
-
],
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
expect(entry.traceId).toBe('req_123_abc');
|
|
26
|
-
expect(entry.function).toBe('llm.component.invoke');
|
|
27
|
-
expect(entry.action).toBe('enter');
|
|
28
|
-
expect(entry.params).toHaveLength(2);
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
test('should have correct structure for quit action', () => {
|
|
32
|
-
const entry: TraceEntry = {
|
|
33
|
-
traceId: 'req_123_abc',
|
|
34
|
-
timestamp: '2026-04-08T19:12:39.213',
|
|
35
|
-
function: 'llm.component.invoke',
|
|
36
|
-
action: 'quit',
|
|
37
|
-
result: {
|
|
38
|
-
output: { content: 'Hello!', finishReason: 'stop' },
|
|
39
|
-
latencyMs: 3077,
|
|
40
|
-
},
|
|
41
|
-
durationMs: 3077,
|
|
42
|
-
};
|
|
43
|
-
|
|
44
|
-
expect(entry.action).toBe('quit');
|
|
45
|
-
expect(entry.durationMs).toBe(3077);
|
|
46
|
-
expect(entry.result).toBeDefined();
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
test('should have correct structure for error action', () => {
|
|
50
|
-
const entry: TraceEntry = {
|
|
51
|
-
traceId: 'req_123_abc',
|
|
52
|
-
timestamp: '2026-04-08T19:12:39.213',
|
|
53
|
-
function: 'llm.component.invoke',
|
|
54
|
-
action: 'error',
|
|
55
|
-
error: 'Connection timeout',
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
expect(entry.action).toBe('error');
|
|
59
|
-
expect(entry.error).toBe('Connection timeout');
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
describe('TraceTreeNode', () => {
|
|
64
|
-
test('should have correct structure', () => {
|
|
65
|
-
const node: TraceTreeNode = {
|
|
66
|
-
traceId: 'req_123_abc',
|
|
67
|
-
function: 'llm.component.invoke',
|
|
68
|
-
startTime: '2026-04-08T19:12:36.134',
|
|
69
|
-
endTime: '2026-04-08T19:12:39.213',
|
|
70
|
-
durationMs: 3077,
|
|
71
|
-
children: [],
|
|
72
|
-
entry: {
|
|
73
|
-
traceId: 'req_123_abc',
|
|
74
|
-
timestamp: '2026-04-08T19:12:36.134',
|
|
75
|
-
function: 'llm.component.invoke',
|
|
76
|
-
action: 'enter',
|
|
77
|
-
},
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
expect(node.children).toHaveLength(0);
|
|
81
|
-
expect(node.durationMs).toBe(3077);
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
test('should support nested children', () => {
|
|
85
|
-
const childNode: TraceTreeNode = {
|
|
86
|
-
traceId: 'req_123_abc',
|
|
87
|
-
function: 'tool.execute',
|
|
88
|
-
startTime: '2026-04-08T19:12:37.000',
|
|
89
|
-
endTime: '2026-04-08T19:12:37.500',
|
|
90
|
-
durationMs: 500,
|
|
91
|
-
children: [],
|
|
92
|
-
entry: {
|
|
93
|
-
traceId: 'req_123_abc',
|
|
94
|
-
timestamp: '2026-04-08T19:12:37.000',
|
|
95
|
-
function: 'tool.execute',
|
|
96
|
-
action: 'enter',
|
|
97
|
-
},
|
|
98
|
-
};
|
|
99
|
-
|
|
100
|
-
const rootNode: TraceTreeNode = {
|
|
101
|
-
traceId: 'req_123_abc',
|
|
102
|
-
function: 'llm.component.invoke',
|
|
103
|
-
startTime: '2026-04-08T19:12:36.134',
|
|
104
|
-
endTime: '2026-04-08T19:12:39.213',
|
|
105
|
-
durationMs: 3077,
|
|
106
|
-
children: [childNode],
|
|
107
|
-
entry: {
|
|
108
|
-
traceId: 'req_123_abc',
|
|
109
|
-
timestamp: '2026-04-08T19:12:36.134',
|
|
110
|
-
function: 'llm.component.invoke',
|
|
111
|
-
action: 'enter',
|
|
112
|
-
},
|
|
113
|
-
};
|
|
114
|
-
|
|
115
|
-
expect(rootNode.children).toHaveLength(1);
|
|
116
|
-
expect(rootNode.children[0].function).toBe('tool.execute');
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
describe('ParserOptions', () => {
|
|
121
|
-
test('should support all optional fields', () => {
|
|
122
|
-
const options: ParserOptions = {
|
|
123
|
-
logFile: '/path/to/app.log',
|
|
124
|
-
traceId: 'req_123',
|
|
125
|
-
function: 'llm.component.invoke',
|
|
126
|
-
since: '2026-04-08T10:00:00',
|
|
127
|
-
until: '2026-04-08T12:00:00',
|
|
128
|
-
level: 'info',
|
|
129
|
-
};
|
|
130
|
-
|
|
131
|
-
expect(options.logFile).toBe('/path/to/app.log');
|
|
132
|
-
expect(options.level).toBe('info');
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
test('should allow empty options', () => {
|
|
136
|
-
const options: ParserOptions = {};
|
|
137
|
-
expect(options.logFile).toBeUndefined();
|
|
138
|
-
expect(options.traceId).toBeUndefined();
|
|
139
|
-
});
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
describe('LogDiscoveryOptions', () => {
|
|
143
|
-
test('should have default pattern', () => {
|
|
144
|
-
const options: LogDiscoveryOptions = {
|
|
145
|
-
logDir: '/custom/logs',
|
|
146
|
-
pattern: '*.log',
|
|
147
|
-
};
|
|
148
|
-
|
|
149
|
-
expect(options.pattern).toBe('*.log');
|
|
150
|
-
});
|
|
151
|
-
});
|
|
152
|
-
|
|
153
|
-
describe('TraceIdInfo', () => {
|
|
154
|
-
test('should have correct structure', () => {
|
|
155
|
-
const info: TraceIdInfo = {
|
|
156
|
-
traceId: 'req_123_abc',
|
|
157
|
-
firstTime: '2026-04-08T19:12:36',
|
|
158
|
-
lastTime: '2026-04-08T19:12:45',
|
|
159
|
-
count: 15,
|
|
160
|
-
};
|
|
161
|
-
|
|
162
|
-
expect(info.traceId).toBe('req_123_abc');
|
|
163
|
-
expect(info.count).toBe(15);
|
|
164
|
-
});
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
describe('ParsedLogLine', () => {
|
|
168
|
-
test('should have correct structure', () => {
|
|
169
|
-
const line: ParsedLogLine = {
|
|
170
|
-
raw: '2026-04-08 19:12:36.134 [INFO] [cli/src/bin/roy.js:80752][traced:llm.component.invoke] [TRACE] >>> llm.component.invoke enter: [{}]',
|
|
171
|
-
timestamp: '2026-04-08 19:12:36.134',
|
|
172
|
-
level: 'INFO',
|
|
173
|
-
source: 'cli/src/bin/roy.js:80752',
|
|
174
|
-
category: 'traced:llm.component.invoke',
|
|
175
|
-
action: '>>>',
|
|
176
|
-
method: 'llm.component.invoke',
|
|
177
|
-
actionType: 'enter',
|
|
178
|
-
rawArgs: '[{}]',
|
|
179
|
-
};
|
|
180
|
-
|
|
181
|
-
expect(line.timestamp).toBe('2026-04-08 19:12:36.134');
|
|
182
|
-
expect(line.level).toBe('INFO');
|
|
183
|
-
expect(line.action).toBe('>>>');
|
|
184
|
-
expect(line.method).toBe('llm.component.invoke');
|
|
185
|
-
});
|
|
186
|
-
});
|
|
187
|
-
});
|