@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,120 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 标准 OpenAI 兼容适配器
|
|
3
|
-
*
|
|
4
|
-
* 为常见的 OpenAI 兼容操作提供基础实现。
|
|
5
|
-
* 特定适配器可以根据需要覆盖方法。
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import type { LLMRequest, LLMResponse } from '../types';
|
|
9
|
-
import { BaseAPIAdapter } from './base';
|
|
10
|
-
|
|
11
|
-
export interface StandardTransformOptions extends LLMRequest {
|
|
12
|
-
/** 如果未指定,则使用的默认模型 */
|
|
13
|
-
defaultModel?: string;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* OpenAI 兼容 API 的标准适配器
|
|
18
|
-
*
|
|
19
|
-
* 处理常见的请求/响应转换逻辑。
|
|
20
|
-
* 子类可以覆盖特定方法以实现自定义行为。
|
|
21
|
-
*/
|
|
22
|
-
export class StandardAdapter extends BaseAPIAdapter {
|
|
23
|
-
readonly endpointPath: string;
|
|
24
|
-
readonly defaultModel: string;
|
|
25
|
-
|
|
26
|
-
constructor(options: { endpointPath?: string; defaultModel?: string } = {}) {
|
|
27
|
-
super();
|
|
28
|
-
this.endpointPath = options.endpointPath ?? '/chat/completions';
|
|
29
|
-
this.defaultModel = options.defaultModel ?? 'gpt-4o';
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
/**
|
|
33
|
-
* 转换请求 - 基础实现
|
|
34
|
-
*/
|
|
35
|
-
transformRequest(options?: LLMRequest): Record<string, unknown> {
|
|
36
|
-
const {
|
|
37
|
-
model,
|
|
38
|
-
max_tokens,
|
|
39
|
-
messages,
|
|
40
|
-
temperature,
|
|
41
|
-
stream,
|
|
42
|
-
tool_stream,
|
|
43
|
-
tools,
|
|
44
|
-
thinking,
|
|
45
|
-
abortSignal,
|
|
46
|
-
...rest
|
|
47
|
-
} = options || ({} as LLMRequest & { abortSignal?: AbortSignal; thinking?: unknown });
|
|
48
|
-
void thinking;
|
|
49
|
-
void abortSignal;
|
|
50
|
-
|
|
51
|
-
const extras = Object.fromEntries(
|
|
52
|
-
Object.entries(rest).filter(([, value]) => value !== undefined)
|
|
53
|
-
);
|
|
54
|
-
|
|
55
|
-
const body: LLMRequest = {
|
|
56
|
-
...extras,
|
|
57
|
-
model: model || this.defaultModel,
|
|
58
|
-
messages: this.cleanMessage(messages || []),
|
|
59
|
-
max_tokens: max_tokens,
|
|
60
|
-
temperature: temperature,
|
|
61
|
-
stream: stream ?? false,
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
if (tool_stream !== undefined) {
|
|
65
|
-
body.tool_stream = tool_stream;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
// 如果提供了工具,则添加
|
|
69
|
-
if (tools && tools.length > 0) {
|
|
70
|
-
body.tools = tools;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
// 允许子类添加自定义转换
|
|
74
|
-
return this.enrichRequestBody(body, options);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
/**
|
|
78
|
-
* 子类的钩子方法,用于向请求体添加自定义字段
|
|
79
|
-
* 覆盖此方法以添加特定于提供商的字段。
|
|
80
|
-
*/
|
|
81
|
-
protected enrichRequestBody(
|
|
82
|
-
body: LLMRequest,
|
|
83
|
-
_options?: StandardTransformOptions
|
|
84
|
-
): Record<string, unknown> {
|
|
85
|
-
return body;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
/**
|
|
89
|
-
* 转换响应 - 基础实现
|
|
90
|
-
*/
|
|
91
|
-
transformResponse(response: Record<string, unknown>): LLMResponse {
|
|
92
|
-
const data = response as LLMResponse;
|
|
93
|
-
|
|
94
|
-
if (!data.choices || data.choices.length === 0) {
|
|
95
|
-
// 提供更详细的错误信息,帮助调试
|
|
96
|
-
const responseStr = JSON.stringify(response, null, 2);
|
|
97
|
-
throw new Error(`Empty choices in response. Response: ${responseStr}`);
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
return data;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
/**
|
|
104
|
-
* 获取标准 HTTP 头
|
|
105
|
-
*/
|
|
106
|
-
getHeaders(apiKey: string): Headers {
|
|
107
|
-
return new Headers({
|
|
108
|
-
'Content-Type': 'application/json',
|
|
109
|
-
'User-Agent': 'RCode/1.0.0(cli)',
|
|
110
|
-
Authorization: `Bearer ${apiKey}`,
|
|
111
|
-
});
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
/**
|
|
115
|
-
* 获取端点路径
|
|
116
|
-
*/
|
|
117
|
-
getEndpointPath(): string {
|
|
118
|
-
return this.endpointPath;
|
|
119
|
-
}
|
|
120
|
-
}
|
|
@@ -1,313 +0,0 @@
|
|
|
1
|
-
import { afterEach, describe, expect, it, vi } from 'vitest';
|
|
2
|
-
import { HTTPClient } from '../client';
|
|
3
|
-
import { LLMRetryableError, LLMAbortedError } from '../../types';
|
|
4
|
-
|
|
5
|
-
describe('HTTPClient timeout behavior', () => {
|
|
6
|
-
afterEach(() => {
|
|
7
|
-
vi.restoreAllMocks();
|
|
8
|
-
});
|
|
9
|
-
|
|
10
|
-
it('should handle external timeout signal from upstream (Agent layer controls timeout)', async () => {
|
|
11
|
-
const timeoutMs = 80;
|
|
12
|
-
const simulatedSlowFetchMs = 1000;
|
|
13
|
-
|
|
14
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(
|
|
15
|
-
async (_input: string | URL | Request, init?: RequestInit) => {
|
|
16
|
-
const signal = init?.signal;
|
|
17
|
-
await new Promise<void>((resolve, reject) => {
|
|
18
|
-
const timer = setTimeout(resolve, simulatedSlowFetchMs);
|
|
19
|
-
if (signal) {
|
|
20
|
-
if (signal.aborted) {
|
|
21
|
-
clearTimeout(timer);
|
|
22
|
-
reject(new DOMException('Aborted', 'AbortError'));
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
signal.addEventListener(
|
|
27
|
-
'abort',
|
|
28
|
-
() => {
|
|
29
|
-
clearTimeout(timer);
|
|
30
|
-
reject(new DOMException('Aborted', 'AbortError'));
|
|
31
|
-
},
|
|
32
|
-
{ once: true }
|
|
33
|
-
);
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
throw new Error('should not reach successful fetch path');
|
|
37
|
-
}
|
|
38
|
-
);
|
|
39
|
-
|
|
40
|
-
// HTTPClient 不再需要 debug 参数
|
|
41
|
-
const client = new HTTPClient();
|
|
42
|
-
|
|
43
|
-
// 模拟 Agent 层创建的超时信号
|
|
44
|
-
const timeoutSignal = AbortSignal.timeout(timeoutMs);
|
|
45
|
-
|
|
46
|
-
const startedAt = Date.now();
|
|
47
|
-
const error = await client
|
|
48
|
-
.fetch('https://example.test/slow', {
|
|
49
|
-
signal: timeoutSignal,
|
|
50
|
-
})
|
|
51
|
-
.then(
|
|
52
|
-
() => null,
|
|
53
|
-
(err) => err
|
|
54
|
-
);
|
|
55
|
-
const elapsedMs = Date.now() - startedAt;
|
|
56
|
-
|
|
57
|
-
// HTTPClient 应该正确处理外部超时信号
|
|
58
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
59
|
-
expect((error as LLMRetryableError).code).toBe('TIMEOUT');
|
|
60
|
-
expect(elapsedMs).toBeGreaterThanOrEqual(40);
|
|
61
|
-
expect(elapsedMs).toBeLessThan(simulatedSlowFetchMs);
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
it('should apply defaultTimeoutMs when upstream signal is not provided', async () => {
|
|
65
|
-
const timeoutMs = 80;
|
|
66
|
-
const simulatedSlowFetchMs = 1000;
|
|
67
|
-
|
|
68
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(
|
|
69
|
-
async (_input: string | URL | Request, init?: RequestInit) => {
|
|
70
|
-
const signal = init?.signal;
|
|
71
|
-
await new Promise<void>((resolve, reject) => {
|
|
72
|
-
const timer = setTimeout(resolve, simulatedSlowFetchMs);
|
|
73
|
-
if (signal) {
|
|
74
|
-
if (signal.aborted) {
|
|
75
|
-
clearTimeout(timer);
|
|
76
|
-
reject(new DOMException('Aborted', 'AbortError'));
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
signal.addEventListener(
|
|
81
|
-
'abort',
|
|
82
|
-
() => {
|
|
83
|
-
clearTimeout(timer);
|
|
84
|
-
reject(new DOMException('Aborted', 'AbortError'));
|
|
85
|
-
},
|
|
86
|
-
{ once: true }
|
|
87
|
-
);
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
throw new Error('should not reach successful fetch path');
|
|
91
|
-
}
|
|
92
|
-
);
|
|
93
|
-
|
|
94
|
-
const client = new HTTPClient({ defaultTimeoutMs: timeoutMs });
|
|
95
|
-
|
|
96
|
-
const startedAt = Date.now();
|
|
97
|
-
const error = await client.fetch('https://example.test/default-timeout').then(
|
|
98
|
-
() => null,
|
|
99
|
-
(err) => err
|
|
100
|
-
);
|
|
101
|
-
const elapsedMs = Date.now() - startedAt;
|
|
102
|
-
|
|
103
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
104
|
-
expect((error as LLMRetryableError).code).toBe('TIMEOUT');
|
|
105
|
-
expect(elapsedMs).toBeGreaterThanOrEqual(40);
|
|
106
|
-
expect(elapsedMs).toBeLessThan(simulatedSlowFetchMs);
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
it('should not apply defaultTimeoutMs when upstream signal is provided', async () => {
|
|
110
|
-
const defaultTimeoutMs = 20;
|
|
111
|
-
const userAbortMs = 80;
|
|
112
|
-
const simulatedSlowFetchMs = 1000;
|
|
113
|
-
|
|
114
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(
|
|
115
|
-
async (_input: string | URL | Request, init?: RequestInit) => {
|
|
116
|
-
const signal = init?.signal;
|
|
117
|
-
await new Promise<void>((resolve, reject) => {
|
|
118
|
-
const timer = setTimeout(resolve, simulatedSlowFetchMs);
|
|
119
|
-
if (signal) {
|
|
120
|
-
if (signal.aborted) {
|
|
121
|
-
clearTimeout(timer);
|
|
122
|
-
reject(new DOMException('Aborted', 'AbortError'));
|
|
123
|
-
return;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
signal.addEventListener(
|
|
127
|
-
'abort',
|
|
128
|
-
() => {
|
|
129
|
-
clearTimeout(timer);
|
|
130
|
-
reject(new DOMException('Aborted', 'AbortError'));
|
|
131
|
-
},
|
|
132
|
-
{ once: true }
|
|
133
|
-
);
|
|
134
|
-
}
|
|
135
|
-
});
|
|
136
|
-
throw new Error('should not reach successful fetch path');
|
|
137
|
-
}
|
|
138
|
-
);
|
|
139
|
-
|
|
140
|
-
const client = new HTTPClient({ defaultTimeoutMs });
|
|
141
|
-
const controller = new AbortController();
|
|
142
|
-
setTimeout(() => controller.abort(), userAbortMs);
|
|
143
|
-
|
|
144
|
-
const startedAt = Date.now();
|
|
145
|
-
const error = await client
|
|
146
|
-
.fetch('https://example.test/user-abort', {
|
|
147
|
-
signal: controller.signal,
|
|
148
|
-
})
|
|
149
|
-
.then(
|
|
150
|
-
() => null,
|
|
151
|
-
(err) => err
|
|
152
|
-
);
|
|
153
|
-
const elapsedMs = Date.now() - startedAt;
|
|
154
|
-
|
|
155
|
-
expect(error).toBeInstanceOf(LLMAbortedError);
|
|
156
|
-
expect(elapsedMs).toBeGreaterThanOrEqual(50);
|
|
157
|
-
expect(elapsedMs).toBeLessThan(simulatedSlowFetchMs);
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
it('should handle user abort signal (not timeout)', async () => {
|
|
161
|
-
const simulatedSlowFetchMs = 1000;
|
|
162
|
-
|
|
163
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(
|
|
164
|
-
async (_input: string | URL | Request, init?: RequestInit) => {
|
|
165
|
-
const signal = init?.signal;
|
|
166
|
-
await new Promise<void>((resolve, reject) => {
|
|
167
|
-
const timer = setTimeout(resolve, simulatedSlowFetchMs);
|
|
168
|
-
if (signal) {
|
|
169
|
-
if (signal.aborted) {
|
|
170
|
-
clearTimeout(timer);
|
|
171
|
-
reject(new DOMException('Aborted', 'AbortError'));
|
|
172
|
-
return;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
signal.addEventListener(
|
|
176
|
-
'abort',
|
|
177
|
-
() => {
|
|
178
|
-
clearTimeout(timer);
|
|
179
|
-
reject(new DOMException('Aborted', 'AbortError'));
|
|
180
|
-
},
|
|
181
|
-
{ once: true }
|
|
182
|
-
);
|
|
183
|
-
}
|
|
184
|
-
});
|
|
185
|
-
throw new Error('should not reach successful fetch path');
|
|
186
|
-
}
|
|
187
|
-
);
|
|
188
|
-
|
|
189
|
-
const client = new HTTPClient();
|
|
190
|
-
const abortController = new AbortController();
|
|
191
|
-
|
|
192
|
-
// 在 50ms 后中止(用户主动取消,不是超时)
|
|
193
|
-
setTimeout(() => abortController.abort(), 50);
|
|
194
|
-
|
|
195
|
-
const error = await client
|
|
196
|
-
.fetch('https://example.test/slow', {
|
|
197
|
-
signal: abortController.signal,
|
|
198
|
-
})
|
|
199
|
-
.then(
|
|
200
|
-
() => null,
|
|
201
|
-
(err) => err
|
|
202
|
-
);
|
|
203
|
-
|
|
204
|
-
// 用户中止应该返回 AbortedError,而不是 TimeoutError
|
|
205
|
-
expect(error).toBeInstanceOf(LLMAbortedError);
|
|
206
|
-
});
|
|
207
|
-
|
|
208
|
-
it('should pass through LLMError from upstream', async () => {
|
|
209
|
-
const llmError = new LLMRetryableError('Custom error', 1000, 'CUSTOM');
|
|
210
|
-
|
|
211
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(async () => {
|
|
212
|
-
throw llmError;
|
|
213
|
-
});
|
|
214
|
-
|
|
215
|
-
const client = new HTTPClient();
|
|
216
|
-
|
|
217
|
-
const error = await client.fetch('https://example.test/error').then(
|
|
218
|
-
() => null,
|
|
219
|
-
(err) => err
|
|
220
|
-
);
|
|
221
|
-
|
|
222
|
-
// LLMError 应该直接传递
|
|
223
|
-
expect(error).toBe(llmError);
|
|
224
|
-
});
|
|
225
|
-
|
|
226
|
-
it('should work without any signal (no timeout at HTTP layer)', async () => {
|
|
227
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(async () => {
|
|
228
|
-
return new Response(JSON.stringify({ data: 'ok' }), {
|
|
229
|
-
status: 200,
|
|
230
|
-
headers: { 'Content-Type': 'application/json' },
|
|
231
|
-
});
|
|
232
|
-
});
|
|
233
|
-
|
|
234
|
-
const client = new HTTPClient();
|
|
235
|
-
|
|
236
|
-
const response = await client.fetch('https://example.test/ok');
|
|
237
|
-
|
|
238
|
-
expect(response.ok).toBe(true);
|
|
239
|
-
});
|
|
240
|
-
|
|
241
|
-
it('should honor Retry-After header with sub-second precision', async () => {
|
|
242
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(async () => {
|
|
243
|
-
return new Response('rate limited', {
|
|
244
|
-
status: 429,
|
|
245
|
-
statusText: 'Too Many Requests',
|
|
246
|
-
headers: { 'Retry-After': '0.25' },
|
|
247
|
-
});
|
|
248
|
-
});
|
|
249
|
-
|
|
250
|
-
const client = new HTTPClient();
|
|
251
|
-
const error = await client.fetch('https://example.test/rate-limit').then(
|
|
252
|
-
() => null,
|
|
253
|
-
(err) => err
|
|
254
|
-
);
|
|
255
|
-
|
|
256
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
257
|
-
expect((error as LLMRetryableError).retryAfter).toBe(250);
|
|
258
|
-
});
|
|
259
|
-
|
|
260
|
-
it('should honor retry-after-ms header when provided', async () => {
|
|
261
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(async () => {
|
|
262
|
-
return new Response('server busy', {
|
|
263
|
-
status: 503,
|
|
264
|
-
statusText: 'Service Unavailable',
|
|
265
|
-
headers: { 'retry-after-ms': '1350' },
|
|
266
|
-
});
|
|
267
|
-
});
|
|
268
|
-
|
|
269
|
-
const client = new HTTPClient();
|
|
270
|
-
const error = await client.fetch('https://example.test/server-busy').then(
|
|
271
|
-
() => null,
|
|
272
|
-
(err) => err
|
|
273
|
-
);
|
|
274
|
-
|
|
275
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
276
|
-
expect((error as LLMRetryableError).retryAfter).toBe(1350);
|
|
277
|
-
});
|
|
278
|
-
|
|
279
|
-
it('should normalize network errors to LLMRetryableError', async () => {
|
|
280
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(async () => {
|
|
281
|
-
const error = new Error('connect ECONNREFUSED');
|
|
282
|
-
(error as Error & { code: string }).code = 'ECONNREFUSED';
|
|
283
|
-
throw error;
|
|
284
|
-
});
|
|
285
|
-
|
|
286
|
-
const client = new HTTPClient();
|
|
287
|
-
|
|
288
|
-
const error = await client.fetch('https://example.test/error').then(
|
|
289
|
-
() => null,
|
|
290
|
-
(err) => err
|
|
291
|
-
);
|
|
292
|
-
|
|
293
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
294
|
-
expect((error as LLMRetryableError).code).toBe('NETWORK_ERROR');
|
|
295
|
-
});
|
|
296
|
-
|
|
297
|
-
it('should normalize bun-style unable to connect errors to LLMRetryableError', async () => {
|
|
298
|
-
vi.spyOn(globalThis, 'fetch').mockImplementation(async () => {
|
|
299
|
-
throw new Error('Unable to connect. Is the computer able to access the url?');
|
|
300
|
-
});
|
|
301
|
-
|
|
302
|
-
const client = new HTTPClient();
|
|
303
|
-
|
|
304
|
-
const error = await client.fetch('https://example.test/error').then(
|
|
305
|
-
() => null,
|
|
306
|
-
(err) => err
|
|
307
|
-
);
|
|
308
|
-
|
|
309
|
-
expect(error).toBeInstanceOf(LLMRetryableError);
|
|
310
|
-
expect((error as LLMRetryableError).code).toBe('NETWORK_ERROR');
|
|
311
|
-
expect((error as Error).message).toContain('Unable to connect');
|
|
312
|
-
});
|
|
313
|
-
});
|