@renxqoo/renx-code 0.0.9 → 0.0.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +31 -143
- package/bin/renx.cjs +79 -42
- package/bin/renx.exe +0 -0
- package/package.json +10 -28
- package/src/App.tsx +0 -297
- package/src/agent/runtime/event-format.ts +0 -258
- package/src/agent/runtime/model-types.ts +0 -13
- package/src/agent/runtime/runtime.context-usage.test.ts +0 -192
- package/src/agent/runtime/runtime.error-handling.test.ts +0 -235
- package/src/agent/runtime/runtime.simple.test.ts +0 -16
- package/src/agent/runtime/runtime.test.ts +0 -296
- package/src/agent/runtime/runtime.ts +0 -875
- package/src/agent/runtime/runtime.usage-forwarding.test.ts +0 -228
- package/src/agent/runtime/source-modules.test.ts +0 -38
- package/src/agent/runtime/source-modules.ts +0 -370
- package/src/agent/runtime/tool-call-buffer.test.ts +0 -65
- package/src/agent/runtime/tool-call-buffer.ts +0 -60
- package/src/agent/runtime/tool-confirmation.test.ts +0 -56
- package/src/agent/runtime/tool-confirmation.ts +0 -15
- package/src/agent/runtime/types.ts +0 -99
- package/src/commands/slash-commands.test.ts +0 -216
- package/src/commands/slash-commands.ts +0 -64
- package/src/components/chat/assistant-reply.test.tsx +0 -47
- package/src/components/chat/assistant-reply.tsx +0 -136
- package/src/components/chat/assistant-segment.test.ts +0 -99
- package/src/components/chat/assistant-segment.tsx +0 -125
- package/src/components/chat/assistant-tool-group.tsx +0 -900
- package/src/components/chat/code-block.test.tsx +0 -206
- package/src/components/chat/code-block.tsx +0 -313
- package/src/components/chat/prompt-card.tsx +0 -81
- package/src/components/chat/segment-groups.test.ts +0 -52
- package/src/components/chat/segment-groups.ts +0 -106
- package/src/components/chat/turn-item.tsx +0 -39
- package/src/components/conversation-panel.tsx +0 -43
- package/src/components/file-mention-menu.tsx +0 -77
- package/src/components/file-picker-dialog.tsx +0 -206
- package/src/components/footer-hints.tsx +0 -75
- package/src/components/model-picker-dialog.tsx +0 -248
- package/src/components/prompt.tsx +0 -233
- package/src/components/slash-command-menu.tsx +0 -65
- package/src/components/tool-confirm-dialog-content.test.ts +0 -103
- package/src/components/tool-confirm-dialog-content.ts +0 -186
- package/src/components/tool-confirm-dialog.tsx +0 -187
- package/src/components/tool-display-config.ts +0 -119
- package/src/context-usage-regressions.test.ts +0 -26
- package/src/files/attachment-capabilities.test.ts +0 -30
- package/src/files/attachment-capabilities.ts +0 -50
- package/src/files/attachment-content.ts +0 -153
- package/src/files/file-mention-query.test.ts +0 -34
- package/src/files/file-mention-query.ts +0 -32
- package/src/files/prompt-display.ts +0 -13
- package/src/files/types.ts +0 -5
- package/src/files/workspace-files.ts +0 -61
- package/src/hooks/agent-event-handlers.test.ts +0 -207
- package/src/hooks/agent-event-handlers.ts +0 -196
- package/src/hooks/chat-local-replies.fixed.test.ts +0 -119
- package/src/hooks/chat-local-replies.test.ts +0 -153
- package/src/hooks/chat-local-replies.ts +0 -63
- package/src/hooks/turn-updater.test.ts +0 -70
- package/src/hooks/turn-updater.ts +0 -166
- package/src/hooks/use-agent-chat.context.test.ts +0 -10
- package/src/hooks/use-agent-chat.status.test.ts +0 -14
- package/src/hooks/use-agent-chat.test.ts +0 -80
- package/src/hooks/use-agent-chat.ts +0 -621
- package/src/hooks/use-file-mention-menu.ts +0 -196
- package/src/hooks/use-file-picker.ts +0 -185
- package/src/hooks/use-model-picker.ts +0 -196
- package/src/hooks/use-slash-command-menu.ts +0 -154
- package/src/index.tsx +0 -55
- package/src/runtime/clipboard.test.ts +0 -43
- package/src/runtime/clipboard.ts +0 -89
- package/src/runtime/exit.test.ts +0 -177
- package/src/runtime/exit.ts +0 -98
- package/src/runtime/runtime-support.test.ts +0 -31
- package/src/runtime/terminal-theme.test.ts +0 -55
- package/src/runtime/terminal-theme.ts +0 -196
- package/src/types/chat.ts +0 -32
- package/src/types/message-content.ts +0 -48
- package/src/ui/open-code-theme.ts +0 -176
- package/src/ui/opencode-markdown.ts +0 -211
- package/src/ui/theme.simple.test.ts +0 -52
- package/src/ui/theme.test.ts +0 -151
- package/src/ui/theme.ts +0 -152
- package/src/utils/time.test.ts +0 -144
- package/src/utils/time.ts +0 -7
- package/tsconfig.json +0 -30
- package/vendor/agent-root/src/agent/ENTERPRISE_ACCEPTANCE_CHECKLIST.md +0 -95
- package/vendor/agent-root/src/agent/ENTERPRISE_REALTIME.html +0 -1345
- package/vendor/agent-root/src/agent/ENTERPRISE_REALTIME.md +0 -1353
- package/vendor/agent-root/src/agent/ERROR_CONTRACT.md +0 -60
- package/vendor/agent-root/src/agent/TEST_COVERAGE_ANALYSIS.md +0 -278
- package/vendor/agent-root/src/agent/__test__/error-contract.test.ts +0 -72
- package/vendor/agent-root/src/agent/__test__/types.test.ts +0 -137
- package/vendor/agent-root/src/agent/agent/__test__/abort-runtime.test.ts +0 -83
- package/vendor/agent-root/src/agent/agent/__test__/callback-safety.test.ts +0 -34
- package/vendor/agent-root/src/agent/agent/__test__/compaction.test.ts +0 -323
- package/vendor/agent-root/src/agent/agent/__test__/concurrency.test.ts +0 -290
- package/vendor/agent-root/src/agent/agent/__test__/error-normalizer.test.ts +0 -377
- package/vendor/agent-root/src/agent/agent/__test__/error.test.ts +0 -212
- package/vendor/agent-root/src/agent/agent/__test__/fault-injection.test.ts +0 -295
- package/vendor/agent-root/src/agent/agent/__test__/index.test.ts +0 -3607
- package/vendor/agent-root/src/agent/agent/__test__/logger.test.ts +0 -35
- package/vendor/agent-root/src/agent/agent/__test__/message-utils.test.ts +0 -517
- package/vendor/agent-root/src/agent/agent/__test__/telemetry.test.ts +0 -97
- package/vendor/agent-root/src/agent/agent/__test__/timeout-budget.test.ts +0 -479
- package/vendor/agent-root/src/agent/agent/__test__/tool-call-merge.test.ts +0 -80
- package/vendor/agent-root/src/agent/agent/__test__/tool-execution-ledger.test.ts +0 -76
- package/vendor/agent-root/src/agent/agent/__test__/write-buffer.test.ts +0 -173
- package/vendor/agent-root/src/agent/agent/__test__/write-file-session.test.ts +0 -109
- package/vendor/agent-root/src/agent/agent/abort-runtime.ts +0 -71
- package/vendor/agent-root/src/agent/agent/callback-safety.ts +0 -33
- package/vendor/agent-root/src/agent/agent/compaction.ts +0 -291
- package/vendor/agent-root/src/agent/agent/concurrency.ts +0 -103
- package/vendor/agent-root/src/agent/agent/error-normalizer.ts +0 -190
- package/vendor/agent-root/src/agent/agent/error.ts +0 -198
- package/vendor/agent-root/src/agent/agent/index.ts +0 -1772
- package/vendor/agent-root/src/agent/agent/logger.ts +0 -65
- package/vendor/agent-root/src/agent/agent/message-utils.ts +0 -101
- package/vendor/agent-root/src/agent/agent/stream-events.ts +0 -61
- package/vendor/agent-root/src/agent/agent/telemetry.ts +0 -123
- package/vendor/agent-root/src/agent/agent/timeout-budget.ts +0 -227
- package/vendor/agent-root/src/agent/agent/tool-call-merge.ts +0 -111
- package/vendor/agent-root/src/agent/agent/tool-execution-ledger.ts +0 -164
- package/vendor/agent-root/src/agent/agent/write-buffer.ts +0 -188
- package/vendor/agent-root/src/agent/agent/write-file-session.ts +0 -238
- package/vendor/agent-root/src/agent/app/__test__/agent-app-service.test.ts +0 -1053
- package/vendor/agent-root/src/agent/app/__test__/minimal-agent-application.test.ts +0 -158
- package/vendor/agent-root/src/agent/app/__test__/sqlite-agent-app-store.test.ts +0 -437
- package/vendor/agent-root/src/agent/app/agent-app-service.ts +0 -748
- package/vendor/agent-root/src/agent/app/contracts.ts +0 -109
- package/vendor/agent-root/src/agent/app/index.ts +0 -5
- package/vendor/agent-root/src/agent/app/minimal-agent-application.ts +0 -151
- package/vendor/agent-root/src/agent/app/ports.ts +0 -72
- package/vendor/agent-root/src/agent/app/sqlite-agent-app-store.ts +0 -1182
- package/vendor/agent-root/src/agent/app/sqlite-client.ts +0 -177
- package/vendor/agent-root/src/agent/docs/cli-app-layer/00-README.md +0 -36
- package/vendor/agent-root/src/agent/docs/cli-app-layer/01-scope-and-goals.md +0 -33
- package/vendor/agent-root/src/agent/docs/cli-app-layer/02-architecture-overview.md +0 -40
- package/vendor/agent-root/src/agent/docs/cli-app-layer/03-domain-model-and-contracts.md +0 -91
- package/vendor/agent-root/src/agent/docs/cli-app-layer/04-ports-and-interfaces.md +0 -116
- package/vendor/agent-root/src/agent/docs/cli-app-layer/05-run-orchestration-and-state-machine.md +0 -52
- package/vendor/agent-root/src/agent/docs/cli-app-layer/06-cli-commands-and-ux.md +0 -53
- package/vendor/agent-root/src/agent/docs/cli-app-layer/07-storage-design-local.md +0 -52
- package/vendor/agent-root/src/agent/docs/cli-app-layer/08-error-and-observability.md +0 -40
- package/vendor/agent-root/src/agent/docs/cli-app-layer/09-security-and-policy-boundary.md +0 -19
- package/vendor/agent-root/src/agent/docs/cli-app-layer/10-test-plan-and-acceptance.md +0 -28
- package/vendor/agent-root/src/agent/docs/cli-app-layer/11-implementation-phases.md +0 -26
- package/vendor/agent-root/src/agent/docs/cli-app-layer/12-open-questions-and-risks.md +0 -30
- package/vendor/agent-root/src/agent/docs/cli-app-layer/13-sqlite-schema-fields-and-rationale.md +0 -567
- package/vendor/agent-root/src/agent/docs/cli-app-layer/14-project-flow-mermaid.md +0 -583
- package/vendor/agent-root/src/agent/docs/cli-app-layer/15-openclaw-style-project-blueprint.md +0 -972
- package/vendor/agent-root/src/agent/error-contract.ts +0 -154
- package/vendor/agent-root/src/agent/prompts/system.ts +0 -246
- package/vendor/agent-root/src/agent/prompts/system1.ts +0 -208
- package/vendor/agent-root/src/agent/storage/__test__/file-history-store.test.ts +0 -98
- package/vendor/agent-root/src/agent/storage/file-history-store.ts +0 -313
- package/vendor/agent-root/src/agent/storage/file-storage-config.ts +0 -94
- package/vendor/agent-root/src/agent/storage/file-system.ts +0 -31
- package/vendor/agent-root/src/agent/storage/file-write-service.ts +0 -21
- package/vendor/agent-root/src/agent/tool/__test__/base-tool.test.ts +0 -413
- package/vendor/agent-root/src/agent/tool/__test__/bash-policy.test.ts +0 -356
- package/vendor/agent-root/src/agent/tool/__test__/bash.mocked-coverage.test.ts +0 -375
- package/vendor/agent-root/src/agent/tool/__test__/bash.test.ts +0 -372
- package/vendor/agent-root/src/agent/tool/__test__/error.test.ts +0 -108
- package/vendor/agent-root/src/agent/tool/__test__/file-edit-tool.test.ts +0 -258
- package/vendor/agent-root/src/agent/tool/__test__/file-history-tools.test.ts +0 -121
- package/vendor/agent-root/src/agent/tool/__test__/file-read-tool.test.ts +0 -210
- package/vendor/agent-root/src/agent/tool/__test__/glob.test.ts +0 -139
- package/vendor/agent-root/src/agent/tool/__test__/grep.mocked-coverage.test.ts +0 -456
- package/vendor/agent-root/src/agent/tool/__test__/grep.test.ts +0 -192
- package/vendor/agent-root/src/agent/tool/__test__/lsp.test.ts +0 -300
- package/vendor/agent-root/src/agent/tool/__test__/outside-workspace-confirmation.test.ts +0 -214
- package/vendor/agent-root/src/agent/tool/__test__/path-security.test.ts +0 -336
- package/vendor/agent-root/src/agent/tool/__test__/skill-loader.test.ts +0 -494
- package/vendor/agent-root/src/agent/tool/__test__/skill-parser.test.ts +0 -543
- package/vendor/agent-root/src/agent/tool/__test__/skill-tool.test.ts +0 -172
- package/vendor/agent-root/src/agent/tool/__test__/task-concurrency-and-version.test.ts +0 -116
- package/vendor/agent-root/src/agent/tool/__test__/task-create-get-list-update.test.ts +0 -267
- package/vendor/agent-root/src/agent/tool/__test__/task-create.test.ts +0 -519
- package/vendor/agent-root/src/agent/tool/__test__/task-errors.test.ts +0 -225
- package/vendor/agent-root/src/agent/tool/__test__/task-output-blocking.test.ts +0 -223
- package/vendor/agent-root/src/agent/tool/__test__/task-output.test.ts +0 -184
- package/vendor/agent-root/src/agent/tool/__test__/task-parent-abort.test.ts +0 -287
- package/vendor/agent-root/src/agent/tool/__test__/task-real-runner-adapter.test.ts +0 -190
- package/vendor/agent-root/src/agent/tool/__test__/task-run-lifecycle.test.ts +0 -352
- package/vendor/agent-root/src/agent/tool/__test__/task-store-runner-branches.test.ts +0 -395
- package/vendor/agent-root/src/agent/tool/__test__/task-store.test.ts +0 -391
- package/vendor/agent-root/src/agent/tool/__test__/task-subagent-config-integration.test.ts +0 -176
- package/vendor/agent-root/src/agent/tool/__test__/task-subagent-config.test.ts +0 -68
- package/vendor/agent-root/src/agent/tool/__test__/task-tools-core-edges.test.ts +0 -630
- package/vendor/agent-root/src/agent/tool/__test__/task-tools-runtime-edges.test.ts +0 -732
- package/vendor/agent-root/src/agent/tool/__test__/task-types.test.ts +0 -494
- package/vendor/agent-root/src/agent/tool/__test__/task-utils-branches.test.ts +0 -175
- package/vendor/agent-root/src/agent/tool/__test__/tool-manager.test.ts +0 -505
- package/vendor/agent-root/src/agent/tool/__test__/types.test.ts +0 -55
- package/vendor/agent-root/src/agent/tool/__test__/web-fetch.test.ts +0 -244
- package/vendor/agent-root/src/agent/tool/__test__/web-search.test.ts +0 -290
- package/vendor/agent-root/src/agent/tool/__test__/write-file.test.ts +0 -368
- package/vendor/agent-root/src/agent/tool/base-tool.ts +0 -345
- package/vendor/agent-root/src/agent/tool/bash-policy.ts +0 -636
- package/vendor/agent-root/src/agent/tool/bash.ts +0 -688
- package/vendor/agent-root/src/agent/tool/error.ts +0 -131
- package/vendor/agent-root/src/agent/tool/file-edit-tool.ts +0 -264
- package/vendor/agent-root/src/agent/tool/file-history-list.ts +0 -103
- package/vendor/agent-root/src/agent/tool/file-history-restore.ts +0 -149
- package/vendor/agent-root/src/agent/tool/file-read-tool.ts +0 -211
- package/vendor/agent-root/src/agent/tool/glob.ts +0 -171
- package/vendor/agent-root/src/agent/tool/grep.ts +0 -496
- package/vendor/agent-root/src/agent/tool/lsp.ts +0 -481
- package/vendor/agent-root/src/agent/tool/path-security.ts +0 -117
- package/vendor/agent-root/src/agent/tool/search/common.ts +0 -153
- package/vendor/agent-root/src/agent/tool/skill/index.ts +0 -13
- package/vendor/agent-root/src/agent/tool/skill/loader.ts +0 -229
- package/vendor/agent-root/src/agent/tool/skill/parser.ts +0 -124
- package/vendor/agent-root/src/agent/tool/skill/types.ts +0 -27
- package/vendor/agent-root/src/agent/tool/skill-tool.ts +0 -143
- package/vendor/agent-root/src/agent/tool/task-create.ts +0 -186
- package/vendor/agent-root/src/agent/tool/task-errors.ts +0 -42
- package/vendor/agent-root/src/agent/tool/task-get.ts +0 -116
- package/vendor/agent-root/src/agent/tool/task-graph.ts +0 -78
- package/vendor/agent-root/src/agent/tool/task-list.ts +0 -141
- package/vendor/agent-root/src/agent/tool/task-mock-runner-adapter.ts +0 -232
- package/vendor/agent-root/src/agent/tool/task-output.ts +0 -223
- package/vendor/agent-root/src/agent/tool/task-parent-abort.ts +0 -115
- package/vendor/agent-root/src/agent/tool/task-real-runner-adapter.ts +0 -336
- package/vendor/agent-root/src/agent/tool/task-runner-adapter.ts +0 -55
- package/vendor/agent-root/src/agent/tool/task-stop.ts +0 -187
- package/vendor/agent-root/src/agent/tool/task-store.ts +0 -217
- package/vendor/agent-root/src/agent/tool/task-subagent-config.ts +0 -149
- package/vendor/agent-root/src/agent/tool/task-types.ts +0 -264
- package/vendor/agent-root/src/agent/tool/task-update.ts +0 -315
- package/vendor/agent-root/src/agent/tool/task.ts +0 -209
- package/vendor/agent-root/src/agent/tool/tool-manager.ts +0 -361
- package/vendor/agent-root/src/agent/tool/tool-prompts.ts +0 -242
- package/vendor/agent-root/src/agent/tool/types.ts +0 -116
- package/vendor/agent-root/src/agent/tool/web-fetch.ts +0 -227
- package/vendor/agent-root/src/agent/tool/web-search.ts +0 -208
- package/vendor/agent-root/src/agent/tool/write-file.ts +0 -497
- package/vendor/agent-root/src/agent/types.ts +0 -232
- package/vendor/agent-root/src/agent/utils/__tests__/index.test.ts +0 -18
- package/vendor/agent-root/src/agent/utils/__tests__/message-utils.test.ts +0 -610
- package/vendor/agent-root/src/agent/utils/__tests__/message.test.ts +0 -223
- package/vendor/agent-root/src/agent/utils/__tests__/token.test.ts +0 -42
- package/vendor/agent-root/src/agent/utils/index.ts +0 -16
- package/vendor/agent-root/src/agent/utils/message.ts +0 -171
- package/vendor/agent-root/src/agent/utils/token.ts +0 -28
- package/vendor/agent-root/src/config/__tests__/load-config-to-env.test.ts +0 -238
- package/vendor/agent-root/src/config/__tests__/loader.test.ts +0 -361
- package/vendor/agent-root/src/config/__tests__/runtime.test.ts +0 -88
- package/vendor/agent-root/src/config/index.ts +0 -55
- package/vendor/agent-root/src/config/loader.ts +0 -494
- package/vendor/agent-root/src/config/paths.ts +0 -30
- package/vendor/agent-root/src/config/runtime.ts +0 -163
- package/vendor/agent-root/src/config/types.ts +0 -96
- package/vendor/agent-root/src/logger/index.ts +0 -57
- package/vendor/agent-root/src/logger/logger.ts +0 -819
- package/vendor/agent-root/src/logger/types.ts +0 -150
- package/vendor/agent-root/src/providers/__tests__/errors.test.ts +0 -441
- package/vendor/agent-root/src/providers/__tests__/index.test.ts +0 -16
- package/vendor/agent-root/src/providers/__tests__/openai-compatible.options.test.ts +0 -318
- package/vendor/agent-root/src/providers/__tests__/openai-compatible.test.ts +0 -600
- package/vendor/agent-root/src/providers/__tests__/registry.test.ts +0 -523
- package/vendor/agent-root/src/providers/__tests__/responses-adapter.test.ts +0 -298
- package/vendor/agent-root/src/providers/adapters/__tests__/anthropic.test.ts +0 -354
- package/vendor/agent-root/src/providers/adapters/__tests__/kimi.test.ts +0 -58
- package/vendor/agent-root/src/providers/adapters/__tests__/standard.test.ts +0 -261
- package/vendor/agent-root/src/providers/adapters/anthropic.ts +0 -572
- package/vendor/agent-root/src/providers/adapters/base.ts +0 -131
- package/vendor/agent-root/src/providers/adapters/kimi.ts +0 -48
- package/vendor/agent-root/src/providers/adapters/responses.ts +0 -732
- package/vendor/agent-root/src/providers/adapters/standard.ts +0 -120
- package/vendor/agent-root/src/providers/http/__tests__/client.timeout.test.ts +0 -313
- package/vendor/agent-root/src/providers/http/client.ts +0 -289
- package/vendor/agent-root/src/providers/http/stream-parser.ts +0 -109
- package/vendor/agent-root/src/providers/index.ts +0 -76
- package/vendor/agent-root/src/providers/kimi-headers.ts +0 -177
- package/vendor/agent-root/src/providers/openai-compatible.ts +0 -387
- package/vendor/agent-root/src/providers/registry/model-config.ts +0 -477
- package/vendor/agent-root/src/providers/registry/provider-factory.ts +0 -127
- package/vendor/agent-root/src/providers/registry.ts +0 -135
- package/vendor/agent-root/src/providers/types/api.ts +0 -284
- package/vendor/agent-root/src/providers/types/config.ts +0 -58
- package/vendor/agent-root/src/providers/types/errors.ts +0 -323
- package/vendor/agent-root/src/providers/types/index.ts +0 -72
- package/vendor/agent-root/src/providers/types/provider.ts +0 -45
- package/vendor/agent-root/src/providers/types/registry.ts +0 -68
|
@@ -1,225 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import { buildTaskFailure, buildTaskSuccess, parsePrefixedError } from '../task-errors';
|
|
3
|
-
import { ToolExecutionError } from '../error';
|
|
4
|
-
|
|
5
|
-
describe('buildTaskFailure', () => {
|
|
6
|
-
it('builds failure result with code and message', () => {
|
|
7
|
-
const result = buildTaskFailure('TASK_NOT_FOUND', 'Task not found');
|
|
8
|
-
|
|
9
|
-
expect(result.success).toBe(false);
|
|
10
|
-
expect(result.output).toBe('TASK_NOT_FOUND: Task not found');
|
|
11
|
-
expect(result.error).toBeInstanceOf(ToolExecutionError);
|
|
12
|
-
expect(result.error!.message).toBe('TASK_NOT_FOUND: Task not found');
|
|
13
|
-
expect(result.metadata).toEqual({
|
|
14
|
-
error: 'TASK_NOT_FOUND',
|
|
15
|
-
message: 'Task not found',
|
|
16
|
-
});
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
it('builds failure result with details', () => {
|
|
20
|
-
const result = buildTaskFailure('TASK_FAILED', 'Task failed', {
|
|
21
|
-
taskId: 'task_1',
|
|
22
|
-
retryCount: 3,
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
expect(result.success).toBe(false);
|
|
26
|
-
expect(result.output).toBe('TASK_FAILED: Task failed');
|
|
27
|
-
expect(result.metadata).toEqual({
|
|
28
|
-
error: 'TASK_FAILED',
|
|
29
|
-
message: 'Task failed',
|
|
30
|
-
taskId: 'task_1',
|
|
31
|
-
retryCount: 3,
|
|
32
|
-
});
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
it('builds failure result with empty details', () => {
|
|
36
|
-
const result = buildTaskFailure('ERROR', 'Error message', {});
|
|
37
|
-
|
|
38
|
-
expect(result.success).toBe(false);
|
|
39
|
-
expect(result.metadata).toEqual({
|
|
40
|
-
error: 'ERROR',
|
|
41
|
-
message: 'Error message',
|
|
42
|
-
});
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it('builds failure result with undefined details', () => {
|
|
46
|
-
const result = buildTaskFailure('ERROR', 'Error message', undefined);
|
|
47
|
-
|
|
48
|
-
expect(result.success).toBe(false);
|
|
49
|
-
expect(result.metadata).toEqual({
|
|
50
|
-
error: 'ERROR',
|
|
51
|
-
message: 'Error message',
|
|
52
|
-
});
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
it('handles empty code', () => {
|
|
56
|
-
const result = buildTaskFailure('', 'Error message');
|
|
57
|
-
|
|
58
|
-
expect(result.success).toBe(false);
|
|
59
|
-
expect(result.output).toBe(': Error message');
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it('handles empty message', () => {
|
|
63
|
-
const result = buildTaskFailure('ERROR', '');
|
|
64
|
-
|
|
65
|
-
expect(result.success).toBe(false);
|
|
66
|
-
expect(result.output).toBe('ERROR: ');
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
it('handles special characters in code and message', () => {
|
|
70
|
-
const result = buildTaskFailure('ERROR_CODE', 'Error: "test" & <value>');
|
|
71
|
-
|
|
72
|
-
expect(result.success).toBe(false);
|
|
73
|
-
expect(result.output).toBe('ERROR_CODE: Error: "test" & <value>');
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
describe('buildTaskSuccess', () => {
|
|
78
|
-
it('builds success result with payload', () => {
|
|
79
|
-
const payload = { taskId: 'task_1', status: 'completed' };
|
|
80
|
-
const result = buildTaskSuccess(payload);
|
|
81
|
-
|
|
82
|
-
expect(result.success).toBe(true);
|
|
83
|
-
expect(result.output).toBe(JSON.stringify(payload));
|
|
84
|
-
expect(result.metadata).toEqual(payload);
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
it('builds success result with empty payload', () => {
|
|
88
|
-
const result = buildTaskSuccess({});
|
|
89
|
-
|
|
90
|
-
expect(result.success).toBe(true);
|
|
91
|
-
expect(result.output).toBe('{}');
|
|
92
|
-
expect(result.metadata).toEqual({});
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
it('builds success result with nested payload', () => {
|
|
96
|
-
const payload = {
|
|
97
|
-
task: {
|
|
98
|
-
id: 'task_1',
|
|
99
|
-
status: 'completed',
|
|
100
|
-
result: { value: 42 },
|
|
101
|
-
},
|
|
102
|
-
};
|
|
103
|
-
const result = buildTaskSuccess(payload);
|
|
104
|
-
|
|
105
|
-
expect(result.success).toBe(true);
|
|
106
|
-
expect(result.output).toBe(JSON.stringify(payload));
|
|
107
|
-
expect(result.metadata).toEqual(payload);
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
it('builds success result with array payload', () => {
|
|
111
|
-
const payload = { items: [1, 2, 3] };
|
|
112
|
-
const result = buildTaskSuccess(payload);
|
|
113
|
-
|
|
114
|
-
expect(result.success).toBe(true);
|
|
115
|
-
expect(result.output).toBe(JSON.stringify(payload));
|
|
116
|
-
expect(result.metadata).toEqual(payload);
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it('builds success result with null values', () => {
|
|
120
|
-
const payload = { value: null, other: undefined };
|
|
121
|
-
const result = buildTaskSuccess(payload);
|
|
122
|
-
|
|
123
|
-
expect(result.success).toBe(true);
|
|
124
|
-
// undefined values are omitted in JSON.stringify
|
|
125
|
-
expect(result.output).toBe('{"value":null}');
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
it('builds success result with special characters', () => {
|
|
129
|
-
const payload = { message: 'Success: "test" & <value>' };
|
|
130
|
-
const result = buildTaskSuccess(payload);
|
|
131
|
-
|
|
132
|
-
expect(result.success).toBe(true);
|
|
133
|
-
expect(result.output).toBe(JSON.stringify(payload));
|
|
134
|
-
});
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
describe('parsePrefixedError', () => {
|
|
138
|
-
it('parses error with code prefix', () => {
|
|
139
|
-
const result = parsePrefixedError('TASK_NOT_FOUND: Task not found');
|
|
140
|
-
|
|
141
|
-
expect(result.code).toBe('TASK_NOT_FOUND');
|
|
142
|
-
expect(result.detail).toBe('Task not found');
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
it('parses error with complex code', () => {
|
|
146
|
-
const result = parsePrefixedError(
|
|
147
|
-
'TASK_INVALID_NAMESPACE: namespace allows only [a-zA-Z0-9._-]'
|
|
148
|
-
);
|
|
149
|
-
|
|
150
|
-
expect(result.code).toBe('TASK_INVALID_NAMESPACE');
|
|
151
|
-
expect(result.detail).toBe('namespace allows only [a-zA-Z0-9._-]');
|
|
152
|
-
});
|
|
153
|
-
|
|
154
|
-
it('parses error with numbers in code', () => {
|
|
155
|
-
const result = parsePrefixedError('ERROR_404: Not found');
|
|
156
|
-
|
|
157
|
-
expect(result.code).toBe('ERROR_404');
|
|
158
|
-
expect(result.detail).toBe('Not found');
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
it('returns default for error without code prefix', () => {
|
|
162
|
-
const result = parsePrefixedError('Task not found');
|
|
163
|
-
|
|
164
|
-
expect(result.code).toBe('TASK_OPERATION_FAILED');
|
|
165
|
-
expect(result.detail).toBe('Task not found');
|
|
166
|
-
});
|
|
167
|
-
|
|
168
|
-
it('returns default for error with lowercase prefix', () => {
|
|
169
|
-
const result = parsePrefixedError('task_not_found: Task not found');
|
|
170
|
-
|
|
171
|
-
expect(result.code).toBe('TASK_OPERATION_FAILED');
|
|
172
|
-
expect(result.detail).toBe('task_not_found: Task not found');
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
it('returns default for error with short code', () => {
|
|
176
|
-
const result = parsePrefixedError('AB: Short code');
|
|
177
|
-
|
|
178
|
-
expect(result.code).toBe('TASK_OPERATION_FAILED');
|
|
179
|
-
expect(result.detail).toBe('AB: Short code');
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
it('returns default for empty string', () => {
|
|
183
|
-
const result = parsePrefixedError('');
|
|
184
|
-
|
|
185
|
-
expect(result.code).toBe('TASK_OPERATION_FAILED');
|
|
186
|
-
expect(result.detail).toBe('');
|
|
187
|
-
});
|
|
188
|
-
|
|
189
|
-
it('handles error with multiple colons', () => {
|
|
190
|
-
const result = parsePrefixedError('ERROR_CODE: Message: with colons');
|
|
191
|
-
|
|
192
|
-
expect(result.code).toBe('ERROR_CODE');
|
|
193
|
-
expect(result.detail).toBe('Message: with colons');
|
|
194
|
-
});
|
|
195
|
-
|
|
196
|
-
it('handles error with whitespace after colon', () => {
|
|
197
|
-
const result = parsePrefixedError('ERROR_CODE: Message with spaces');
|
|
198
|
-
|
|
199
|
-
expect(result.code).toBe('ERROR_CODE');
|
|
200
|
-
// \s* in regex matches all whitespace, so leading spaces are trimmed
|
|
201
|
-
expect(result.detail).toBe('Message with spaces');
|
|
202
|
-
});
|
|
203
|
-
|
|
204
|
-
it('handles error with no detail after colon', () => {
|
|
205
|
-
const result = parsePrefixedError('ERROR_CODE:');
|
|
206
|
-
|
|
207
|
-
expect(result.code).toBe('ERROR_CODE');
|
|
208
|
-
expect(result.detail).toBe('');
|
|
209
|
-
});
|
|
210
|
-
|
|
211
|
-
it('handles error with special characters in detail', () => {
|
|
212
|
-
const result = parsePrefixedError('ERROR_CODE: Error: "test" & <value>');
|
|
213
|
-
|
|
214
|
-
expect(result.code).toBe('ERROR_CODE');
|
|
215
|
-
expect(result.detail).toBe('Error: "test" & <value>');
|
|
216
|
-
});
|
|
217
|
-
|
|
218
|
-
it('handles error with newlines in detail', () => {
|
|
219
|
-
// The regex doesn't match newlines, so it returns default
|
|
220
|
-
const result = parsePrefixedError('ERROR_CODE: Line 1\nLine 2');
|
|
221
|
-
|
|
222
|
-
expect(result.code).toBe('TASK_OPERATION_FAILED');
|
|
223
|
-
expect(result.detail).toBe('ERROR_CODE: Line 1\nLine 2');
|
|
224
|
-
});
|
|
225
|
-
});
|
|
@@ -1,223 +0,0 @@
|
|
|
1
|
-
import * as os from 'node:os';
|
|
2
|
-
import * as path from 'node:path';
|
|
3
|
-
import { promises as fs } from 'node:fs';
|
|
4
|
-
import { afterEach, beforeEach, describe, expect, it } from 'vitest';
|
|
5
|
-
import { TaskStore } from '../task-store';
|
|
6
|
-
import { InProcessMockRunnerAdapter } from '../task-runner-adapter';
|
|
7
|
-
import { TaskTool } from '../task';
|
|
8
|
-
import { TaskOutputTool } from '../task-output';
|
|
9
|
-
import type { AgentRunEntity } from '../task-types';
|
|
10
|
-
import type { SubagentRunnerAdapter } from '../task-runner-adapter';
|
|
11
|
-
|
|
12
|
-
function parseOutput<T>(output: string | undefined): T {
|
|
13
|
-
return JSON.parse(output || '{}') as T;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
function makeRun(overrides: Partial<AgentRunEntity> = {}): AgentRunEntity {
|
|
17
|
-
const now = Date.now();
|
|
18
|
-
return {
|
|
19
|
-
agentId: overrides.agentId || 'agent-x',
|
|
20
|
-
status: overrides.status || 'running',
|
|
21
|
-
subagentType: overrides.subagentType || 'Plan',
|
|
22
|
-
prompt: overrides.prompt || 'p',
|
|
23
|
-
description: overrides.description,
|
|
24
|
-
model: overrides.model,
|
|
25
|
-
maxTurns: overrides.maxTurns,
|
|
26
|
-
allowedTools: overrides.allowedTools,
|
|
27
|
-
linkedTaskId: overrides.linkedTaskId,
|
|
28
|
-
output: overrides.output,
|
|
29
|
-
error: overrides.error,
|
|
30
|
-
progress: overrides.progress,
|
|
31
|
-
createdAt: overrides.createdAt || now,
|
|
32
|
-
startedAt: overrides.startedAt || now,
|
|
33
|
-
endedAt: overrides.endedAt,
|
|
34
|
-
updatedAt: overrides.updatedAt || now,
|
|
35
|
-
outputFile: overrides.outputFile,
|
|
36
|
-
metadata: overrides.metadata || {},
|
|
37
|
-
version: overrides.version || 1,
|
|
38
|
-
};
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
describe('task_output blocking semantics', () => {
|
|
42
|
-
let baseDir: string;
|
|
43
|
-
let store: TaskStore;
|
|
44
|
-
let runner: InProcessMockRunnerAdapter;
|
|
45
|
-
let taskTool: TaskTool;
|
|
46
|
-
let taskOutput: TaskOutputTool;
|
|
47
|
-
|
|
48
|
-
beforeEach(async () => {
|
|
49
|
-
baseDir = await fs.mkdtemp(path.join(os.tmpdir(), 'renx-task-output-'));
|
|
50
|
-
store = new TaskStore({ baseDir });
|
|
51
|
-
runner = new InProcessMockRunnerAdapter(store, { completionDelayMs: 200 });
|
|
52
|
-
taskTool = new TaskTool({ store, runner });
|
|
53
|
-
taskOutput = new TaskOutputTool({ store, runner });
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
afterEach(async () => {
|
|
57
|
-
await fs.rm(baseDir, { recursive: true, force: true });
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
it('uses block=true by default when block is omitted', async () => {
|
|
61
|
-
const started = await taskTool.execute({
|
|
62
|
-
namespace: 'out1',
|
|
63
|
-
subagent_type: 'general-purpose',
|
|
64
|
-
prompt: 'Default blocking behavior check',
|
|
65
|
-
run_in_background: true,
|
|
66
|
-
});
|
|
67
|
-
const run = parseOutput<{ agent_run: { agentId: string } }>(started.output).agent_run;
|
|
68
|
-
|
|
69
|
-
const t0 = Date.now();
|
|
70
|
-
const result = await taskOutput.execute({
|
|
71
|
-
namespace: 'out1',
|
|
72
|
-
agent_id: run.agentId,
|
|
73
|
-
timeout_ms: 3000,
|
|
74
|
-
});
|
|
75
|
-
const elapsed = Date.now() - t0;
|
|
76
|
-
|
|
77
|
-
expect(result.success).toBe(true);
|
|
78
|
-
const payload = parseOutput<{ completed: boolean; agent_run: { status: string } }>(
|
|
79
|
-
result.output
|
|
80
|
-
);
|
|
81
|
-
expect(payload.completed).toBe(true);
|
|
82
|
-
expect(payload.agent_run.status).toBe('completed');
|
|
83
|
-
expect(elapsed).toBeGreaterThanOrEqual(120);
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
it('returns quickly in non-blocking mode and can report running state', async () => {
|
|
87
|
-
const started = await taskTool.execute({
|
|
88
|
-
namespace: 'out2',
|
|
89
|
-
subagent_type: 'general-purpose',
|
|
90
|
-
prompt: 'Non-blocking behavior check',
|
|
91
|
-
run_in_background: true,
|
|
92
|
-
});
|
|
93
|
-
const run = parseOutput<{ agent_run: { agentId: string } }>(started.output).agent_run;
|
|
94
|
-
|
|
95
|
-
const t0 = Date.now();
|
|
96
|
-
const result = await taskOutput.execute({
|
|
97
|
-
namespace: 'out2',
|
|
98
|
-
agent_id: run.agentId,
|
|
99
|
-
block: false,
|
|
100
|
-
});
|
|
101
|
-
const elapsed = Date.now() - t0;
|
|
102
|
-
|
|
103
|
-
expect(result.success).toBe(true);
|
|
104
|
-
const payload = parseOutput<{ agent_run: { status: string; output?: string } }>(result.output);
|
|
105
|
-
expect(['running', 'completed']).toContain(payload.agent_run.status);
|
|
106
|
-
if (payload.agent_run.status === 'running') {
|
|
107
|
-
expect(payload.agent_run.output).toBeUndefined();
|
|
108
|
-
}
|
|
109
|
-
expect(elapsed).toBeLessThan(120);
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
it('hides output for in-progress run but keeps completion output', async () => {
|
|
113
|
-
const partialRunner: SubagentRunnerAdapter = {
|
|
114
|
-
start: async () => makeRun(),
|
|
115
|
-
poll: async (_namespace, agentId) => {
|
|
116
|
-
if (agentId === 'agent-running') {
|
|
117
|
-
return makeRun({
|
|
118
|
-
agentId,
|
|
119
|
-
status: 'running',
|
|
120
|
-
output: 'partial content',
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
return makeRun({
|
|
124
|
-
agentId,
|
|
125
|
-
status: 'completed',
|
|
126
|
-
output: 'final content',
|
|
127
|
-
endedAt: Date.now(),
|
|
128
|
-
});
|
|
129
|
-
},
|
|
130
|
-
cancel: async () => null,
|
|
131
|
-
};
|
|
132
|
-
|
|
133
|
-
const outputTool = new TaskOutputTool({ store, runner: partialRunner });
|
|
134
|
-
|
|
135
|
-
const running = await outputTool.execute({
|
|
136
|
-
namespace: 'out3',
|
|
137
|
-
agent_id: 'agent-running',
|
|
138
|
-
block: false,
|
|
139
|
-
});
|
|
140
|
-
const runningPayload = parseOutput<{ agent_run: { status: string; output?: string } }>(
|
|
141
|
-
running.output
|
|
142
|
-
);
|
|
143
|
-
expect(runningPayload.agent_run.status).toBe('running');
|
|
144
|
-
expect(runningPayload.agent_run.output).toBeUndefined();
|
|
145
|
-
|
|
146
|
-
const completed = await outputTool.execute({
|
|
147
|
-
namespace: 'out3',
|
|
148
|
-
agent_id: 'agent-completed',
|
|
149
|
-
block: false,
|
|
150
|
-
});
|
|
151
|
-
const completedPayload = parseOutput<{ agent_run: { status: string; output?: string } }>(
|
|
152
|
-
completed.output
|
|
153
|
-
);
|
|
154
|
-
expect(completedPayload.agent_run.status).toBe('completed');
|
|
155
|
-
expect(completedPayload.agent_run.output).toBe('final content');
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
it('reports failure to parent agent and never leaks failed output', async () => {
|
|
159
|
-
const failedRunner: SubagentRunnerAdapter = {
|
|
160
|
-
start: async () => makeRun(),
|
|
161
|
-
poll: async () =>
|
|
162
|
-
makeRun({
|
|
163
|
-
agentId: 'agent-failed',
|
|
164
|
-
status: 'failed',
|
|
165
|
-
output: 'internal stack trace',
|
|
166
|
-
error: 'compile failed',
|
|
167
|
-
endedAt: Date.now(),
|
|
168
|
-
}),
|
|
169
|
-
cancel: async () => null,
|
|
170
|
-
};
|
|
171
|
-
const outputTool = new TaskOutputTool({ store, runner: failedRunner });
|
|
172
|
-
const failed = await outputTool.execute({
|
|
173
|
-
namespace: 'out4',
|
|
174
|
-
agent_id: 'agent-failed',
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
expect(failed.success).toBe(true);
|
|
178
|
-
const payload = parseOutput<{
|
|
179
|
-
completed: boolean;
|
|
180
|
-
agent_run: { status: string; output?: string; error?: string };
|
|
181
|
-
}>(failed.output);
|
|
182
|
-
expect(payload.completed).toBe(true);
|
|
183
|
-
expect(payload.agent_run.status).toBe('failed');
|
|
184
|
-
expect(payload.agent_run.output).toBeUndefined();
|
|
185
|
-
expect(payload.agent_run.error).toBe('compile failed');
|
|
186
|
-
});
|
|
187
|
-
|
|
188
|
-
it('fills default error text for terminal failed/timed_out/cancelled without error', async () => {
|
|
189
|
-
const statuses: Array<'failed' | 'timed_out' | 'cancelled'> = [
|
|
190
|
-
'failed',
|
|
191
|
-
'timed_out',
|
|
192
|
-
'cancelled',
|
|
193
|
-
];
|
|
194
|
-
|
|
195
|
-
for (const status of statuses) {
|
|
196
|
-
const runnerWithoutError: SubagentRunnerAdapter = {
|
|
197
|
-
start: async () => makeRun(),
|
|
198
|
-
poll: async () =>
|
|
199
|
-
makeRun({
|
|
200
|
-
agentId: `agent-${status}`,
|
|
201
|
-
status,
|
|
202
|
-
output: 'must hide',
|
|
203
|
-
error: undefined,
|
|
204
|
-
endedAt: Date.now(),
|
|
205
|
-
}),
|
|
206
|
-
cancel: async () => null,
|
|
207
|
-
};
|
|
208
|
-
|
|
209
|
-
const outputTool = new TaskOutputTool({ store, runner: runnerWithoutError });
|
|
210
|
-
const result = await outputTool.execute({
|
|
211
|
-
namespace: 'out5',
|
|
212
|
-
agent_id: `agent-${status}`,
|
|
213
|
-
});
|
|
214
|
-
|
|
215
|
-
const payload = parseOutput<{
|
|
216
|
-
agent_run: { status: string; output?: string; error?: string };
|
|
217
|
-
}>(result.output);
|
|
218
|
-
expect(payload.agent_run.status).toBe(status);
|
|
219
|
-
expect(payload.agent_run.output).toBeUndefined();
|
|
220
|
-
expect(payload.agent_run.error).toBe(`Agent run ${status}`);
|
|
221
|
-
}
|
|
222
|
-
});
|
|
223
|
-
});
|
|
@@ -1,184 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it, beforeEach, afterEach } from 'vitest';
|
|
2
|
-
import * as fs from 'node:fs/promises';
|
|
3
|
-
import * as os from 'node:os';
|
|
4
|
-
import * as path from 'node:path';
|
|
5
|
-
import { TaskOutputTool } from '../task-output';
|
|
6
|
-
import { TaskStore } from '../task-store';
|
|
7
|
-
import type { ToolExecutionContext } from '../types';
|
|
8
|
-
|
|
9
|
-
describe('TaskOutputTool', () => {
|
|
10
|
-
let tempDir: string;
|
|
11
|
-
let store: TaskStore;
|
|
12
|
-
let tool: TaskOutputTool;
|
|
13
|
-
|
|
14
|
-
beforeEach(async () => {
|
|
15
|
-
tempDir = await fs.mkdtemp(path.join(os.tmpdir(), 'task-output-test-'));
|
|
16
|
-
store = new TaskStore({ baseDir: tempDir });
|
|
17
|
-
tool = new TaskOutputTool({ store });
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
afterEach(async () => {
|
|
21
|
-
await fs.rm(tempDir, { recursive: true, force: true });
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
describe('name and description', () => {
|
|
25
|
-
it('has correct name', () => {
|
|
26
|
-
expect(tool.name).toBe('task_output');
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
it('has description', () => {
|
|
30
|
-
expect(tool.description).toBeTruthy();
|
|
31
|
-
});
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
describe('parameters', () => {
|
|
35
|
-
it('has task_id parameter', () => {
|
|
36
|
-
const schema = tool.parameters;
|
|
37
|
-
expect(schema).toBeDefined();
|
|
38
|
-
});
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
describe('execute', () => {
|
|
42
|
-
it('returns error when neither agent_id nor task_id is provided', async () => {
|
|
43
|
-
const result = await tool.execute({});
|
|
44
|
-
|
|
45
|
-
expect(result.success).toBe(false);
|
|
46
|
-
expect(result.output).toContain('TASK_OUTPUT_TARGET_REQUIRED');
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it('returns error for non-existent task', async () => {
|
|
50
|
-
const result = await tool.execute({ task_id: 'non-existent' });
|
|
51
|
-
|
|
52
|
-
expect(result.success).toBe(false);
|
|
53
|
-
expect(result.output).toContain('TASK_NOT_FOUND');
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
it('returns error for task without linked agent run', async () => {
|
|
57
|
-
await store.updateState('default', (state) => {
|
|
58
|
-
state.tasks.task_1 = {
|
|
59
|
-
id: 'task_1',
|
|
60
|
-
subject: 'Test Task',
|
|
61
|
-
description: 'Test description',
|
|
62
|
-
activeForm: 'Testing',
|
|
63
|
-
status: 'pending',
|
|
64
|
-
priority: 'normal',
|
|
65
|
-
owner: null,
|
|
66
|
-
blockedBy: [],
|
|
67
|
-
blocks: [],
|
|
68
|
-
progress: 0,
|
|
69
|
-
checkpoints: [],
|
|
70
|
-
retryConfig: { maxRetries: 3, retryDelayMs: 5000, backoffMultiplier: 2, retryOn: [] },
|
|
71
|
-
retryCount: 0,
|
|
72
|
-
tags: [],
|
|
73
|
-
metadata: {},
|
|
74
|
-
history: [],
|
|
75
|
-
createdAt: Date.now(),
|
|
76
|
-
updatedAt: Date.now(),
|
|
77
|
-
version: 1,
|
|
78
|
-
};
|
|
79
|
-
return 'created';
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
const result = await tool.execute({ task_id: 'task_1' });
|
|
83
|
-
|
|
84
|
-
expect(result.success).toBe(false);
|
|
85
|
-
expect(result.output).toContain('AGENT_RUN_NOT_FOUND');
|
|
86
|
-
});
|
|
87
|
-
|
|
88
|
-
it('returns error for non-existent agent run', async () => {
|
|
89
|
-
const result = await tool.execute({ agent_id: 'non-existent', block: false });
|
|
90
|
-
|
|
91
|
-
expect(result.success).toBe(false);
|
|
92
|
-
expect(result.output).toContain('AGENT_RUN_NOT_FOUND');
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
it('handles task with context', async () => {
|
|
96
|
-
const context: ToolExecutionContext = {
|
|
97
|
-
toolCallId: 'call_1',
|
|
98
|
-
loopIndex: 1,
|
|
99
|
-
agent: {},
|
|
100
|
-
};
|
|
101
|
-
|
|
102
|
-
const result = await tool.execute({ task_id: 'non-existent' }, context);
|
|
103
|
-
|
|
104
|
-
expect(result.success).toBe(false);
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
it('handles task with invalid task_id parameter', async () => {
|
|
108
|
-
const result = await tool.execute({ task_id: '' });
|
|
109
|
-
|
|
110
|
-
expect(result.success).toBe(false);
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
it('handles task with namespace', async () => {
|
|
114
|
-
const result = await tool.execute({ task_id: 'non-existent', namespace: 'custom' });
|
|
115
|
-
|
|
116
|
-
expect(result.success).toBe(false);
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it('handles task with block=false', async () => {
|
|
120
|
-
const result = await tool.execute({ agent_id: 'non-existent', block: false });
|
|
121
|
-
|
|
122
|
-
expect(result.success).toBe(false);
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
it('handles task with timeout_ms', async () => {
|
|
126
|
-
const result = await tool.execute({ agent_id: 'non-existent', timeout_ms: 1000 });
|
|
127
|
-
|
|
128
|
-
expect(result.success).toBe(false);
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
it('handles task with poll_interval_ms', async () => {
|
|
132
|
-
const result = await tool.execute({ agent_id: 'non-existent', poll_interval_ms: 100 });
|
|
133
|
-
|
|
134
|
-
expect(result.success).toBe(false);
|
|
135
|
-
});
|
|
136
|
-
});
|
|
137
|
-
|
|
138
|
-
describe('shouldConfirm', () => {
|
|
139
|
-
it('returns false', () => {
|
|
140
|
-
expect(tool.shouldConfirm({ task_id: 'task_1' })).toBe(false);
|
|
141
|
-
});
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
describe('getConfirmDetails', () => {
|
|
145
|
-
it('returns null', () => {
|
|
146
|
-
expect(tool.getConfirmDetails({ task_id: 'task_1' })).toBeNull();
|
|
147
|
-
});
|
|
148
|
-
});
|
|
149
|
-
|
|
150
|
-
describe('getConcurrencyMode', () => {
|
|
151
|
-
it('returns parallel-safe', () => {
|
|
152
|
-
expect(tool.getConcurrencyMode()).toBe('parallel-safe');
|
|
153
|
-
});
|
|
154
|
-
});
|
|
155
|
-
|
|
156
|
-
describe('getConcurrencyLockKey', () => {
|
|
157
|
-
it('returns lock key based on task_id', () => {
|
|
158
|
-
expect(tool.getConcurrencyLockKey({ task_id: 'task_1' })).toBe('taskns:default:agent:task_1');
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
it('returns different lock keys for different task_ids', () => {
|
|
162
|
-
expect(tool.getConcurrencyLockKey({ task_id: 'task_1' })).not.toBe(
|
|
163
|
-
tool.getConcurrencyLockKey({ task_id: 'task_2' })
|
|
164
|
-
);
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
it('returns lock key based on agent_id', () => {
|
|
168
|
-
expect(tool.getConcurrencyLockKey({ agent_id: 'agent_1' })).toBe(
|
|
169
|
-
'taskns:default:agent:agent_1'
|
|
170
|
-
);
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
it('returns lock key with custom namespace', () => {
|
|
174
|
-
const tool = new TaskOutputTool({ store, defaultNamespace: 'custom' });
|
|
175
|
-
expect(tool.getConcurrencyLockKey({ task_id: 'task_1' })).toBe('taskns:custom:agent:task_1');
|
|
176
|
-
});
|
|
177
|
-
|
|
178
|
-
it('returns lock key with namespace from args', () => {
|
|
179
|
-
expect(tool.getConcurrencyLockKey({ task_id: 'task_1', namespace: 'custom' })).toBe(
|
|
180
|
-
'taskns:custom:agent:task_1'
|
|
181
|
-
);
|
|
182
|
-
});
|
|
183
|
-
});
|
|
184
|
-
});
|