@gguf/coder 0.3.1 → 0.3.3
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/package.json +5 -2
- package/.editorconfig +0 -16
- package/.env.example +0 -63
- package/.gitattributes +0 -1
- package/.semgrepignore +0 -19
- package/coder-dummy-file.ts +0 -52
- package/coder.config.example.json +0 -59
- package/coder.config.json +0 -13
- package/color_picker.html +0 -36
- package/scripts/extract-changelog.js +0 -73
- package/scripts/fetch-models.js +0 -143
- package/scripts/test.sh +0 -40
- package/scripts/update-homebrew-formula.sh +0 -125
- package/scripts/update-nix-version.sh +0 -157
- package/source/ai-sdk-client/AISDKClient.spec.ts +0 -117
- package/source/ai-sdk-client/AISDKClient.ts +0 -155
- package/source/ai-sdk-client/chat/chat-handler.spec.ts +0 -121
- package/source/ai-sdk-client/chat/chat-handler.ts +0 -276
- package/source/ai-sdk-client/chat/streaming-handler.spec.ts +0 -173
- package/source/ai-sdk-client/chat/streaming-handler.ts +0 -110
- package/source/ai-sdk-client/chat/tool-processor.spec.ts +0 -92
- package/source/ai-sdk-client/chat/tool-processor.ts +0 -70
- package/source/ai-sdk-client/converters/message-converter.spec.ts +0 -220
- package/source/ai-sdk-client/converters/message-converter.ts +0 -113
- package/source/ai-sdk-client/converters/tool-converter.spec.ts +0 -90
- package/source/ai-sdk-client/converters/tool-converter.ts +0 -46
- package/source/ai-sdk-client/error-handling/error-extractor.spec.ts +0 -55
- package/source/ai-sdk-client/error-handling/error-extractor.ts +0 -15
- package/source/ai-sdk-client/error-handling/error-parser.spec.ts +0 -169
- package/source/ai-sdk-client/error-handling/error-parser.ts +0 -161
- package/source/ai-sdk-client/index.ts +0 -7
- package/source/ai-sdk-client/providers/provider-factory.spec.ts +0 -71
- package/source/ai-sdk-client/providers/provider-factory.ts +0 -41
- package/source/ai-sdk-client/types.ts +0 -9
- package/source/ai-sdk-client-empty-message.spec.ts +0 -141
- package/source/ai-sdk-client-error-handling.spec.ts +0 -186
- package/source/ai-sdk-client-maxretries.spec.ts +0 -114
- package/source/ai-sdk-client-preparestep.spec.ts +0 -279
- package/source/app/App.spec.tsx +0 -32
- package/source/app/App.tsx +0 -480
- package/source/app/components/AppContainer.spec.tsx +0 -96
- package/source/app/components/AppContainer.tsx +0 -56
- package/source/app/components/ChatInterface.spec.tsx +0 -163
- package/source/app/components/ChatInterface.tsx +0 -144
- package/source/app/components/ModalSelectors.spec.tsx +0 -141
- package/source/app/components/ModalSelectors.tsx +0 -135
- package/source/app/helpers.spec.ts +0 -97
- package/source/app/helpers.ts +0 -63
- package/source/app/index.ts +0 -4
- package/source/app/types.ts +0 -39
- package/source/app/utils/appUtils.ts +0 -294
- package/source/app/utils/conversationState.ts +0 -310
- package/source/app.spec.tsx +0 -244
- package/source/cli.spec.ts +0 -73
- package/source/cli.tsx +0 -51
- package/source/client-factory.spec.ts +0 -48
- package/source/client-factory.ts +0 -178
- package/source/command-parser.spec.ts +0 -127
- package/source/command-parser.ts +0 -36
- package/source/commands/checkpoint.spec.tsx +0 -277
- package/source/commands/checkpoint.tsx +0 -366
- package/source/commands/clear.tsx +0 -22
- package/source/commands/custom-commands.tsx +0 -121
- package/source/commands/exit.ts +0 -21
- package/source/commands/export.spec.tsx +0 -131
- package/source/commands/export.tsx +0 -79
- package/source/commands/help.tsx +0 -120
- package/source/commands/index.ts +0 -17
- package/source/commands/init.tsx +0 -339
- package/source/commands/lsp-command.spec.tsx +0 -281
- package/source/commands/lsp.tsx +0 -120
- package/source/commands/mcp-command.spec.tsx +0 -313
- package/source/commands/mcp.tsx +0 -162
- package/source/commands/model-database.spec.tsx +0 -758
- package/source/commands/model-database.tsx +0 -418
- package/source/commands/model.ts +0 -12
- package/source/commands/provider.ts +0 -12
- package/source/commands/setup-config.tsx +0 -16
- package/source/commands/simple-commands.spec.tsx +0 -175
- package/source/commands/status.ts +0 -12
- package/source/commands/theme.ts +0 -12
- package/source/commands/update.spec.tsx +0 -261
- package/source/commands/update.tsx +0 -201
- package/source/commands/usage.spec.tsx +0 -495
- package/source/commands/usage.tsx +0 -100
- package/source/commands.spec.ts +0 -436
- package/source/commands.ts +0 -83
- package/source/components/assistant-message.spec.tsx +0 -796
- package/source/components/assistant-message.tsx +0 -34
- package/source/components/bash-execution-indicator.tsx +0 -21
- package/source/components/cancelling-indicator.tsx +0 -16
- package/source/components/chat-queue.spec.tsx +0 -83
- package/source/components/chat-queue.tsx +0 -36
- package/source/components/checkpoint-display.spec.tsx +0 -219
- package/source/components/checkpoint-display.tsx +0 -126
- package/source/components/checkpoint-selector.spec.tsx +0 -173
- package/source/components/checkpoint-selector.tsx +0 -173
- package/source/components/development-mode-indicator.spec.tsx +0 -268
- package/source/components/development-mode-indicator.tsx +0 -38
- package/source/components/message-box.spec.tsx +0 -427
- package/source/components/message-box.tsx +0 -87
- package/source/components/model-selector.tsx +0 -132
- package/source/components/provider-selector.tsx +0 -75
- package/source/components/random-spinner.tsx +0 -19
- package/source/components/security-disclaimer.tsx +0 -73
- package/source/components/status-connection-display.spec.tsx +0 -133
- package/source/components/status.tsx +0 -267
- package/source/components/theme-selector.tsx +0 -126
- package/source/components/tool-confirmation.tsx +0 -190
- package/source/components/tool-execution-indicator.tsx +0 -33
- package/source/components/tool-message.tsx +0 -85
- package/source/components/ui/titled-box.spec.tsx +0 -207
- package/source/components/ui/titled-box.tsx +0 -57
- package/source/components/usage/progress-bar.spec.tsx +0 -398
- package/source/components/usage/progress-bar.tsx +0 -30
- package/source/components/usage/usage-display.spec.tsx +0 -780
- package/source/components/usage/usage-display.tsx +0 -291
- package/source/components/user-input.spec.tsx +0 -327
- package/source/components/user-input.tsx +0 -533
- package/source/components/user-message.spec.tsx +0 -230
- package/source/components/user-message.tsx +0 -84
- package/source/components/welcome-message.tsx +0 -76
- package/source/config/env-substitution.ts +0 -65
- package/source/config/index.spec.ts +0 -171
- package/source/config/index.ts +0 -154
- package/source/config/paths.spec.ts +0 -241
- package/source/config/paths.ts +0 -55
- package/source/config/preferences.ts +0 -51
- package/source/config/themes.ts +0 -315
- package/source/constants.ts +0 -130
- package/source/context/mode-context.spec.ts +0 -79
- package/source/context/mode-context.ts +0 -24
- package/source/custom-commands/executor.spec.ts +0 -142
- package/source/custom-commands/executor.ts +0 -64
- package/source/custom-commands/loader.spec.ts +0 -314
- package/source/custom-commands/loader.ts +0 -153
- package/source/custom-commands/parser.ts +0 -196
- package/source/hooks/chat-handler/conversation/conversation-loop.spec.ts +0 -39
- package/source/hooks/chat-handler/conversation/conversation-loop.tsx +0 -511
- package/source/hooks/chat-handler/conversation/tool-executor.spec.ts +0 -50
- package/source/hooks/chat-handler/conversation/tool-executor.tsx +0 -109
- package/source/hooks/chat-handler/index.ts +0 -12
- package/source/hooks/chat-handler/state/streaming-state.spec.ts +0 -26
- package/source/hooks/chat-handler/state/streaming-state.ts +0 -19
- package/source/hooks/chat-handler/types.ts +0 -38
- package/source/hooks/chat-handler/useChatHandler.spec.tsx +0 -321
- package/source/hooks/chat-handler/useChatHandler.tsx +0 -194
- package/source/hooks/chat-handler/utils/context-checker.spec.ts +0 -60
- package/source/hooks/chat-handler/utils/context-checker.tsx +0 -73
- package/source/hooks/chat-handler/utils/message-helpers.spec.ts +0 -42
- package/source/hooks/chat-handler/utils/message-helpers.tsx +0 -36
- package/source/hooks/chat-handler/utils/tool-filters.spec.ts +0 -109
- package/source/hooks/chat-handler/utils/tool-filters.ts +0 -64
- package/source/hooks/useAppHandlers.tsx +0 -291
- package/source/hooks/useAppInitialization.tsx +0 -422
- package/source/hooks/useAppState.tsx +0 -311
- package/source/hooks/useDirectoryTrust.tsx +0 -98
- package/source/hooks/useInputState.ts +0 -414
- package/source/hooks/useModeHandlers.tsx +0 -302
- package/source/hooks/useNonInteractiveMode.ts +0 -140
- package/source/hooks/useTerminalWidth.tsx +0 -81
- package/source/hooks/useTheme.ts +0 -18
- package/source/hooks/useToolHandler.tsx +0 -349
- package/source/hooks/useUIState.ts +0 -61
- package/source/init/agents-template-generator.ts +0 -421
- package/source/init/existing-rules-extractor.ts +0 -319
- package/source/init/file-scanner.spec.ts +0 -227
- package/source/init/file-scanner.ts +0 -238
- package/source/init/framework-detector.ts +0 -382
- package/source/init/language-detector.ts +0 -269
- package/source/init/project-analyzer.spec.ts +0 -231
- package/source/init/project-analyzer.ts +0 -458
- package/source/lsp/index.ts +0 -31
- package/source/lsp/lsp-client.spec.ts +0 -508
- package/source/lsp/lsp-client.ts +0 -487
- package/source/lsp/lsp-manager.spec.ts +0 -477
- package/source/lsp/lsp-manager.ts +0 -419
- package/source/lsp/protocol.spec.ts +0 -502
- package/source/lsp/protocol.ts +0 -360
- package/source/lsp/server-discovery.spec.ts +0 -654
- package/source/lsp/server-discovery.ts +0 -515
- package/source/markdown-parser/html-entities.spec.ts +0 -88
- package/source/markdown-parser/html-entities.ts +0 -45
- package/source/markdown-parser/index.spec.ts +0 -281
- package/source/markdown-parser/index.ts +0 -126
- package/source/markdown-parser/table-parser.spec.ts +0 -133
- package/source/markdown-parser/table-parser.ts +0 -114
- package/source/markdown-parser/utils.spec.ts +0 -70
- package/source/markdown-parser/utils.ts +0 -13
- package/source/mcp/mcp-client.spec.ts +0 -81
- package/source/mcp/mcp-client.ts +0 -625
- package/source/mcp/transport-factory.spec.ts +0 -406
- package/source/mcp/transport-factory.ts +0 -312
- package/source/message-handler.ts +0 -67
- package/source/model-database/database-engine.spec.ts +0 -494
- package/source/model-database/database-engine.ts +0 -50
- package/source/model-database/model-database.spec.ts +0 -363
- package/source/model-database/model-database.ts +0 -91
- package/source/model-database/model-engine.spec.ts +0 -447
- package/source/model-database/model-engine.ts +0 -65
- package/source/model-database/model-fetcher.spec.ts +0 -583
- package/source/model-database/model-fetcher.ts +0 -330
- package/source/models/index.ts +0 -1
- package/source/models/models-cache.spec.ts +0 -214
- package/source/models/models-cache.ts +0 -78
- package/source/models/models-dev-client.spec.ts +0 -379
- package/source/models/models-dev-client.ts +0 -329
- package/source/models/models-types.ts +0 -68
- package/source/prompt-history.ts +0 -155
- package/source/security/command-injection.spec.ts +0 -240
- package/source/services/checkpoint-manager.spec.ts +0 -523
- package/source/services/checkpoint-manager.ts +0 -466
- package/source/services/file-snapshot.spec.ts +0 -569
- package/source/services/file-snapshot.ts +0 -220
- package/source/test-utils/render-with-theme.tsx +0 -48
- package/source/tokenization/index.ts +0 -1
- package/source/tokenization/tokenizer-factory.spec.ts +0 -170
- package/source/tokenization/tokenizer-factory.ts +0 -125
- package/source/tokenization/tokenizers/anthropic-tokenizer.spec.ts +0 -200
- package/source/tokenization/tokenizers/anthropic-tokenizer.ts +0 -43
- package/source/tokenization/tokenizers/fallback-tokenizer.spec.ts +0 -236
- package/source/tokenization/tokenizers/fallback-tokenizer.ts +0 -26
- package/source/tokenization/tokenizers/llama-tokenizer.spec.ts +0 -224
- package/source/tokenization/tokenizers/llama-tokenizer.ts +0 -41
- package/source/tokenization/tokenizers/openai-tokenizer.spec.ts +0 -184
- package/source/tokenization/tokenizers/openai-tokenizer.ts +0 -57
- package/source/tool-calling/index.ts +0 -5
- package/source/tool-calling/json-parser.spec.ts +0 -639
- package/source/tool-calling/json-parser.ts +0 -247
- package/source/tool-calling/tool-parser.spec.ts +0 -395
- package/source/tool-calling/tool-parser.ts +0 -120
- package/source/tool-calling/xml-parser.spec.ts +0 -662
- package/source/tool-calling/xml-parser.ts +0 -289
- package/source/tools/execute-bash.spec.tsx +0 -353
- package/source/tools/execute-bash.tsx +0 -219
- package/source/tools/execute-function.spec.ts +0 -130
- package/source/tools/fetch-url.spec.tsx +0 -342
- package/source/tools/fetch-url.tsx +0 -172
- package/source/tools/find-files.spec.tsx +0 -924
- package/source/tools/find-files.tsx +0 -293
- package/source/tools/index.ts +0 -102
- package/source/tools/lsp-get-diagnostics.tsx +0 -192
- package/source/tools/needs-approval.spec.ts +0 -282
- package/source/tools/read-file.spec.tsx +0 -801
- package/source/tools/read-file.tsx +0 -387
- package/source/tools/search-file-contents.spec.tsx +0 -1273
- package/source/tools/search-file-contents.tsx +0 -293
- package/source/tools/string-replace.spec.tsx +0 -730
- package/source/tools/string-replace.tsx +0 -548
- package/source/tools/tool-manager.ts +0 -210
- package/source/tools/tool-registry.spec.ts +0 -415
- package/source/tools/tool-registry.ts +0 -228
- package/source/tools/web-search.tsx +0 -223
- package/source/tools/write-file.spec.tsx +0 -559
- package/source/tools/write-file.tsx +0 -228
- package/source/types/app.ts +0 -37
- package/source/types/checkpoint.ts +0 -48
- package/source/types/commands.ts +0 -46
- package/source/types/components.ts +0 -27
- package/source/types/config.ts +0 -103
- package/source/types/core-connection-status.spec.ts +0 -67
- package/source/types/core.ts +0 -181
- package/source/types/hooks.ts +0 -50
- package/source/types/index.ts +0 -12
- package/source/types/markdown-parser.ts +0 -11
- package/source/types/mcp.ts +0 -52
- package/source/types/system.ts +0 -16
- package/source/types/tokenization.ts +0 -41
- package/source/types/ui.ts +0 -40
- package/source/types/usage.ts +0 -58
- package/source/types/utils.ts +0 -16
- package/source/usage/calculator.spec.ts +0 -385
- package/source/usage/calculator.ts +0 -104
- package/source/usage/storage.spec.ts +0 -703
- package/source/usage/storage.ts +0 -238
- package/source/usage/tracker.spec.ts +0 -456
- package/source/usage/tracker.ts +0 -102
- package/source/utils/atomic-deletion.spec.ts +0 -194
- package/source/utils/atomic-deletion.ts +0 -127
- package/source/utils/bounded-map.spec.ts +0 -300
- package/source/utils/bounded-map.ts +0 -193
- package/source/utils/checkpoint-utils.spec.ts +0 -222
- package/source/utils/checkpoint-utils.ts +0 -92
- package/source/utils/error-formatter.spec.ts +0 -169
- package/source/utils/error-formatter.ts +0 -194
- package/source/utils/file-autocomplete.spec.ts +0 -173
- package/source/utils/file-autocomplete.ts +0 -196
- package/source/utils/file-cache.spec.ts +0 -309
- package/source/utils/file-cache.ts +0 -195
- package/source/utils/file-content-loader.spec.ts +0 -180
- package/source/utils/file-content-loader.ts +0 -179
- package/source/utils/file-mention-handler.spec.ts +0 -261
- package/source/utils/file-mention-handler.ts +0 -84
- package/source/utils/file-mention-parser.spec.ts +0 -182
- package/source/utils/file-mention-parser.ts +0 -170
- package/source/utils/fuzzy-matching.spec.ts +0 -149
- package/source/utils/fuzzy-matching.ts +0 -146
- package/source/utils/indentation-normalizer.spec.ts +0 -216
- package/source/utils/indentation-normalizer.ts +0 -76
- package/source/utils/installation-detector.spec.ts +0 -178
- package/source/utils/installation-detector.ts +0 -153
- package/source/utils/logging/config.spec.ts +0 -311
- package/source/utils/logging/config.ts +0 -210
- package/source/utils/logging/console-facade.spec.ts +0 -184
- package/source/utils/logging/console-facade.ts +0 -384
- package/source/utils/logging/correlation.spec.ts +0 -679
- package/source/utils/logging/correlation.ts +0 -474
- package/source/utils/logging/formatters.spec.ts +0 -464
- package/source/utils/logging/formatters.ts +0 -207
- package/source/utils/logging/health-monitor/alerts/alert-manager.spec.ts +0 -93
- package/source/utils/logging/health-monitor/alerts/alert-manager.ts +0 -79
- package/source/utils/logging/health-monitor/checks/configuration-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/configuration-check.ts +0 -43
- package/source/utils/logging/health-monitor/checks/logging-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/logging-check.ts +0 -58
- package/source/utils/logging/health-monitor/checks/memory-check.spec.ts +0 -100
- package/source/utils/logging/health-monitor/checks/memory-check.ts +0 -78
- package/source/utils/logging/health-monitor/checks/performance-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/performance-check.ts +0 -56
- package/source/utils/logging/health-monitor/checks/request-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/request-check.ts +0 -76
- package/source/utils/logging/health-monitor/core/health-check-runner.spec.ts +0 -70
- package/source/utils/logging/health-monitor/core/health-check-runner.ts +0 -138
- package/source/utils/logging/health-monitor/core/health-monitor.spec.ts +0 -58
- package/source/utils/logging/health-monitor/core/health-monitor.ts +0 -344
- package/source/utils/logging/health-monitor/core/scoring.spec.ts +0 -65
- package/source/utils/logging/health-monitor/core/scoring.ts +0 -91
- package/source/utils/logging/health-monitor/index.ts +0 -15
- package/source/utils/logging/health-monitor/instances.ts +0 -48
- package/source/utils/logging/health-monitor/middleware/http-middleware.spec.ts +0 -141
- package/source/utils/logging/health-monitor/middleware/http-middleware.ts +0 -75
- package/source/utils/logging/health-monitor/types.ts +0 -126
- package/source/utils/logging/index.spec.ts +0 -284
- package/source/utils/logging/index.ts +0 -236
- package/source/utils/logging/integration.spec.ts +0 -441
- package/source/utils/logging/log-method-factory.spec.ts +0 -573
- package/source/utils/logging/log-method-factory.ts +0 -233
- package/source/utils/logging/log-query/aggregation/aggregator.spec.ts +0 -277
- package/source/utils/logging/log-query/aggregation/aggregator.ts +0 -159
- package/source/utils/logging/log-query/aggregation/facet-generator.spec.ts +0 -159
- package/source/utils/logging/log-query/aggregation/facet-generator.ts +0 -47
- package/source/utils/logging/log-query/index.ts +0 -23
- package/source/utils/logging/log-query/query/filter-predicates.spec.ts +0 -247
- package/source/utils/logging/log-query/query/filter-predicates.ts +0 -154
- package/source/utils/logging/log-query/query/query-builder.spec.ts +0 -182
- package/source/utils/logging/log-query/query/query-builder.ts +0 -151
- package/source/utils/logging/log-query/query/query-engine.spec.ts +0 -214
- package/source/utils/logging/log-query/query/query-engine.ts +0 -45
- package/source/utils/logging/log-query/storage/circular-buffer.spec.ts +0 -143
- package/source/utils/logging/log-query/storage/circular-buffer.ts +0 -75
- package/source/utils/logging/log-query/storage/index-manager.spec.ts +0 -150
- package/source/utils/logging/log-query/storage/index-manager.ts +0 -71
- package/source/utils/logging/log-query/storage/log-storage.spec.ts +0 -257
- package/source/utils/logging/log-query/storage/log-storage.ts +0 -80
- package/source/utils/logging/log-query/types.ts +0 -163
- package/source/utils/logging/log-query/utils/helpers.spec.ts +0 -263
- package/source/utils/logging/log-query/utils/helpers.ts +0 -72
- package/source/utils/logging/log-query/utils/sorting.spec.ts +0 -182
- package/source/utils/logging/log-query/utils/sorting.ts +0 -61
- package/source/utils/logging/logger-provider.spec.ts +0 -262
- package/source/utils/logging/logger-provider.ts +0 -362
- package/source/utils/logging/performance.spec.ts +0 -209
- package/source/utils/logging/performance.ts +0 -757
- package/source/utils/logging/pino-logger.spec.ts +0 -425
- package/source/utils/logging/pino-logger.ts +0 -514
- package/source/utils/logging/redaction.spec.ts +0 -490
- package/source/utils/logging/redaction.ts +0 -267
- package/source/utils/logging/request-tracker.spec.ts +0 -1198
- package/source/utils/logging/request-tracker.ts +0 -803
- package/source/utils/logging/transports.spec.ts +0 -505
- package/source/utils/logging/transports.ts +0 -305
- package/source/utils/logging/types.ts +0 -216
- package/source/utils/message-builder.spec.ts +0 -179
- package/source/utils/message-builder.ts +0 -101
- package/source/utils/message-queue.tsx +0 -486
- package/source/utils/paste-detection.spec.ts +0 -69
- package/source/utils/paste-detection.ts +0 -124
- package/source/utils/paste-roundtrip.spec.ts +0 -442
- package/source/utils/paste-utils.spec.ts +0 -128
- package/source/utils/paste-utils.ts +0 -52
- package/source/utils/programming-language-helper.spec.ts +0 -74
- package/source/utils/programming-language-helper.ts +0 -32
- package/source/utils/prompt-assembly.spec.ts +0 -221
- package/source/utils/prompt-processor.ts +0 -173
- package/source/utils/tool-args-parser.spec.ts +0 -136
- package/source/utils/tool-args-parser.ts +0 -54
- package/source/utils/tool-cancellation.spec.ts +0 -230
- package/source/utils/tool-cancellation.ts +0 -28
- package/source/utils/tool-result-display.spec.tsx +0 -469
- package/source/utils/tool-result-display.tsx +0 -90
- package/source/utils/update-checker.spec.ts +0 -383
- package/source/utils/update-checker.ts +0 -183
- package/source/wizard/config-wizard.spec.tsx +0 -103
- package/source/wizard/config-wizard.tsx +0 -382
- package/source/wizard/steps/location-step.spec.tsx +0 -186
- package/source/wizard/steps/location-step.tsx +0 -147
- package/source/wizard/steps/mcp-step.spec.tsx +0 -607
- package/source/wizard/steps/mcp-step.tsx +0 -632
- package/source/wizard/steps/provider-step.spec.tsx +0 -342
- package/source/wizard/steps/provider-step.tsx +0 -957
- package/source/wizard/steps/summary-step.spec.tsx +0 -749
- package/source/wizard/steps/summary-step.tsx +0 -228
- package/source/wizard/templates/mcp-templates.spec.ts +0 -613
- package/source/wizard/templates/mcp-templates.ts +0 -570
- package/source/wizard/templates/provider-templates.spec.ts +0 -152
- package/source/wizard/templates/provider-templates.ts +0 -485
- package/source/wizard/utils/fetch-cloud-models.spec.ts +0 -428
- package/source/wizard/utils/fetch-cloud-models.ts +0 -223
- package/source/wizard/utils/fetch-local-models.spec.ts +0 -297
- package/source/wizard/utils/fetch-local-models.ts +0 -192
- package/source/wizard/validation-array.spec.ts +0 -264
- package/source/wizard/validation.spec.ts +0 -373
- package/source/wizard/validation.ts +0 -232
|
@@ -1,210 +0,0 @@
|
|
|
1
|
-
import {MCPClient} from '@/mcp/mcp-client';
|
|
2
|
-
import {
|
|
3
|
-
nativeToolsRegistry as staticNativeToolsRegistry,
|
|
4
|
-
toolFormatters as staticToolFormatters,
|
|
5
|
-
toolRegistry as staticToolRegistry,
|
|
6
|
-
toolValidators as staticToolValidators,
|
|
7
|
-
} from '@/tools/index';
|
|
8
|
-
import {ToolRegistry} from '@/tools/tool-registry';
|
|
9
|
-
import type {
|
|
10
|
-
AISDKCoreTool,
|
|
11
|
-
MCPInitResult,
|
|
12
|
-
MCPServer,
|
|
13
|
-
MCPTool,
|
|
14
|
-
ToolEntry,
|
|
15
|
-
ToolFormatter,
|
|
16
|
-
ToolHandler,
|
|
17
|
-
ToolValidator,
|
|
18
|
-
} from '@/types/index';
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* Manages both static tools and dynamic MCP tools
|
|
22
|
-
* All tools are stored in unified ToolEntry format via ToolRegistry
|
|
23
|
-
*/
|
|
24
|
-
export class ToolManager {
|
|
25
|
-
/**
|
|
26
|
-
* Unified tool registry using ToolRegistry helper class
|
|
27
|
-
*/
|
|
28
|
-
private registry: ToolRegistry;
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* MCP client for dynamic tool discovery and execution
|
|
32
|
-
*/
|
|
33
|
-
private mcpClient: MCPClient | null = null;
|
|
34
|
-
|
|
35
|
-
constructor() {
|
|
36
|
-
// Initialize with static tools using ToolRegistry factory method
|
|
37
|
-
this.registry = ToolRegistry.fromRegistries(
|
|
38
|
-
staticToolRegistry,
|
|
39
|
-
staticNativeToolsRegistry,
|
|
40
|
-
staticToolFormatters,
|
|
41
|
-
staticToolValidators,
|
|
42
|
-
);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* Initialize MCP servers and register their tools
|
|
47
|
-
*/
|
|
48
|
-
async initializeMCP(
|
|
49
|
-
servers: MCPServer[],
|
|
50
|
-
onProgress?: (result: MCPInitResult) => void,
|
|
51
|
-
): Promise<MCPInitResult[]> {
|
|
52
|
-
if (servers && servers.length > 0) {
|
|
53
|
-
this.mcpClient = new MCPClient();
|
|
54
|
-
|
|
55
|
-
const results = await this.mcpClient.connectToServers(
|
|
56
|
-
servers,
|
|
57
|
-
onProgress,
|
|
58
|
-
);
|
|
59
|
-
|
|
60
|
-
// Register MCP tools using ToolRegistry
|
|
61
|
-
// getToolEntries() returns structured ToolEntry objects
|
|
62
|
-
const mcpToolEntries = this.mcpClient.getToolEntries();
|
|
63
|
-
this.registry.registerMany(mcpToolEntries);
|
|
64
|
-
|
|
65
|
-
return results;
|
|
66
|
-
}
|
|
67
|
-
return [];
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* Get all available native AI SDK tools (static + MCP)
|
|
72
|
-
*/
|
|
73
|
-
getAllTools(): Record<string, AISDKCoreTool> {
|
|
74
|
-
return this.registry.getNativeTools();
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
/**
|
|
78
|
-
* Get all tool handlers
|
|
79
|
-
*/
|
|
80
|
-
getToolRegistry(): Record<string, ToolHandler> {
|
|
81
|
-
return this.registry.getHandlers();
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
/**
|
|
85
|
-
* Get a specific tool handler
|
|
86
|
-
*/
|
|
87
|
-
getToolHandler(toolName: string): ToolHandler | undefined {
|
|
88
|
-
return this.registry.getHandler(toolName);
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* Get a specific tool formatter
|
|
93
|
-
*/
|
|
94
|
-
getToolFormatter(toolName: string): ToolFormatter | undefined {
|
|
95
|
-
return this.registry.getFormatter(toolName);
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
/**
|
|
99
|
-
* Get a specific tool validator
|
|
100
|
-
*/
|
|
101
|
-
getToolValidator(toolName: string): ToolValidator | undefined {
|
|
102
|
-
return this.registry.getValidator(toolName);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
/**
|
|
106
|
-
* Check if a tool exists
|
|
107
|
-
*/
|
|
108
|
-
hasTool(toolName: string): boolean {
|
|
109
|
-
return this.registry.hasTool(toolName);
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
/**
|
|
113
|
-
* Check if a tool is an MCP tool and get server info
|
|
114
|
-
*/
|
|
115
|
-
getMCPToolInfo(toolName: string): {isMCPTool: boolean; serverName?: string} {
|
|
116
|
-
if (!this.mcpClient) {
|
|
117
|
-
return {isMCPTool: false};
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
const toolMapping = this.mcpClient.getToolMapping();
|
|
121
|
-
const mapping = toolMapping.get(toolName);
|
|
122
|
-
|
|
123
|
-
if (mapping) {
|
|
124
|
-
return {
|
|
125
|
-
isMCPTool: true,
|
|
126
|
-
serverName: mapping.serverName,
|
|
127
|
-
};
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
return {isMCPTool: false};
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
/**
|
|
134
|
-
* Disconnect from MCP servers and remove their tools
|
|
135
|
-
*/
|
|
136
|
-
async disconnectMCP(): Promise<void> {
|
|
137
|
-
if (this.mcpClient) {
|
|
138
|
-
// Get list of MCP tool names
|
|
139
|
-
const mcpTools = this.mcpClient.getNativeToolsRegistry();
|
|
140
|
-
const mcpToolNames = Object.keys(mcpTools);
|
|
141
|
-
|
|
142
|
-
// Remove all MCP tools from registry in one operation
|
|
143
|
-
this.registry.unregisterMany(mcpToolNames);
|
|
144
|
-
|
|
145
|
-
// Disconnect from servers
|
|
146
|
-
await this.mcpClient.disconnect();
|
|
147
|
-
|
|
148
|
-
// Reset registry to only static tools
|
|
149
|
-
this.registry = ToolRegistry.fromRegistries(
|
|
150
|
-
staticToolRegistry,
|
|
151
|
-
staticNativeToolsRegistry,
|
|
152
|
-
staticToolFormatters,
|
|
153
|
-
staticToolValidators,
|
|
154
|
-
);
|
|
155
|
-
|
|
156
|
-
this.mcpClient = null;
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
/**
|
|
161
|
-
* Get a complete tool entry (all metadata)
|
|
162
|
-
*
|
|
163
|
-
* Returns the full ToolEntry with all components (tool, handler, formatter, validator)
|
|
164
|
-
*/
|
|
165
|
-
getToolEntry(toolName: string): ToolEntry | undefined {
|
|
166
|
-
return this.registry.getEntry(toolName);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
/**
|
|
170
|
-
* Get all registered tool names
|
|
171
|
-
*/
|
|
172
|
-
getToolNames(): string[] {
|
|
173
|
-
return this.registry.getToolNames();
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
/**
|
|
177
|
-
* Get total number of registered tools
|
|
178
|
-
*/
|
|
179
|
-
getToolCount(): number {
|
|
180
|
-
return this.registry.getToolCount();
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
/**
|
|
184
|
-
* Get connected MCP servers
|
|
185
|
-
*/
|
|
186
|
-
getConnectedServers(): string[] {
|
|
187
|
-
return this.mcpClient?.getConnectedServers() || [];
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
/**
|
|
191
|
-
* Get tools for a specific MCP server
|
|
192
|
-
*/
|
|
193
|
-
getServerTools(serverName: string): MCPTool[] {
|
|
194
|
-
return this.mcpClient?.getServerTools(serverName) || [];
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
/**
|
|
198
|
-
* Get server information including transport type and URL
|
|
199
|
-
*/
|
|
200
|
-
getServerInfo(serverName: string) {
|
|
201
|
-
return this.mcpClient?.getServerInfo(serverName);
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
/**
|
|
205
|
-
* Get the MCP client instance
|
|
206
|
-
*/
|
|
207
|
-
getMCPClient() {
|
|
208
|
-
return this.mcpClient;
|
|
209
|
-
}
|
|
210
|
-
}
|
|
@@ -1,415 +0,0 @@
|
|
|
1
|
-
import test from 'ava';
|
|
2
|
-
import { ToolRegistry } from './tool-registry';
|
|
3
|
-
import type { ToolEntry } from '@/types/index';
|
|
4
|
-
|
|
5
|
-
// Mock tool handler function - returns Promise<string>
|
|
6
|
-
const mockHandler: ToolEntry['handler'] = async () => 'test result';
|
|
7
|
-
|
|
8
|
-
// Mock formatter function
|
|
9
|
-
const mockFormatter: ToolEntry['formatter'] = (output: unknown) => {
|
|
10
|
-
return String(output);
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
// Mock validator function - returns Promise<{valid: true} | {valid: false, error: string}>
|
|
14
|
-
const mockValidator: ToolEntry['validator'] = async () => ({ valid: true });
|
|
15
|
-
|
|
16
|
-
// Mock AI SDK tool - cast to any since we're just testing registry functionality
|
|
17
|
-
const mockTool: ToolEntry['tool'] = {
|
|
18
|
-
execute: async () => 'test result',
|
|
19
|
-
} as any;
|
|
20
|
-
|
|
21
|
-
function createMockToolEntry(overrides: Partial<ToolEntry> = {}): ToolEntry {
|
|
22
|
-
return {
|
|
23
|
-
name: 'test-tool',
|
|
24
|
-
handler: mockHandler,
|
|
25
|
-
tool: mockTool,
|
|
26
|
-
formatter: mockFormatter,
|
|
27
|
-
validator: mockValidator,
|
|
28
|
-
...overrides
|
|
29
|
-
} as ToolEntry;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
test('ToolRegistry - register adds a tool entry', t => {
|
|
33
|
-
const registry = new ToolRegistry();
|
|
34
|
-
const entry = createMockToolEntry();
|
|
35
|
-
|
|
36
|
-
registry.register(entry);
|
|
37
|
-
|
|
38
|
-
t.true(registry.hasTool('test-tool'));
|
|
39
|
-
t.is(registry.getToolCount(), 1);
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
test('ToolRegistry - registerMany adds multiple tools', t => {
|
|
43
|
-
const registry = new ToolRegistry();
|
|
44
|
-
const entries = [
|
|
45
|
-
createMockToolEntry({ name: 'tool1' }),
|
|
46
|
-
createMockToolEntry({ name: 'tool2' }),
|
|
47
|
-
createMockToolEntry({ name: 'tool3' })
|
|
48
|
-
];
|
|
49
|
-
|
|
50
|
-
registry.registerMany(entries);
|
|
51
|
-
|
|
52
|
-
t.is(registry.getToolCount(), 3);
|
|
53
|
-
t.true(registry.hasTool('tool1'));
|
|
54
|
-
t.true(registry.hasTool('tool2'));
|
|
55
|
-
t.true(registry.hasTool('tool3'));
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
test('ToolRegistry - registerMany with empty array', t => {
|
|
59
|
-
const registry = new ToolRegistry();
|
|
60
|
-
|
|
61
|
-
registry.registerMany([]);
|
|
62
|
-
|
|
63
|
-
t.is(registry.getToolCount(), 0);
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
test('ToolRegistry - unregister removes a tool', t => {
|
|
67
|
-
const registry = new ToolRegistry();
|
|
68
|
-
const entry = createMockToolEntry();
|
|
69
|
-
|
|
70
|
-
registry.register(entry);
|
|
71
|
-
t.true(registry.hasTool('test-tool'));
|
|
72
|
-
|
|
73
|
-
registry.unregister('test-tool');
|
|
74
|
-
t.false(registry.hasTool('test-tool'));
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
test('ToolRegistry - unregisterMany removes multiple tools', t => {
|
|
78
|
-
const registry = new ToolRegistry();
|
|
79
|
-
registry.registerMany([
|
|
80
|
-
createMockToolEntry({ name: 'tool1' }),
|
|
81
|
-
createMockToolEntry({ name: 'tool2' }),
|
|
82
|
-
createMockToolEntry({ name: 'tool3' })
|
|
83
|
-
]);
|
|
84
|
-
|
|
85
|
-
registry.unregisterMany(['tool1', 'tool3']);
|
|
86
|
-
|
|
87
|
-
t.false(registry.hasTool('tool1'));
|
|
88
|
-
t.true(registry.hasTool('tool2'));
|
|
89
|
-
t.false(registry.hasTool('tool3'));
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
test('ToolRegistry - unregisterMany with empty array', t => {
|
|
93
|
-
const registry = new ToolRegistry();
|
|
94
|
-
const entry = createMockToolEntry();
|
|
95
|
-
|
|
96
|
-
registry.register(entry);
|
|
97
|
-
registry.unregisterMany([]);
|
|
98
|
-
|
|
99
|
-
t.true(registry.hasTool('test-tool'));
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
test('ToolRegistry - getEntry returns tool entry', t => {
|
|
103
|
-
const registry = new ToolRegistry();
|
|
104
|
-
const entry = createMockToolEntry();
|
|
105
|
-
|
|
106
|
-
registry.register(entry);
|
|
107
|
-
const retrieved = registry.getEntry('test-tool');
|
|
108
|
-
|
|
109
|
-
t.truthy(retrieved);
|
|
110
|
-
t.is(retrieved?.name, 'test-tool');
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
test('ToolRegistry - getEntry returns undefined for non-existent tool', t => {
|
|
114
|
-
const registry = new ToolRegistry();
|
|
115
|
-
|
|
116
|
-
const retrieved = registry.getEntry('non-existent');
|
|
117
|
-
|
|
118
|
-
t.is(retrieved, undefined);
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
test('ToolRegistry - getHandler returns tool handler', t => {
|
|
122
|
-
const registry = new ToolRegistry();
|
|
123
|
-
const entry = createMockToolEntry();
|
|
124
|
-
|
|
125
|
-
registry.register(entry);
|
|
126
|
-
const handler = registry.getHandler('test-tool');
|
|
127
|
-
|
|
128
|
-
t.truthy(handler);
|
|
129
|
-
t.is(handler, mockHandler);
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
test('ToolRegistry - getHandler returns undefined for non-existent tool', t => {
|
|
133
|
-
const registry = new ToolRegistry();
|
|
134
|
-
|
|
135
|
-
const handler = registry.getHandler('non-existent');
|
|
136
|
-
|
|
137
|
-
t.is(handler, undefined);
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
test('ToolRegistry - getFormatter returns tool formatter', t => {
|
|
141
|
-
const registry = new ToolRegistry();
|
|
142
|
-
const entry = createMockToolEntry();
|
|
143
|
-
|
|
144
|
-
registry.register(entry);
|
|
145
|
-
const formatter = registry.getFormatter('test-tool');
|
|
146
|
-
|
|
147
|
-
t.truthy(formatter);
|
|
148
|
-
t.is(formatter, mockFormatter);
|
|
149
|
-
});
|
|
150
|
-
|
|
151
|
-
test('ToolRegistry - getFormatter returns undefined when no formatter', t => {
|
|
152
|
-
const registry = new ToolRegistry();
|
|
153
|
-
const entry = createMockToolEntry({ formatter: undefined });
|
|
154
|
-
|
|
155
|
-
registry.register(entry);
|
|
156
|
-
const formatter = registry.getFormatter('test-tool');
|
|
157
|
-
|
|
158
|
-
t.is(formatter, undefined);
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
test('ToolRegistry - getValidator returns tool validator', t => {
|
|
162
|
-
const registry = new ToolRegistry();
|
|
163
|
-
const entry = createMockToolEntry();
|
|
164
|
-
|
|
165
|
-
registry.register(entry);
|
|
166
|
-
const validator = registry.getValidator('test-tool');
|
|
167
|
-
|
|
168
|
-
t.truthy(validator);
|
|
169
|
-
t.is(validator, mockValidator);
|
|
170
|
-
});
|
|
171
|
-
|
|
172
|
-
test('ToolRegistry - getValidator returns undefined when no validator', t => {
|
|
173
|
-
const registry = new ToolRegistry();
|
|
174
|
-
const entry = createMockToolEntry({ validator: undefined });
|
|
175
|
-
|
|
176
|
-
registry.register(entry);
|
|
177
|
-
const validator = registry.getValidator('test-tool');
|
|
178
|
-
|
|
179
|
-
t.is(validator, undefined);
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
test('ToolRegistry - getTool returns native AI SDK tool', t => {
|
|
183
|
-
const registry = new ToolRegistry();
|
|
184
|
-
const entry = createMockToolEntry();
|
|
185
|
-
|
|
186
|
-
registry.register(entry);
|
|
187
|
-
const tool = registry.getTool('test-tool');
|
|
188
|
-
|
|
189
|
-
t.truthy(tool);
|
|
190
|
-
t.is(tool, mockTool);
|
|
191
|
-
});
|
|
192
|
-
|
|
193
|
-
test('ToolRegistry - getTool returns undefined for non-existent tool', t => {
|
|
194
|
-
const registry = new ToolRegistry();
|
|
195
|
-
|
|
196
|
-
const tool = registry.getTool('non-existent');
|
|
197
|
-
|
|
198
|
-
t.is(tool, undefined);
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
test('ToolRegistry - getHandlers returns record of all handlers', t => {
|
|
202
|
-
const registry = new ToolRegistry();
|
|
203
|
-
const handler1: ToolEntry['handler'] = async () => 'result 1';
|
|
204
|
-
const handler2: ToolEntry['handler'] = async () => 'result 2';
|
|
205
|
-
|
|
206
|
-
registry.registerMany([
|
|
207
|
-
createMockToolEntry({ name: 'tool1', handler: handler1 }),
|
|
208
|
-
createMockToolEntry({ name: 'tool2', handler: handler2 })
|
|
209
|
-
]);
|
|
210
|
-
|
|
211
|
-
const handlers = registry.getHandlers();
|
|
212
|
-
|
|
213
|
-
t.is(handlers.tool1, handler1);
|
|
214
|
-
t.is(handlers.tool2, handler2);
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
test('ToolRegistry - getHandlers returns empty object when no tools', t => {
|
|
218
|
-
const registry = new ToolRegistry();
|
|
219
|
-
|
|
220
|
-
const handlers = registry.getHandlers();
|
|
221
|
-
|
|
222
|
-
t.deepEqual(handlers, {});
|
|
223
|
-
});
|
|
224
|
-
|
|
225
|
-
test('ToolRegistry - getFormatters returns record of formatters', t => {
|
|
226
|
-
const registry = new ToolRegistry();
|
|
227
|
-
const formatter1: ToolEntry['formatter'] = (o) => String(o);
|
|
228
|
-
const formatter2: ToolEntry['formatter'] = (o) => String(o);
|
|
229
|
-
|
|
230
|
-
registry.registerMany([
|
|
231
|
-
createMockToolEntry({ name: 'tool1', formatter: formatter1 }),
|
|
232
|
-
createMockToolEntry({ name: 'tool2', formatter: formatter2 }),
|
|
233
|
-
createMockToolEntry({ name: 'tool3', formatter: undefined })
|
|
234
|
-
]);
|
|
235
|
-
|
|
236
|
-
const formatters = registry.getFormatters();
|
|
237
|
-
|
|
238
|
-
t.is(formatters.tool1, formatter1);
|
|
239
|
-
t.is(formatters.tool2, formatter2);
|
|
240
|
-
// tool3 has no formatter, so it shouldn't be in the record
|
|
241
|
-
t.false('tool3' in formatters);
|
|
242
|
-
});
|
|
243
|
-
|
|
244
|
-
test('ToolRegistry - getValidators returns record of validators', t => {
|
|
245
|
-
const registry = new ToolRegistry();
|
|
246
|
-
const validator1: ToolEntry['validator'] = async () => ({ valid: true });
|
|
247
|
-
const validator2: ToolEntry['validator'] = async () => ({ valid: false, error: 'test error' });
|
|
248
|
-
|
|
249
|
-
registry.registerMany([
|
|
250
|
-
createMockToolEntry({ name: 'tool1', validator: validator1 }),
|
|
251
|
-
createMockToolEntry({ name: 'tool2', validator: validator2 }),
|
|
252
|
-
createMockToolEntry({ name: 'tool3', validator: undefined })
|
|
253
|
-
]);
|
|
254
|
-
|
|
255
|
-
const validators = registry.getValidators();
|
|
256
|
-
|
|
257
|
-
t.is(validators.tool1, validator1);
|
|
258
|
-
t.is(validators.tool2, validator2);
|
|
259
|
-
// tool3 has no validator, so it shouldn't be in the record
|
|
260
|
-
t.false('tool3' in validators);
|
|
261
|
-
});
|
|
262
|
-
|
|
263
|
-
test('ToolRegistry - getNativeTools returns record of native tools', t => {
|
|
264
|
-
const registry = new ToolRegistry();
|
|
265
|
-
const tool1: ToolEntry['tool'] = { execute: async () => 'test 1' } as any;
|
|
266
|
-
const tool2: ToolEntry['tool'] = { execute: async () => 'test 2' } as any;
|
|
267
|
-
|
|
268
|
-
registry.registerMany([
|
|
269
|
-
createMockToolEntry({ name: 'tool1', tool: tool1 }),
|
|
270
|
-
createMockToolEntry({ name: 'tool2', tool: tool2 })
|
|
271
|
-
]);
|
|
272
|
-
|
|
273
|
-
const nativeTools = registry.getNativeTools();
|
|
274
|
-
|
|
275
|
-
t.is(nativeTools.tool1, tool1);
|
|
276
|
-
t.is(nativeTools.tool2, tool2);
|
|
277
|
-
});
|
|
278
|
-
|
|
279
|
-
test('ToolRegistry - getAllEntries returns array of all entries', t => {
|
|
280
|
-
const registry = new ToolRegistry();
|
|
281
|
-
const entry1 = createMockToolEntry({ name: 'tool1' });
|
|
282
|
-
const entry2 = createMockToolEntry({ name: 'tool2' });
|
|
283
|
-
|
|
284
|
-
registry.registerMany([entry1, entry2]);
|
|
285
|
-
|
|
286
|
-
const entries = registry.getAllEntries();
|
|
287
|
-
|
|
288
|
-
t.is(entries.length, 2);
|
|
289
|
-
t.true(entries.some(e => e.name === 'tool1'));
|
|
290
|
-
t.true(entries.some(e => e.name === 'tool2'));
|
|
291
|
-
});
|
|
292
|
-
|
|
293
|
-
test('ToolRegistry - getAllEntries returns empty array when no tools', t => {
|
|
294
|
-
const registry = new ToolRegistry();
|
|
295
|
-
|
|
296
|
-
const entries = registry.getAllEntries();
|
|
297
|
-
|
|
298
|
-
t.deepEqual(entries, []);
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
test('ToolRegistry - getToolNames returns array of tool names', t => {
|
|
302
|
-
const registry = new ToolRegistry();
|
|
303
|
-
registry.registerMany([
|
|
304
|
-
createMockToolEntry({ name: 'tool1' }),
|
|
305
|
-
createMockToolEntry({ name: 'tool2' }),
|
|
306
|
-
createMockToolEntry({ name: 'tool3' })
|
|
307
|
-
]);
|
|
308
|
-
|
|
309
|
-
const names = registry.getToolNames();
|
|
310
|
-
|
|
311
|
-
t.is(names.length, 3);
|
|
312
|
-
t.true(names.includes('tool1'));
|
|
313
|
-
t.true(names.includes('tool2'));
|
|
314
|
-
t.true(names.includes('tool3'));
|
|
315
|
-
});
|
|
316
|
-
|
|
317
|
-
test('ToolRegistry - getToolNames returns empty array when no tools', t => {
|
|
318
|
-
const registry = new ToolRegistry();
|
|
319
|
-
|
|
320
|
-
const names = registry.getToolNames();
|
|
321
|
-
|
|
322
|
-
t.deepEqual(names, []);
|
|
323
|
-
});
|
|
324
|
-
|
|
325
|
-
test('ToolRegistry - hasTool returns true for registered tool', t => {
|
|
326
|
-
const registry = new ToolRegistry();
|
|
327
|
-
registry.register(createMockToolEntry());
|
|
328
|
-
|
|
329
|
-
t.true(registry.hasTool('test-tool'));
|
|
330
|
-
});
|
|
331
|
-
|
|
332
|
-
test('ToolRegistry - hasTool returns false for non-existent tool', t => {
|
|
333
|
-
const registry = new ToolRegistry();
|
|
334
|
-
|
|
335
|
-
t.false(registry.hasTool('non-existent'));
|
|
336
|
-
});
|
|
337
|
-
|
|
338
|
-
test('ToolRegistry - getToolCount returns correct count', t => {
|
|
339
|
-
const registry = new ToolRegistry();
|
|
340
|
-
|
|
341
|
-
t.is(registry.getToolCount(), 0);
|
|
342
|
-
|
|
343
|
-
registry.register(createMockToolEntry());
|
|
344
|
-
t.is(registry.getToolCount(), 1);
|
|
345
|
-
|
|
346
|
-
registry.registerMany([
|
|
347
|
-
createMockToolEntry({ name: 'tool1' }),
|
|
348
|
-
createMockToolEntry({ name: 'tool2' })
|
|
349
|
-
]);
|
|
350
|
-
t.is(registry.getToolCount(), 3);
|
|
351
|
-
});
|
|
352
|
-
|
|
353
|
-
test('ToolRegistry - clear removes all tools', t => {
|
|
354
|
-
const registry = new ToolRegistry();
|
|
355
|
-
registry.registerMany([
|
|
356
|
-
createMockToolEntry({ name: 'tool1' }),
|
|
357
|
-
createMockToolEntry({ name: 'tool2' }),
|
|
358
|
-
createMockToolEntry({ name: 'tool3' })
|
|
359
|
-
]);
|
|
360
|
-
|
|
361
|
-
registry.clear();
|
|
362
|
-
|
|
363
|
-
t.is(registry.getToolCount(), 0);
|
|
364
|
-
t.false(registry.hasTool('tool1'));
|
|
365
|
-
t.false(registry.hasTool('tool2'));
|
|
366
|
-
t.false(registry.hasTool('tool3'));
|
|
367
|
-
});
|
|
368
|
-
|
|
369
|
-
test('ToolRegistry - fromRegistries creates registry from records', t => {
|
|
370
|
-
const handler1: ToolEntry['handler'] = async () => 'test';
|
|
371
|
-
const handler2: ToolEntry['handler'] = async () => 'test';
|
|
372
|
-
const formatter1: ToolEntry['formatter'] = (o) => String(o);
|
|
373
|
-
const validator1: ToolEntry['validator'] = async () => ({ valid: true });
|
|
374
|
-
const tool1: ToolEntry['tool'] = { execute: async () => 'test' } as any;
|
|
375
|
-
const tool2: ToolEntry['tool'] = { execute: async () => 'test' } as any;
|
|
376
|
-
|
|
377
|
-
const handlers = { tool1: handler1, tool2: handler2 };
|
|
378
|
-
const tools = { tool1, tool2 };
|
|
379
|
-
const formatters = { tool1: formatter1 };
|
|
380
|
-
const validators = { tool1: validator1 };
|
|
381
|
-
|
|
382
|
-
const registry = ToolRegistry.fromRegistries(handlers, tools, formatters, validators);
|
|
383
|
-
|
|
384
|
-
t.is(registry.getToolCount(), 2);
|
|
385
|
-
t.true(registry.hasTool('tool1'));
|
|
386
|
-
t.true(registry.hasTool('tool2'));
|
|
387
|
-
t.is(registry.getHandler('tool1'), handler1);
|
|
388
|
-
t.is(registry.getFormatter('tool1'), formatter1);
|
|
389
|
-
t.is(registry.getValidator('tool1'), validator1);
|
|
390
|
-
});
|
|
391
|
-
|
|
392
|
-
test('ToolRegistry - fromRegistries with optional parameters', t => {
|
|
393
|
-
const handler: ToolEntry['handler'] = async () => 'test';
|
|
394
|
-
const tool: ToolEntry['tool'] = { execute: async () => 'test' } as any;
|
|
395
|
-
|
|
396
|
-
const registry = ToolRegistry.fromRegistries({ tool1: handler }, { tool1: tool });
|
|
397
|
-
|
|
398
|
-
t.is(registry.getToolCount(), 1);
|
|
399
|
-
t.is(registry.getFormatter('tool1'), undefined);
|
|
400
|
-
t.is(registry.getValidator('tool1'), undefined);
|
|
401
|
-
});
|
|
402
|
-
|
|
403
|
-
test('ToolRegistry - fromRegistries skips tools without matching handlers', t => {
|
|
404
|
-
const handler: ToolEntry['handler'] = async () => 'test';
|
|
405
|
-
const tool: ToolEntry['tool'] = { execute: async () => 'test' } as any;
|
|
406
|
-
|
|
407
|
-
const registry = ToolRegistry.fromRegistries(
|
|
408
|
-
{ tool1: handler }, // Only has handler for tool1
|
|
409
|
-
{ tool1: tool, tool2: tool } // But tools for tool1 and tool2
|
|
410
|
-
);
|
|
411
|
-
|
|
412
|
-
t.is(registry.getToolCount(), 1);
|
|
413
|
-
t.true(registry.hasTool('tool1'));
|
|
414
|
-
t.false(registry.hasTool('tool2'));
|
|
415
|
-
});
|