@renxqoo/renx-code 0.0.9 → 0.0.10
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 +14 -0
- 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,377 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import { isAbortError, normalizeError, calculateRetryDelay } from '../error-normalizer';
|
|
3
|
-
import {
|
|
4
|
-
LLMAbortedError,
|
|
5
|
-
LLMAuthError,
|
|
6
|
-
LLMBadRequestError,
|
|
7
|
-
LLMError,
|
|
8
|
-
LLMNotFoundError,
|
|
9
|
-
LLMPermanentError,
|
|
10
|
-
LLMRateLimitError,
|
|
11
|
-
LLMRetryableError,
|
|
12
|
-
} from '../../../providers';
|
|
13
|
-
import {
|
|
14
|
-
AgentUpstreamAuthError,
|
|
15
|
-
AgentUpstreamBadRequestError,
|
|
16
|
-
AgentUpstreamError,
|
|
17
|
-
AgentUpstreamNetworkError,
|
|
18
|
-
AgentUpstreamNotFoundError,
|
|
19
|
-
AgentUpstreamPermanentError,
|
|
20
|
-
AgentUpstreamRateLimitError,
|
|
21
|
-
AgentUpstreamRetryableError,
|
|
22
|
-
AgentUpstreamServerError,
|
|
23
|
-
AgentUpstreamTimeoutError,
|
|
24
|
-
AgentAbortedError,
|
|
25
|
-
AgentError,
|
|
26
|
-
ConfirmationTimeoutError,
|
|
27
|
-
UnknownError,
|
|
28
|
-
} from '../error';
|
|
29
|
-
|
|
30
|
-
describe('isAbortError', () => {
|
|
31
|
-
it('returns true for AbortError name', () => {
|
|
32
|
-
const error = { name: 'AbortError', message: 'aborted' };
|
|
33
|
-
expect(isAbortError(error, 'aborted')).toBe(true);
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
it('returns true for matching aborted message', () => {
|
|
37
|
-
const error = { name: 'Error', message: 'Operation aborted' };
|
|
38
|
-
expect(isAbortError(error, 'Operation aborted')).toBe(true);
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
it('returns false for non-abort errors', () => {
|
|
42
|
-
expect(isAbortError(new Error('other'), 'aborted')).toBe(false);
|
|
43
|
-
expect(isAbortError(null, 'aborted')).toBe(false);
|
|
44
|
-
expect(isAbortError(undefined, 'aborted')).toBe(false);
|
|
45
|
-
expect(isAbortError('string', 'aborted')).toBe(false);
|
|
46
|
-
expect(isAbortError(123, 'aborted')).toBe(false);
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it('returns false for object without name or message', () => {
|
|
50
|
-
expect(isAbortError({}, 'aborted')).toBe(false);
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
describe('normalizeError', () => {
|
|
55
|
-
const abortedMessage = 'Operation aborted';
|
|
56
|
-
|
|
57
|
-
it('returns AgentError unchanged', () => {
|
|
58
|
-
const agentError = new AgentError('test');
|
|
59
|
-
expect(normalizeError(agentError, abortedMessage)).toBe(agentError);
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it('converts abort error to AgentAbortedError', () => {
|
|
63
|
-
const error = { name: 'AbortError', message: 'aborted' };
|
|
64
|
-
const result = normalizeError(error, abortedMessage);
|
|
65
|
-
|
|
66
|
-
expect(result).toBeInstanceOf(AgentAbortedError);
|
|
67
|
-
expect(result.message).toBe(abortedMessage);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
it('converts LLMAbortedError to AgentAbortedError', () => {
|
|
71
|
-
const error = new LLMAbortedError('llm aborted');
|
|
72
|
-
const result = normalizeError(error, abortedMessage);
|
|
73
|
-
|
|
74
|
-
expect(result).toBeInstanceOf(AgentAbortedError);
|
|
75
|
-
expect(result.message).toBe('llm aborted');
|
|
76
|
-
});
|
|
77
|
-
|
|
78
|
-
it('converts LLMAbortedError with empty message to default', () => {
|
|
79
|
-
const error = new LLMAbortedError('');
|
|
80
|
-
const result = normalizeError(error, abortedMessage);
|
|
81
|
-
|
|
82
|
-
expect(result).toBeInstanceOf(AgentAbortedError);
|
|
83
|
-
expect(result.message).toBe(abortedMessage);
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
it('converts LLMRateLimitError to AgentUpstreamRateLimitError', () => {
|
|
87
|
-
const error = new LLMRateLimitError('rate limited');
|
|
88
|
-
const result = normalizeError(error, abortedMessage);
|
|
89
|
-
|
|
90
|
-
expect(result).toBeInstanceOf(AgentUpstreamRateLimitError);
|
|
91
|
-
expect(result.message).toBe('rate limited');
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('converts LLMAuthError to AgentUpstreamAuthError', () => {
|
|
95
|
-
const error = new LLMAuthError('auth failed');
|
|
96
|
-
const result = normalizeError(error, abortedMessage);
|
|
97
|
-
|
|
98
|
-
expect(result).toBeInstanceOf(AgentUpstreamAuthError);
|
|
99
|
-
expect(result.message).toBe('auth failed');
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
it('converts LLMNotFoundError to AgentUpstreamNotFoundError', () => {
|
|
103
|
-
const error = new LLMNotFoundError('not found');
|
|
104
|
-
const result = normalizeError(error, abortedMessage);
|
|
105
|
-
|
|
106
|
-
expect(result).toBeInstanceOf(AgentUpstreamNotFoundError);
|
|
107
|
-
expect(result.message).toBe('not found');
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
it('converts LLMBadRequestError to AgentUpstreamBadRequestError', () => {
|
|
111
|
-
const error = new LLMBadRequestError('bad request');
|
|
112
|
-
const result = normalizeError(error, abortedMessage);
|
|
113
|
-
|
|
114
|
-
expect(result).toBeInstanceOf(AgentUpstreamBadRequestError);
|
|
115
|
-
expect(result.message).toBe('bad request');
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
it('converts LLMRetryableError with RATE_LIMIT code', () => {
|
|
119
|
-
const error = new LLMRetryableError('rate limit', undefined, 'RATE_LIMIT');
|
|
120
|
-
const result = normalizeError(error, abortedMessage);
|
|
121
|
-
|
|
122
|
-
expect(result).toBeInstanceOf(AgentUpstreamRateLimitError);
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
it('converts LLMRetryableError with TIMEOUT code', () => {
|
|
126
|
-
const error = new LLMRetryableError('timeout', undefined, 'TIMEOUT');
|
|
127
|
-
const result = normalizeError(error, abortedMessage);
|
|
128
|
-
|
|
129
|
-
expect(result).toBeInstanceOf(AgentUpstreamTimeoutError);
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
it('converts LLMRetryableError with BODY_TIMEOUT code', () => {
|
|
133
|
-
const error = new LLMRetryableError('body timeout', undefined, 'BODY_TIMEOUT');
|
|
134
|
-
const result = normalizeError(error, abortedMessage);
|
|
135
|
-
|
|
136
|
-
expect(result).toBeInstanceOf(AgentUpstreamTimeoutError);
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
it('converts LLMRetryableError with NETWORK_ERROR code', () => {
|
|
140
|
-
const error = new LLMRetryableError('network error', undefined, 'NETWORK_ERROR');
|
|
141
|
-
const result = normalizeError(error, abortedMessage);
|
|
142
|
-
|
|
143
|
-
expect(result).toBeInstanceOf(AgentUpstreamNetworkError);
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
it('converts LLMRetryableError with SERVER_500 code', () => {
|
|
147
|
-
const error = new LLMRetryableError('server error', undefined, 'SERVER_500');
|
|
148
|
-
const result = normalizeError(error, abortedMessage);
|
|
149
|
-
|
|
150
|
-
expect(result).toBeInstanceOf(AgentUpstreamServerError);
|
|
151
|
-
});
|
|
152
|
-
|
|
153
|
-
it('converts LLMRetryableError with unknown code to AgentUpstreamRetryableError', () => {
|
|
154
|
-
const error = new LLMRetryableError('retryable', undefined, 'UNKNOWN');
|
|
155
|
-
const result = normalizeError(error, abortedMessage);
|
|
156
|
-
|
|
157
|
-
expect(result).toBeInstanceOf(AgentUpstreamRetryableError);
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
it('infers network retryable errors from message when code is missing', () => {
|
|
161
|
-
const error = new LLMRetryableError(
|
|
162
|
-
'Network connection lost. (chunk: gen-1773295956-gHGwhy1zWdrqK3KOjVOl)'
|
|
163
|
-
);
|
|
164
|
-
const result = normalizeError(error, abortedMessage);
|
|
165
|
-
|
|
166
|
-
expect(result).toBeInstanceOf(AgentUpstreamNetworkError);
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
it('infers timeout retryable errors from message when code is missing', () => {
|
|
170
|
-
const error = new LLMRetryableError('Request timed out while streaming response');
|
|
171
|
-
const result = normalizeError(error, abortedMessage);
|
|
172
|
-
|
|
173
|
-
expect(result).toBeInstanceOf(AgentUpstreamTimeoutError);
|
|
174
|
-
});
|
|
175
|
-
|
|
176
|
-
it('converts LLMPermanentError to AgentUpstreamPermanentError', () => {
|
|
177
|
-
const error = new LLMPermanentError('permanent');
|
|
178
|
-
const result = normalizeError(error, abortedMessage);
|
|
179
|
-
|
|
180
|
-
expect(result).toBeInstanceOf(AgentUpstreamPermanentError);
|
|
181
|
-
expect(result.message).toBe('permanent');
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
it('converts LLMError with ABORTED code', () => {
|
|
185
|
-
const error = new LLMError('aborted', 'ABORTED');
|
|
186
|
-
const result = normalizeError(error, abortedMessage);
|
|
187
|
-
|
|
188
|
-
expect(result).toBeInstanceOf(AgentAbortedError);
|
|
189
|
-
});
|
|
190
|
-
|
|
191
|
-
it('converts LLMError with AUTH_FAILED code', () => {
|
|
192
|
-
const error = new LLMError('auth failed', 'AUTH_FAILED');
|
|
193
|
-
const result = normalizeError(error, abortedMessage);
|
|
194
|
-
|
|
195
|
-
expect(result).toBeInstanceOf(AgentUpstreamAuthError);
|
|
196
|
-
});
|
|
197
|
-
|
|
198
|
-
it('converts LLMError with NOT_FOUND code', () => {
|
|
199
|
-
const error = new LLMError('not found', 'NOT_FOUND');
|
|
200
|
-
const result = normalizeError(error, abortedMessage);
|
|
201
|
-
|
|
202
|
-
expect(result).toBeInstanceOf(AgentUpstreamNotFoundError);
|
|
203
|
-
});
|
|
204
|
-
|
|
205
|
-
it('converts LLMError with BAD_REQUEST code', () => {
|
|
206
|
-
const error = new LLMError('bad request', 'BAD_REQUEST');
|
|
207
|
-
const result = normalizeError(error, abortedMessage);
|
|
208
|
-
|
|
209
|
-
expect(result).toBeInstanceOf(AgentUpstreamBadRequestError);
|
|
210
|
-
});
|
|
211
|
-
|
|
212
|
-
it('converts LLMError with RATE_LIMIT code', () => {
|
|
213
|
-
const error = new LLMError('rate limit', 'RATE_LIMIT');
|
|
214
|
-
const result = normalizeError(error, abortedMessage);
|
|
215
|
-
|
|
216
|
-
expect(result).toBeInstanceOf(AgentUpstreamRateLimitError);
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
it('converts LLMError with TIMEOUT code', () => {
|
|
220
|
-
const error = new LLMError('timeout', 'TIMEOUT');
|
|
221
|
-
const result = normalizeError(error, abortedMessage);
|
|
222
|
-
|
|
223
|
-
expect(result).toBeInstanceOf(AgentUpstreamTimeoutError);
|
|
224
|
-
});
|
|
225
|
-
|
|
226
|
-
it('converts LLMError with BODY_TIMEOUT code', () => {
|
|
227
|
-
const error = new LLMError('body timeout', 'BODY_TIMEOUT');
|
|
228
|
-
const result = normalizeError(error, abortedMessage);
|
|
229
|
-
|
|
230
|
-
expect(result).toBeInstanceOf(AgentUpstreamTimeoutError);
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
it('converts LLMError with NETWORK_ERROR code', () => {
|
|
234
|
-
const error = new LLMError('network error', 'NETWORK_ERROR');
|
|
235
|
-
const result = normalizeError(error, abortedMessage);
|
|
236
|
-
|
|
237
|
-
expect(result).toBeInstanceOf(AgentUpstreamNetworkError);
|
|
238
|
-
});
|
|
239
|
-
|
|
240
|
-
it('converts LLMError with SERVER_500 code', () => {
|
|
241
|
-
const error = new LLMError('server error', 'SERVER_500');
|
|
242
|
-
const result = normalizeError(error, abortedMessage);
|
|
243
|
-
|
|
244
|
-
expect(result).toBeInstanceOf(AgentUpstreamServerError);
|
|
245
|
-
});
|
|
246
|
-
|
|
247
|
-
it('converts LLMError with unknown code to AgentUpstreamError', () => {
|
|
248
|
-
const error = new LLMError('unknown', 'UNKNOWN');
|
|
249
|
-
const result = normalizeError(error, abortedMessage);
|
|
250
|
-
|
|
251
|
-
expect(result).toBeInstanceOf(AgentUpstreamError);
|
|
252
|
-
});
|
|
253
|
-
|
|
254
|
-
it('converts LLMError with empty message to default', () => {
|
|
255
|
-
const error = new LLMError('', 'UNKNOWN');
|
|
256
|
-
const result = normalizeError(error, abortedMessage);
|
|
257
|
-
|
|
258
|
-
expect(result).toBeInstanceOf(AgentUpstreamError);
|
|
259
|
-
});
|
|
260
|
-
|
|
261
|
-
it('converts ConfirmationTimeoutError', () => {
|
|
262
|
-
const error = new Error('Confirmation timeout');
|
|
263
|
-
error.name = 'ConfirmationTimeoutError';
|
|
264
|
-
const result = normalizeError(error, abortedMessage);
|
|
265
|
-
|
|
266
|
-
expect(result).toBeInstanceOf(ConfirmationTimeoutError);
|
|
267
|
-
});
|
|
268
|
-
|
|
269
|
-
it('converts Error with Confirmation timeout message', () => {
|
|
270
|
-
const error = new Error('Confirmation timeout');
|
|
271
|
-
const result = normalizeError(error, abortedMessage);
|
|
272
|
-
|
|
273
|
-
expect(result).toBeInstanceOf(ConfirmationTimeoutError);
|
|
274
|
-
});
|
|
275
|
-
|
|
276
|
-
it('converts plain network Error to AgentUpstreamNetworkError', () => {
|
|
277
|
-
const error = new Error('transient network failure');
|
|
278
|
-
const result = normalizeError(error, abortedMessage);
|
|
279
|
-
|
|
280
|
-
expect(result).toBeInstanceOf(AgentUpstreamNetworkError);
|
|
281
|
-
expect(result.retryable).toBe(true);
|
|
282
|
-
});
|
|
283
|
-
|
|
284
|
-
it('converts plain timeout Error to AgentUpstreamTimeoutError', () => {
|
|
285
|
-
const error = new Error('request timed out');
|
|
286
|
-
const result = normalizeError(error, abortedMessage);
|
|
287
|
-
|
|
288
|
-
expect(result).toBeInstanceOf(AgentUpstreamTimeoutError);
|
|
289
|
-
expect(result.retryable).toBe(true);
|
|
290
|
-
});
|
|
291
|
-
|
|
292
|
-
it('converts generic Error to UnknownError', () => {
|
|
293
|
-
const error = new Error('generic error');
|
|
294
|
-
const result = normalizeError(error, abortedMessage);
|
|
295
|
-
|
|
296
|
-
expect(result).toBeInstanceOf(UnknownError);
|
|
297
|
-
expect(result.message).toBe('generic error');
|
|
298
|
-
});
|
|
299
|
-
|
|
300
|
-
it('converts Error with empty message to default UnknownError', () => {
|
|
301
|
-
const error = new Error('');
|
|
302
|
-
const result = normalizeError(error, abortedMessage);
|
|
303
|
-
|
|
304
|
-
expect(result).toBeInstanceOf(UnknownError);
|
|
305
|
-
});
|
|
306
|
-
|
|
307
|
-
it('converts non-Error to UnknownError', () => {
|
|
308
|
-
const result = normalizeError('string error', abortedMessage);
|
|
309
|
-
|
|
310
|
-
expect(result).toBeInstanceOf(UnknownError);
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
it('converts null to UnknownError', () => {
|
|
314
|
-
const result = normalizeError(null, abortedMessage);
|
|
315
|
-
|
|
316
|
-
expect(result).toBeInstanceOf(UnknownError);
|
|
317
|
-
});
|
|
318
|
-
|
|
319
|
-
it('converts undefined to UnknownError', () => {
|
|
320
|
-
const result = normalizeError(undefined, abortedMessage);
|
|
321
|
-
|
|
322
|
-
expect(result).toBeInstanceOf(UnknownError);
|
|
323
|
-
});
|
|
324
|
-
});
|
|
325
|
-
|
|
326
|
-
describe('calculateRetryDelay', () => {
|
|
327
|
-
const backoffConfig = {
|
|
328
|
-
initialDelayMs: 1000,
|
|
329
|
-
maxDelayMs: 10000,
|
|
330
|
-
base: 2,
|
|
331
|
-
jitter: false, // Disable jitter for predictable tests
|
|
332
|
-
};
|
|
333
|
-
|
|
334
|
-
it('calculates delay for first retry', () => {
|
|
335
|
-
const error = new Error('test');
|
|
336
|
-
const delay = calculateRetryDelay(1, error, backoffConfig);
|
|
337
|
-
|
|
338
|
-
expect(delay).toBe(1000);
|
|
339
|
-
});
|
|
340
|
-
|
|
341
|
-
it('calculates delay for second retry', () => {
|
|
342
|
-
const error = new Error('test');
|
|
343
|
-
const delay = calculateRetryDelay(2, error, backoffConfig);
|
|
344
|
-
|
|
345
|
-
expect(delay).toBe(2000);
|
|
346
|
-
});
|
|
347
|
-
|
|
348
|
-
it('calculates delay for third retry', () => {
|
|
349
|
-
const error = new Error('test');
|
|
350
|
-
const delay = calculateRetryDelay(3, error, backoffConfig);
|
|
351
|
-
|
|
352
|
-
expect(delay).toBe(4000);
|
|
353
|
-
});
|
|
354
|
-
|
|
355
|
-
it('respects max delay', () => {
|
|
356
|
-
const error = new Error('test');
|
|
357
|
-
const delay = calculateRetryDelay(10, error, backoffConfig);
|
|
358
|
-
|
|
359
|
-
expect(delay).toBe(10000);
|
|
360
|
-
});
|
|
361
|
-
|
|
362
|
-
it('uses retryAfter from LLMRetryableError', () => {
|
|
363
|
-
const error = new LLMRetryableError('rate limit', 5000);
|
|
364
|
-
const delay = calculateRetryDelay(1, error, backoffConfig);
|
|
365
|
-
|
|
366
|
-
expect(delay).toBe(5000);
|
|
367
|
-
});
|
|
368
|
-
|
|
369
|
-
it('ignores retryAfter from non-LLMRetryableError', () => {
|
|
370
|
-
const error = new Error('test');
|
|
371
|
-
// Add retryAfter property to test that it's ignored for non-LLMRetryableError
|
|
372
|
-
Object.defineProperty(error, 'retryAfter', { value: 5000 });
|
|
373
|
-
const delay = calculateRetryDelay(1, error, backoffConfig);
|
|
374
|
-
|
|
375
|
-
expect(delay).toBe(1000);
|
|
376
|
-
});
|
|
377
|
-
});
|
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'vitest';
|
|
2
|
-
import {
|
|
3
|
-
AgentAbortedError,
|
|
4
|
-
AgentError,
|
|
5
|
-
AgentQueryError,
|
|
6
|
-
AgentUpstreamAuthError,
|
|
7
|
-
AgentUpstreamBadRequestError,
|
|
8
|
-
AgentUpstreamError,
|
|
9
|
-
AgentUpstreamNetworkError,
|
|
10
|
-
AgentUpstreamNotFoundError,
|
|
11
|
-
AgentUpstreamPermanentError,
|
|
12
|
-
AgentUpstreamRateLimitError,
|
|
13
|
-
AgentUpstreamRetryableError,
|
|
14
|
-
AgentUpstreamServerError,
|
|
15
|
-
AgentUpstreamTimeoutError,
|
|
16
|
-
ConfirmationTimeoutError,
|
|
17
|
-
MaxRetriesError,
|
|
18
|
-
TimeoutBudgetExceededError,
|
|
19
|
-
UnknownError,
|
|
20
|
-
} from '../error';
|
|
21
|
-
|
|
22
|
-
describe('agent/error', () => {
|
|
23
|
-
it('builds AgentError with default and custom code', () => {
|
|
24
|
-
const defaultErr = new AgentError('boom');
|
|
25
|
-
const customErr = new AgentError('boom2', 2001);
|
|
26
|
-
|
|
27
|
-
expect(defaultErr.name).toBe('AgentError');
|
|
28
|
-
expect(defaultErr.code).toBe(1000);
|
|
29
|
-
expect(defaultErr.message).toBe('boom');
|
|
30
|
-
expect(defaultErr.errorCode).toBe('AGENT_ERROR');
|
|
31
|
-
expect(defaultErr.category).toBe('internal');
|
|
32
|
-
expect(defaultErr.retryable).toBe(false);
|
|
33
|
-
expect(defaultErr.httpStatus).toBe(500);
|
|
34
|
-
|
|
35
|
-
expect(customErr.code).toBe(2001);
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it('builds AgentQueryError with defaults', () => {
|
|
39
|
-
const err = new AgentQueryError();
|
|
40
|
-
|
|
41
|
-
expect(err.name).toBe('AgentQueryError');
|
|
42
|
-
expect(err.code).toBe(1001);
|
|
43
|
-
expect(err.message).toBe('Query is empty');
|
|
44
|
-
expect(err.errorCode).toBe('AGENT_QUERY_EMPTY');
|
|
45
|
-
expect(err.category).toBe('validation');
|
|
46
|
-
expect(err.retryable).toBe(false);
|
|
47
|
-
expect(err.httpStatus).toBe(400);
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
it('builds AgentAbortedError', () => {
|
|
51
|
-
const err = new AgentAbortedError();
|
|
52
|
-
|
|
53
|
-
expect(err).toBeInstanceOf(AgentError);
|
|
54
|
-
expect(err.name).toBe('AgentAbortedError');
|
|
55
|
-
expect(err.code).toBe(1002);
|
|
56
|
-
expect(err.message).toBe('Agent was aborted');
|
|
57
|
-
expect(err.errorCode).toBe('AGENT_ABORTED');
|
|
58
|
-
expect(err.category).toBe('abort');
|
|
59
|
-
expect(err.retryable).toBe(false);
|
|
60
|
-
expect(err.httpStatus).toBe(499);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it('builds MaxRetriesError', () => {
|
|
64
|
-
const err = new MaxRetriesError();
|
|
65
|
-
|
|
66
|
-
expect(err).toBeInstanceOf(AgentError);
|
|
67
|
-
expect(err.name).toBe('MaxRetriesError');
|
|
68
|
-
expect(err.code).toBe(1003);
|
|
69
|
-
expect(err.message).toBe('Max retries reached');
|
|
70
|
-
expect(err.errorCode).toBe('AGENT_MAX_RETRIES_REACHED');
|
|
71
|
-
expect(err.category).toBe('timeout');
|
|
72
|
-
expect(err.retryable).toBe(false);
|
|
73
|
-
expect(err.httpStatus).toBe(504);
|
|
74
|
-
});
|
|
75
|
-
|
|
76
|
-
it('builds ConfirmationTimeoutError', () => {
|
|
77
|
-
const err = new ConfirmationTimeoutError();
|
|
78
|
-
|
|
79
|
-
expect(err).toBeInstanceOf(AgentError);
|
|
80
|
-
expect(err.name).toBe('ConfirmationTimeoutError');
|
|
81
|
-
expect(err.code).toBe(1004);
|
|
82
|
-
expect(err.message).toBe('Confirmation timeout');
|
|
83
|
-
expect(err.errorCode).toBe('AGENT_CONFIRMATION_TIMEOUT');
|
|
84
|
-
expect(err.category).toBe('timeout');
|
|
85
|
-
expect(err.retryable).toBe(true);
|
|
86
|
-
expect(err.httpStatus).toBe(408);
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it('builds UnknownError', () => {
|
|
90
|
-
const err = new UnknownError();
|
|
91
|
-
|
|
92
|
-
expect(err).toBeInstanceOf(AgentError);
|
|
93
|
-
expect(err.name).toBe('UnknownError');
|
|
94
|
-
expect(err.code).toBe(1005);
|
|
95
|
-
expect(err.message).toBe('Unknown error');
|
|
96
|
-
expect(err.errorCode).toBe('AGENT_UNKNOWN_ERROR');
|
|
97
|
-
expect(err.category).toBe('internal');
|
|
98
|
-
expect(err.retryable).toBe(false);
|
|
99
|
-
expect(err.httpStatus).toBe(500);
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
it('builds TimeoutBudgetExceededError', () => {
|
|
103
|
-
const err = new TimeoutBudgetExceededError();
|
|
104
|
-
|
|
105
|
-
expect(err).toBeInstanceOf(AgentError);
|
|
106
|
-
expect(err.name).toBe('TimeoutBudgetExceededError');
|
|
107
|
-
expect(err.code).toBe(1006);
|
|
108
|
-
expect(err.message).toBe('Timeout budget exceeded');
|
|
109
|
-
expect(err.errorCode).toBe('AGENT_TIMEOUT_BUDGET_EXCEEDED');
|
|
110
|
-
expect(err.category).toBe('timeout');
|
|
111
|
-
expect(err.retryable).toBe(false);
|
|
112
|
-
expect(err.httpStatus).toBe(504);
|
|
113
|
-
});
|
|
114
|
-
|
|
115
|
-
it('builds upstream retryable errors', () => {
|
|
116
|
-
const rateLimit = new AgentUpstreamRateLimitError('rate limited');
|
|
117
|
-
const timeout = new AgentUpstreamTimeoutError('timed out');
|
|
118
|
-
const network = new AgentUpstreamNetworkError('network down');
|
|
119
|
-
const server = new AgentUpstreamServerError('server 500');
|
|
120
|
-
const retryable = new AgentUpstreamRetryableError('retry me');
|
|
121
|
-
|
|
122
|
-
expect(rateLimit).toMatchObject({
|
|
123
|
-
name: 'AgentUpstreamRateLimitError',
|
|
124
|
-
code: 1007,
|
|
125
|
-
errorCode: 'AGENT_UPSTREAM_RATE_LIMIT',
|
|
126
|
-
category: 'rate_limit',
|
|
127
|
-
retryable: true,
|
|
128
|
-
httpStatus: 429,
|
|
129
|
-
});
|
|
130
|
-
expect(timeout).toMatchObject({
|
|
131
|
-
name: 'AgentUpstreamTimeoutError',
|
|
132
|
-
code: 1008,
|
|
133
|
-
errorCode: 'AGENT_UPSTREAM_TIMEOUT',
|
|
134
|
-
category: 'timeout',
|
|
135
|
-
retryable: true,
|
|
136
|
-
httpStatus: 504,
|
|
137
|
-
});
|
|
138
|
-
expect(network).toMatchObject({
|
|
139
|
-
name: 'AgentUpstreamNetworkError',
|
|
140
|
-
code: 1009,
|
|
141
|
-
errorCode: 'AGENT_UPSTREAM_NETWORK',
|
|
142
|
-
category: 'internal',
|
|
143
|
-
retryable: true,
|
|
144
|
-
httpStatus: 503,
|
|
145
|
-
});
|
|
146
|
-
expect(server).toMatchObject({
|
|
147
|
-
name: 'AgentUpstreamServerError',
|
|
148
|
-
code: 1010,
|
|
149
|
-
errorCode: 'AGENT_UPSTREAM_SERVER',
|
|
150
|
-
category: 'internal',
|
|
151
|
-
retryable: true,
|
|
152
|
-
httpStatus: 502,
|
|
153
|
-
});
|
|
154
|
-
expect(retryable).toMatchObject({
|
|
155
|
-
name: 'AgentUpstreamRetryableError',
|
|
156
|
-
code: 1015,
|
|
157
|
-
errorCode: 'AGENT_UPSTREAM_RETRYABLE',
|
|
158
|
-
category: 'internal',
|
|
159
|
-
retryable: true,
|
|
160
|
-
httpStatus: 503,
|
|
161
|
-
});
|
|
162
|
-
});
|
|
163
|
-
|
|
164
|
-
it('builds upstream non-retryable errors', () => {
|
|
165
|
-
const auth = new AgentUpstreamAuthError('bad key');
|
|
166
|
-
const notFound = new AgentUpstreamNotFoundError('missing model');
|
|
167
|
-
const badRequest = new AgentUpstreamBadRequestError('invalid payload');
|
|
168
|
-
const permanent = new AgentUpstreamPermanentError('not implemented');
|
|
169
|
-
const generic = new AgentUpstreamError('provider error');
|
|
170
|
-
|
|
171
|
-
expect(auth).toMatchObject({
|
|
172
|
-
name: 'AgentUpstreamAuthError',
|
|
173
|
-
code: 1011,
|
|
174
|
-
errorCode: 'AGENT_UPSTREAM_AUTH',
|
|
175
|
-
category: 'permission',
|
|
176
|
-
retryable: false,
|
|
177
|
-
httpStatus: 401,
|
|
178
|
-
});
|
|
179
|
-
expect(notFound).toMatchObject({
|
|
180
|
-
name: 'AgentUpstreamNotFoundError',
|
|
181
|
-
code: 1012,
|
|
182
|
-
errorCode: 'AGENT_UPSTREAM_NOT_FOUND',
|
|
183
|
-
category: 'not_found',
|
|
184
|
-
retryable: false,
|
|
185
|
-
httpStatus: 404,
|
|
186
|
-
});
|
|
187
|
-
expect(badRequest).toMatchObject({
|
|
188
|
-
name: 'AgentUpstreamBadRequestError',
|
|
189
|
-
code: 1013,
|
|
190
|
-
errorCode: 'AGENT_UPSTREAM_BAD_REQUEST',
|
|
191
|
-
category: 'validation',
|
|
192
|
-
retryable: false,
|
|
193
|
-
httpStatus: 400,
|
|
194
|
-
});
|
|
195
|
-
expect(permanent).toMatchObject({
|
|
196
|
-
name: 'AgentUpstreamPermanentError',
|
|
197
|
-
code: 1014,
|
|
198
|
-
errorCode: 'AGENT_UPSTREAM_PERMANENT',
|
|
199
|
-
category: 'internal',
|
|
200
|
-
retryable: false,
|
|
201
|
-
httpStatus: 500,
|
|
202
|
-
});
|
|
203
|
-
expect(generic).toMatchObject({
|
|
204
|
-
name: 'AgentUpstreamError',
|
|
205
|
-
code: 1016,
|
|
206
|
-
errorCode: 'AGENT_UPSTREAM_ERROR',
|
|
207
|
-
category: 'internal',
|
|
208
|
-
retryable: false,
|
|
209
|
-
httpStatus: 500,
|
|
210
|
-
});
|
|
211
|
-
});
|
|
212
|
-
});
|