@renxqoo/renx-code 0.0.8 → 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 +114 -40
- 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,150 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Logger 类型定义
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* 日志级别
|
|
7
|
-
*/
|
|
8
|
-
export enum LogLevel {
|
|
9
|
-
TRACE = 0,
|
|
10
|
-
DEBUG = 10,
|
|
11
|
-
INFO = 20,
|
|
12
|
-
WARN = 30,
|
|
13
|
-
ERROR = 40,
|
|
14
|
-
FATAL = 50,
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* 日志级别名称映射
|
|
19
|
-
*/
|
|
20
|
-
export const LogLevelName: Record<LogLevel, string> = {
|
|
21
|
-
[LogLevel.TRACE]: 'TRACE',
|
|
22
|
-
[LogLevel.DEBUG]: 'DEBUG',
|
|
23
|
-
[LogLevel.INFO]: 'INFO',
|
|
24
|
-
[LogLevel.WARN]: 'WARN',
|
|
25
|
-
[LogLevel.ERROR]: 'ERROR',
|
|
26
|
-
[LogLevel.FATAL]: 'FATAL',
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
/**
|
|
30
|
-
* 日志上下文
|
|
31
|
-
*/
|
|
32
|
-
export interface LogContext {
|
|
33
|
-
[key: string]: unknown;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* 错误信息结构
|
|
38
|
-
*/
|
|
39
|
-
export interface LogError {
|
|
40
|
-
name: string;
|
|
41
|
-
message: string;
|
|
42
|
-
stack?: string;
|
|
43
|
-
code?: string | number;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* 日志记录
|
|
48
|
-
*/
|
|
49
|
-
export interface LogRecord {
|
|
50
|
-
/** 时间戳 ISO 8601 */
|
|
51
|
-
timestamp: string;
|
|
52
|
-
/** 日志级别 */
|
|
53
|
-
level: LogLevel;
|
|
54
|
-
/** 日志级别名称 */
|
|
55
|
-
levelName: string;
|
|
56
|
-
/** 日志消息 */
|
|
57
|
-
message: string;
|
|
58
|
-
/** 上下文 */
|
|
59
|
-
context: LogContext;
|
|
60
|
-
/** 错误信息 */
|
|
61
|
-
error?: LogError;
|
|
62
|
-
/** 任意数据(支持任意类型) */
|
|
63
|
-
data?: unknown;
|
|
64
|
-
/** 模块名 */
|
|
65
|
-
module?: string;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* 文件输出配置
|
|
70
|
-
*/
|
|
71
|
-
export interface FileConfig {
|
|
72
|
-
/** 是否启用 */
|
|
73
|
-
enabled: boolean;
|
|
74
|
-
/** 文件路径 */
|
|
75
|
-
filepath: string;
|
|
76
|
-
/** 日志级别(可选,默认使用全局级别) */
|
|
77
|
-
level?: LogLevel;
|
|
78
|
-
/** 输出格式 */
|
|
79
|
-
format?: 'json' | 'pretty';
|
|
80
|
-
/** 日志轮转最大文件大小(字节) */
|
|
81
|
-
maxSize?: number;
|
|
82
|
-
/** 日志轮转最大文件数 */
|
|
83
|
-
maxFiles?: number;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
/**
|
|
87
|
-
* 控制台输出配置
|
|
88
|
-
*/
|
|
89
|
-
export interface ConsoleConfig {
|
|
90
|
-
/** 是否启用 */
|
|
91
|
-
enabled: boolean;
|
|
92
|
-
/** 日志级别(可选,默认使用全局级别) */
|
|
93
|
-
level?: LogLevel;
|
|
94
|
-
/** 输出格式 */
|
|
95
|
-
format?: 'json' | 'pretty';
|
|
96
|
-
/** 是否彩色输出 */
|
|
97
|
-
colorize?: boolean;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
* Transport 接口
|
|
102
|
-
*
|
|
103
|
-
* 实现此接口以支持自定义日志输出目标(如数据库、远程服务等)
|
|
104
|
-
*/
|
|
105
|
-
export interface ITransport {
|
|
106
|
-
/** Transport 名称(用于调试) */
|
|
107
|
-
readonly name?: string;
|
|
108
|
-
/**
|
|
109
|
-
* 写入日志记录
|
|
110
|
-
* @param record 日志记录(已脱敏)
|
|
111
|
-
* @param globalLevel 全局日志级别
|
|
112
|
-
*/
|
|
113
|
-
write(record: LogRecord, globalLevel: LogLevel): void | Promise<void>;
|
|
114
|
-
/** 关闭 Transport(可选) */
|
|
115
|
-
close?(): void | Promise<void>;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
/**
|
|
119
|
-
* 日志回调函数
|
|
120
|
-
*/
|
|
121
|
-
export type LogCallback = (record: LogRecord) => void | Promise<void>;
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* Logger 配置
|
|
125
|
-
*/
|
|
126
|
-
export interface LoggerConfig {
|
|
127
|
-
/** 服务名称 */
|
|
128
|
-
service: string;
|
|
129
|
-
/** 环境 */
|
|
130
|
-
env?: 'development' | 'production' | 'test';
|
|
131
|
-
/** 全局最小日志级别 */
|
|
132
|
-
level?: LogLevel;
|
|
133
|
-
/** 默认上下文 */
|
|
134
|
-
defaultContext?: LogContext;
|
|
135
|
-
/** 控制台配置 */
|
|
136
|
-
console?: ConsoleConfig;
|
|
137
|
-
/** 文件配置 */
|
|
138
|
-
file?: FileConfig;
|
|
139
|
-
/** 敏感字段列表(会被脱敏) */
|
|
140
|
-
sensitiveFields?: string[];
|
|
141
|
-
/** 自定义 Transport 列表(如数据库存储) */
|
|
142
|
-
transports?: ITransport[];
|
|
143
|
-
/** 日志回调(每条日志都会调用) */
|
|
144
|
-
onLog?: LogCallback;
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
/**
|
|
148
|
-
* 中间件函数类型
|
|
149
|
-
*/
|
|
150
|
-
export type LogMiddleware = (record: LogRecord, next: () => void) => void;
|
|
@@ -1,441 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Errors 模块测试
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { describe, it, expect } from 'vitest';
|
|
6
|
-
import {
|
|
7
|
-
PERMANENT_STREAM_ERROR_CODE_MARKERS,
|
|
8
|
-
PERMANENT_STREAM_ERROR_MESSAGE_PATTERNS,
|
|
9
|
-
isPermanentStreamChunkError,
|
|
10
|
-
abortReasonToText,
|
|
11
|
-
isIdleTimeoutReasonText,
|
|
12
|
-
isTimeoutReasonText,
|
|
13
|
-
classifyAbortReason,
|
|
14
|
-
LLMError,
|
|
15
|
-
LLMRetryableError,
|
|
16
|
-
LLMRateLimitError,
|
|
17
|
-
LLMPermanentError,
|
|
18
|
-
LLMAuthError,
|
|
19
|
-
LLMNotFoundError,
|
|
20
|
-
LLMBadRequestError,
|
|
21
|
-
LLMAbortedError,
|
|
22
|
-
createErrorFromStatus,
|
|
23
|
-
isRetryableError,
|
|
24
|
-
isPermanentError,
|
|
25
|
-
isAbortedError,
|
|
26
|
-
calculateBackoff,
|
|
27
|
-
} from '../types';
|
|
28
|
-
|
|
29
|
-
describe('LLMError', () => {
|
|
30
|
-
it('should create error with message and code', () => {
|
|
31
|
-
const error = new LLMError('Something went wrong', 'CUSTOM_ERROR');
|
|
32
|
-
expect(error.message).toBe('Something went wrong');
|
|
33
|
-
expect(error.code).toBe('CUSTOM_ERROR');
|
|
34
|
-
expect(error.name).toBe('LLMError');
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it('should create error with only message', () => {
|
|
38
|
-
const error = new LLMError('Something went wrong');
|
|
39
|
-
expect(error.message).toBe('Something went wrong');
|
|
40
|
-
expect(error.code).toBeUndefined();
|
|
41
|
-
expect(error.name).toBe('LLMError');
|
|
42
|
-
});
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
describe('LLMRetryableError', () => {
|
|
46
|
-
it('should create error with message and retryAfter', () => {
|
|
47
|
-
const error = new LLMRetryableError('Rate limited', 5000, 'RATE_LIMIT');
|
|
48
|
-
expect(error.message).toBe('Rate limited');
|
|
49
|
-
expect(error.retryAfter).toBe(5000);
|
|
50
|
-
expect(error.code).toBe('RATE_LIMIT');
|
|
51
|
-
expect(error.name).toBe('LLMRetryableError');
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
it('should calculate backoff with retryAfter', () => {
|
|
55
|
-
const error = new LLMRetryableError('Rate limited', 3000);
|
|
56
|
-
// 当有 retryAfter 时,返回值应该等于 retryAfter(不超过 maxDelay)
|
|
57
|
-
const backoff = error.getBackoff(1);
|
|
58
|
-
expect(backoff).toBe(3000);
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
it('should calculate exponential backoff without retryAfter', () => {
|
|
62
|
-
const error = new LLMRetryableError('Server error');
|
|
63
|
-
// 无 jitter 时,backoff = initialDelayMs * (base ^ retryCount)
|
|
64
|
-
// initialDelayMs = 1000, base = 2
|
|
65
|
-
// retryCount=1: 1000 * 2^1 = 2000
|
|
66
|
-
// 由于默认启用 jitter,实际值会在 [1000, 3000] 范围内
|
|
67
|
-
const backoff1 = error.getBackoff(1);
|
|
68
|
-
expect(backoff1).toBeGreaterThanOrEqual(1000);
|
|
69
|
-
expect(backoff1).toBeLessThanOrEqual(3000);
|
|
70
|
-
|
|
71
|
-
// retryCount=2: 1000 * 2^2 = 4000
|
|
72
|
-
const backoff2 = error.getBackoff(2);
|
|
73
|
-
expect(backoff2).toBeGreaterThanOrEqual(2000);
|
|
74
|
-
expect(backoff2).toBeLessThanOrEqual(6000);
|
|
75
|
-
|
|
76
|
-
// retryCount=3: 1000 * 2^3 = 8000,但不超过 maxDelayMs=60000
|
|
77
|
-
const backoff3 = error.getBackoff(3);
|
|
78
|
-
expect(backoff3).toBeGreaterThanOrEqual(4000);
|
|
79
|
-
expect(backoff3).toBeLessThanOrEqual(12000);
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
describe('calculateBackoff', () => {
|
|
84
|
-
it('should use retryAfter when provided', () => {
|
|
85
|
-
const delay = calculateBackoff(5, 5000);
|
|
86
|
-
expect(delay).toBe(5000);
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it('should cap retryAfter at maxDelayMs', () => {
|
|
90
|
-
const delay = calculateBackoff(1, 100000, { maxDelayMs: 60000 });
|
|
91
|
-
expect(delay).toBe(60000);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
it('should calculate exponential backoff without retryAfter', () => {
|
|
95
|
-
// 无 jitter 时: 1000 * 2^1 = 2000
|
|
96
|
-
const delay = calculateBackoff(1, undefined, { jitter: false });
|
|
97
|
-
expect(delay).toBe(2000);
|
|
98
|
-
|
|
99
|
-
// 无 jitter 时: 1000 * 2^2 = 4000
|
|
100
|
-
const delay2 = calculateBackoff(2, undefined, { jitter: false });
|
|
101
|
-
expect(delay2).toBe(4000);
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
it('should respect maxDelayMs', () => {
|
|
105
|
-
// 指数退避会超过最大值,应该被限制
|
|
106
|
-
const delay = calculateBackoff(10, undefined, {
|
|
107
|
-
initialDelayMs: 1000,
|
|
108
|
-
maxDelayMs: 5000,
|
|
109
|
-
jitter: false,
|
|
110
|
-
});
|
|
111
|
-
expect(delay).toBe(5000);
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('should apply jitter when enabled', () => {
|
|
115
|
-
// 运行多次来验证 jitter 范围
|
|
116
|
-
const delays: number[] = [];
|
|
117
|
-
for (let i = 0; i < 100; i++) {
|
|
118
|
-
delays.push(calculateBackoff(1, undefined, { jitter: true }));
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// jitter 范围应该是 [0.5, 1.5] * 2000 = [1000, 3000]
|
|
122
|
-
const min = Math.min(...delays);
|
|
123
|
-
const max = Math.max(...delays);
|
|
124
|
-
|
|
125
|
-
expect(min).toBeGreaterThanOrEqual(1000);
|
|
126
|
-
expect(max).toBeLessThanOrEqual(3000);
|
|
127
|
-
|
|
128
|
-
// 验证不是所有值都相同(即确实有 jitter)
|
|
129
|
-
const uniqueValues = new Set(delays);
|
|
130
|
-
expect(uniqueValues.size).toBeGreaterThan(1);
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
it('should respect custom config', () => {
|
|
134
|
-
const delay = calculateBackoff(1, undefined, {
|
|
135
|
-
initialDelayMs: 500,
|
|
136
|
-
base: 3,
|
|
137
|
-
maxDelayMs: 10000,
|
|
138
|
-
jitter: false,
|
|
139
|
-
});
|
|
140
|
-
// 500 * 3^1 = 1500
|
|
141
|
-
expect(delay).toBe(1500);
|
|
142
|
-
});
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
describe('LLMRateLimitError', () => {
|
|
146
|
-
it('should create rate limit error', () => {
|
|
147
|
-
const error = new LLMRateLimitError('Too many requests');
|
|
148
|
-
expect(error.message).toBe('Too many requests');
|
|
149
|
-
expect(error.retryAfter).toBeUndefined();
|
|
150
|
-
expect(error.code).toBe('RATE_LIMIT');
|
|
151
|
-
expect(error.name).toBe('LLMRateLimitError');
|
|
152
|
-
});
|
|
153
|
-
|
|
154
|
-
it('should create without retryAfter', () => {
|
|
155
|
-
const error = new LLMRateLimitError('Too many requests');
|
|
156
|
-
expect(error.retryAfter).toBeUndefined();
|
|
157
|
-
expect(error.code).toBe('RATE_LIMIT');
|
|
158
|
-
});
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
describe('LLMPermanentError', () => {
|
|
162
|
-
it('should create permanent error with statusCode', () => {
|
|
163
|
-
const error = new LLMPermanentError('Not found', 404, 'NOT_FOUND');
|
|
164
|
-
expect(error.message).toBe('Not found');
|
|
165
|
-
expect(error.statusCode).toBe(404);
|
|
166
|
-
expect(error.code).toBe('NOT_FOUND');
|
|
167
|
-
expect(error.name).toBe('LLMPermanentError');
|
|
168
|
-
});
|
|
169
|
-
});
|
|
170
|
-
|
|
171
|
-
describe('LLMAuthError', () => {
|
|
172
|
-
it('should create auth error', () => {
|
|
173
|
-
const error = new LLMAuthError('Invalid API key');
|
|
174
|
-
expect(error.message).toBe('Invalid API key');
|
|
175
|
-
expect(error.statusCode).toBe(401);
|
|
176
|
-
expect(error.code).toBe('AUTH_FAILED');
|
|
177
|
-
expect(error.name).toBe('LLMAuthError');
|
|
178
|
-
});
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
describe('LLMNotFoundError', () => {
|
|
182
|
-
it('should create not found error with resource type', () => {
|
|
183
|
-
const error = new LLMNotFoundError('Model not found', 'model');
|
|
184
|
-
expect(error.message).toBe('Model not found');
|
|
185
|
-
expect(error.statusCode).toBe(404);
|
|
186
|
-
expect(error.code).toBe('NOT_FOUND');
|
|
187
|
-
expect(error.resourceType).toBe('model');
|
|
188
|
-
expect(error.name).toBe('LLMNotFoundError');
|
|
189
|
-
});
|
|
190
|
-
|
|
191
|
-
it('should create without resource type', () => {
|
|
192
|
-
const error = new LLMNotFoundError('Resource not found');
|
|
193
|
-
expect(error.resourceType).toBeUndefined();
|
|
194
|
-
});
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
describe('LLMBadRequestError', () => {
|
|
198
|
-
it('should create bad request error with validation errors', () => {
|
|
199
|
-
const validationErrors = { field: 'Invalid value' };
|
|
200
|
-
const error = new LLMBadRequestError('Invalid request', validationErrors);
|
|
201
|
-
expect(error.message).toBe('Invalid request');
|
|
202
|
-
expect(error.statusCode).toBe(400);
|
|
203
|
-
expect(error.code).toBe('BAD_REQUEST');
|
|
204
|
-
expect(error.validationErrors).toEqual(validationErrors);
|
|
205
|
-
expect(error.name).toBe('LLMBadRequestError');
|
|
206
|
-
});
|
|
207
|
-
});
|
|
208
|
-
|
|
209
|
-
describe('LLMAbortedError', () => {
|
|
210
|
-
it('should create aborted error with default message', () => {
|
|
211
|
-
const error = new LLMAbortedError();
|
|
212
|
-
expect(error.message).toBe('Request was cancelled');
|
|
213
|
-
expect(error.code).toBe('ABORTED');
|
|
214
|
-
expect(error.name).toBe('LLMAbortedError');
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
it('should create aborted error with custom message', () => {
|
|
218
|
-
const error = new LLMAbortedError('User cancelled');
|
|
219
|
-
expect(error.message).toBe('User cancelled');
|
|
220
|
-
expect(error.code).toBe('ABORTED');
|
|
221
|
-
});
|
|
222
|
-
});
|
|
223
|
-
|
|
224
|
-
describe('createErrorFromStatus', () => {
|
|
225
|
-
it('should return LLMAuthError for 401', () => {
|
|
226
|
-
const error = createErrorFromStatus(401, 'Unauthorized', 'Invalid token');
|
|
227
|
-
expect(error).toBeInstanceOf(LLMAuthError);
|
|
228
|
-
expect(error.code).toBe('AUTH_FAILED');
|
|
229
|
-
});
|
|
230
|
-
|
|
231
|
-
it('should return LLMAuthError for 403', () => {
|
|
232
|
-
const error = createErrorFromStatus(403, 'Forbidden', 'Access denied');
|
|
233
|
-
expect(error).toBeInstanceOf(LLMAuthError);
|
|
234
|
-
});
|
|
235
|
-
|
|
236
|
-
it('should return LLMNotFoundError for 404', () => {
|
|
237
|
-
const error = createErrorFromStatus(404, 'Not Found', 'Resource not found');
|
|
238
|
-
expect(error).toBeInstanceOf(LLMNotFoundError);
|
|
239
|
-
expect((error as LLMNotFoundError).resourceType).toBe('resource');
|
|
240
|
-
});
|
|
241
|
-
|
|
242
|
-
it('should return LLMRateLimitError for 429', () => {
|
|
243
|
-
const error = createErrorFromStatus(429, 'Too Many Requests', 'Rate limit exceeded');
|
|
244
|
-
expect(error).toBeInstanceOf(LLMRateLimitError);
|
|
245
|
-
});
|
|
246
|
-
|
|
247
|
-
it('should return LLMBadRequestError for 400', () => {
|
|
248
|
-
const error = createErrorFromStatus(400, 'Bad Request', 'Invalid input');
|
|
249
|
-
expect(error).toBeInstanceOf(LLMBadRequestError);
|
|
250
|
-
});
|
|
251
|
-
|
|
252
|
-
it('should return LLMPermanentError for 501', () => {
|
|
253
|
-
const error = createErrorFromStatus(501, 'Not Implemented', 'Feature not available');
|
|
254
|
-
expect(error).toBeInstanceOf(LLMPermanentError);
|
|
255
|
-
expect(error.code).toBe('NOT_IMPLEMENTED');
|
|
256
|
-
});
|
|
257
|
-
|
|
258
|
-
it('should return LLMRetryableError for 500', () => {
|
|
259
|
-
const error = createErrorFromStatus(500, 'Internal Server Error', 'Something broke');
|
|
260
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
261
|
-
expect(error.code).toBe('SERVER_500');
|
|
262
|
-
});
|
|
263
|
-
|
|
264
|
-
it('should return LLMRetryableError for 408', () => {
|
|
265
|
-
const error = createErrorFromStatus(408, 'Request Timeout', 'RequestTimeOut');
|
|
266
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
267
|
-
expect(error.code).toBe('TIMEOUT');
|
|
268
|
-
});
|
|
269
|
-
|
|
270
|
-
it('should return LLMRetryableError for 502', () => {
|
|
271
|
-
const error = createErrorFromStatus(502, 'Bad Gateway', 'Upstream error');
|
|
272
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
273
|
-
expect(error.code).toBe('SERVER_502');
|
|
274
|
-
});
|
|
275
|
-
|
|
276
|
-
it('should return LLMRetryableError for 503', () => {
|
|
277
|
-
const error = createErrorFromStatus(503, 'Service Unavailable', 'Server busy');
|
|
278
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
279
|
-
expect(error.code).toBe('SERVER_503');
|
|
280
|
-
});
|
|
281
|
-
|
|
282
|
-
it('should return LLMRetryableError for 504', () => {
|
|
283
|
-
const error = createErrorFromStatus(504, 'Gateway Timeout', 'Timeout');
|
|
284
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
285
|
-
expect(error.code).toBe('SERVER_504');
|
|
286
|
-
});
|
|
287
|
-
|
|
288
|
-
it('should return LLMError for unknown status codes', () => {
|
|
289
|
-
const error = createErrorFromStatus(418, "I'm a teapot", 'Teapot');
|
|
290
|
-
expect(error).toBeInstanceOf(LLMError);
|
|
291
|
-
expect(error.code).toBe('HTTP_418');
|
|
292
|
-
});
|
|
293
|
-
|
|
294
|
-
it('should parse error details from JSON', () => {
|
|
295
|
-
const errorText = JSON.stringify({ error: { message: 'Detailed error' } });
|
|
296
|
-
const error = createErrorFromStatus(400, 'Bad Request', errorText);
|
|
297
|
-
expect(error.message).toContain('Detailed error');
|
|
298
|
-
});
|
|
299
|
-
|
|
300
|
-
it('should handle non-JSON error text', () => {
|
|
301
|
-
const error = createErrorFromStatus(500, 'Internal Server Error', 'Plain text error');
|
|
302
|
-
expect(error.message).toContain('Plain text error');
|
|
303
|
-
});
|
|
304
|
-
|
|
305
|
-
it('should handle empty error text', () => {
|
|
306
|
-
const error = createErrorFromStatus(500, 'Internal Server Error', '');
|
|
307
|
-
expect(error.message).toBe('500 Internal Server Error');
|
|
308
|
-
});
|
|
309
|
-
});
|
|
310
|
-
|
|
311
|
-
describe('isRetryableError', () => {
|
|
312
|
-
it('should return true for LLMRetryableError', () => {
|
|
313
|
-
const error = new LLMRetryableError('Server error');
|
|
314
|
-
expect(isRetryableError(error)).toBe(true);
|
|
315
|
-
});
|
|
316
|
-
|
|
317
|
-
it('should return true for LLMRateLimitError', () => {
|
|
318
|
-
const error = new LLMRateLimitError('Rate limited');
|
|
319
|
-
expect(isRetryableError(error)).toBe(true);
|
|
320
|
-
});
|
|
321
|
-
|
|
322
|
-
it('should return false for LLMAuthError', () => {
|
|
323
|
-
const error = new LLMAuthError('Unauthorized');
|
|
324
|
-
expect(isRetryableError(error)).toBe(false);
|
|
325
|
-
});
|
|
326
|
-
|
|
327
|
-
it('should return false for generic error', () => {
|
|
328
|
-
const error = new Error('Generic error');
|
|
329
|
-
expect(isRetryableError(error)).toBe(false);
|
|
330
|
-
});
|
|
331
|
-
|
|
332
|
-
it('should return false for non-Error objects', () => {
|
|
333
|
-
expect(isRetryableError('string')).toBe(false);
|
|
334
|
-
expect(isRetryableError(null)).toBe(false);
|
|
335
|
-
expect(isRetryableError(undefined)).toBe(false);
|
|
336
|
-
});
|
|
337
|
-
});
|
|
338
|
-
|
|
339
|
-
describe('isPermanentError', () => {
|
|
340
|
-
it('should return true for LLMPermanentError', () => {
|
|
341
|
-
const error = new LLMPermanentError('Not found', 404);
|
|
342
|
-
expect(isPermanentError(error)).toBe(true);
|
|
343
|
-
});
|
|
344
|
-
|
|
345
|
-
it('should return true for LLMAuthError', () => {
|
|
346
|
-
const error = new LLMAuthError('Unauthorized');
|
|
347
|
-
expect(isPermanentError(error)).toBe(true);
|
|
348
|
-
});
|
|
349
|
-
|
|
350
|
-
it('should return true for LLMNotFoundError', () => {
|
|
351
|
-
const error = new LLMNotFoundError('Not found');
|
|
352
|
-
expect(isPermanentError(error)).toBe(true);
|
|
353
|
-
});
|
|
354
|
-
|
|
355
|
-
it('should return true for LLMBadRequestError', () => {
|
|
356
|
-
const error = new LLMBadRequestError('Bad request');
|
|
357
|
-
expect(isPermanentError(error)).toBe(true);
|
|
358
|
-
});
|
|
359
|
-
|
|
360
|
-
it('should return false for LLMRetryableError', () => {
|
|
361
|
-
const error = new LLMRetryableError('Server error');
|
|
362
|
-
expect(isPermanentError(error)).toBe(false);
|
|
363
|
-
});
|
|
364
|
-
|
|
365
|
-
it('should return false for generic error', () => {
|
|
366
|
-
const error = new Error('Generic error');
|
|
367
|
-
expect(isPermanentError(error)).toBe(false);
|
|
368
|
-
});
|
|
369
|
-
});
|
|
370
|
-
|
|
371
|
-
describe('isAbortedError', () => {
|
|
372
|
-
it('should return true for LLMAbortedError', () => {
|
|
373
|
-
const error = new LLMAbortedError();
|
|
374
|
-
expect(isAbortedError(error)).toBe(true);
|
|
375
|
-
});
|
|
376
|
-
|
|
377
|
-
it('should return false for other errors', () => {
|
|
378
|
-
const error = new LLMError('Other error');
|
|
379
|
-
expect(isAbortedError(error)).toBe(false);
|
|
380
|
-
});
|
|
381
|
-
|
|
382
|
-
it('should return false for non-Error objects', () => {
|
|
383
|
-
expect(isAbortedError('string')).toBe(false);
|
|
384
|
-
expect(isAbortedError(null)).toBe(false);
|
|
385
|
-
});
|
|
386
|
-
});
|
|
387
|
-
|
|
388
|
-
describe('abort reason helpers', () => {
|
|
389
|
-
it('abortReasonToText should normalize Error and string', () => {
|
|
390
|
-
expect(abortReasonToText(new Error('boom'))).toContain('boom');
|
|
391
|
-
expect(abortReasonToText(' manual abort ')).toBe('manual abort');
|
|
392
|
-
expect(abortReasonToText({})).toBe('');
|
|
393
|
-
});
|
|
394
|
-
|
|
395
|
-
it('isIdleTimeoutReasonText should detect idle timeout signatures', () => {
|
|
396
|
-
expect(isIdleTimeoutReasonText('Idle timeout after 300000ms')).toBe(true);
|
|
397
|
-
expect(isIdleTimeoutReasonText('IDLE_TIMEOUT')).toBe(true);
|
|
398
|
-
expect(isIdleTimeoutReasonText('Request timeout')).toBe(false);
|
|
399
|
-
});
|
|
400
|
-
|
|
401
|
-
it('isTimeoutReasonText should detect timeout signatures', () => {
|
|
402
|
-
expect(isTimeoutReasonText('TimeoutError Request timeout')).toBe(true);
|
|
403
|
-
expect(isTimeoutReasonText('signal timed out')).toBe(true);
|
|
404
|
-
expect(isTimeoutReasonText('manual abort')).toBe(false);
|
|
405
|
-
});
|
|
406
|
-
|
|
407
|
-
it('classifyAbortReason should classify idle timeout, timeout and abort', () => {
|
|
408
|
-
expect(classifyAbortReason(new DOMException('Idle timeout after 1000ms', 'TimeoutError'))).toBe(
|
|
409
|
-
'idle_timeout'
|
|
410
|
-
);
|
|
411
|
-
expect(classifyAbortReason(new DOMException('The operation timed out', 'TimeoutError'))).toBe(
|
|
412
|
-
'timeout'
|
|
413
|
-
);
|
|
414
|
-
expect(classifyAbortReason('Request was cancelled by user')).toBe('abort');
|
|
415
|
-
expect(classifyAbortReason(undefined)).toBe('unknown');
|
|
416
|
-
});
|
|
417
|
-
});
|
|
418
|
-
|
|
419
|
-
describe('stream chunk permanent error helpers', () => {
|
|
420
|
-
it('should expose permanent stream error rule sets', () => {
|
|
421
|
-
expect(PERMANENT_STREAM_ERROR_CODE_MARKERS.length).toBeGreaterThan(0);
|
|
422
|
-
expect(PERMANENT_STREAM_ERROR_MESSAGE_PATTERNS.length).toBeGreaterThan(0);
|
|
423
|
-
});
|
|
424
|
-
|
|
425
|
-
it('should classify known permanent stream errors by code first', () => {
|
|
426
|
-
expect(isPermanentStreamChunkError('invalid_request_error', 'temporary issue')).toBe(true);
|
|
427
|
-
expect(isPermanentStreamChunkError('permission_denied', 'temporary issue')).toBe(true);
|
|
428
|
-
expect(isPermanentStreamChunkError('unsupported_model', 'temporary issue')).toBe(true);
|
|
429
|
-
});
|
|
430
|
-
|
|
431
|
-
it('should not misclassify auth-like but unrelated code tokens', () => {
|
|
432
|
-
// 不应因为包含 "auth" 子串而误判(例如 authoring)。
|
|
433
|
-
expect(isPermanentStreamChunkError('authoring_tool_error', 'retry later')).toBe(false);
|
|
434
|
-
});
|
|
435
|
-
|
|
436
|
-
it('should fallback to message patterns when code is missing', () => {
|
|
437
|
-
expect(isPermanentStreamChunkError(undefined, 'Bad request: invalid parameter')).toBe(true);
|
|
438
|
-
expect(isPermanentStreamChunkError('', 'Permission denied for this model')).toBe(true);
|
|
439
|
-
expect(isPermanentStreamChunkError(undefined, 'transient upstream timeout')).toBe(false);
|
|
440
|
-
});
|
|
441
|
-
});
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from 'vitest';
|
|
2
|
-
|
|
3
|
-
import { Models, ProviderRegistry } from '../../index';
|
|
4
|
-
|
|
5
|
-
describe('providers module exports', () => {
|
|
6
|
-
it('should expose model IDs from registry', () => {
|
|
7
|
-
const ids = ProviderRegistry.getModelIds();
|
|
8
|
-
expect(ids.length).toBeGreaterThan(0);
|
|
9
|
-
expect(ids).toContain('glm-4.7');
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
it('should expose convenience model accessors', () => {
|
|
13
|
-
expect(Models.glm47.id).toBe('glm-4.7');
|
|
14
|
-
expect(Models.kimiK25.provider).toBe('kimi');
|
|
15
|
-
});
|
|
16
|
-
});
|