@gguf/coder 0.3.1 → 0.3.2
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 +2 -2
- package/pnpm-workspace.yaml +15 -0
- 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,425 +0,0 @@
|
|
|
1
|
-
import {existsSync, mkdirSync, readFileSync, rmSync} from 'fs';
|
|
2
|
-
import {tmpdir} from 'os';
|
|
3
|
-
import {join} from 'path';
|
|
4
|
-
import test from 'ava';
|
|
5
|
-
|
|
6
|
-
import {getDefaultLogDirectory} from './config.js';
|
|
7
|
-
// Implementation imports
|
|
8
|
-
import {
|
|
9
|
-
createLoggerWithTransport,
|
|
10
|
-
createPinoLogger,
|
|
11
|
-
getLoggerStats,
|
|
12
|
-
} from './pino-logger.js';
|
|
13
|
-
import type {LoggerConfig, LoggingCliConfig} from './types.js';
|
|
14
|
-
|
|
15
|
-
// Test utilities
|
|
16
|
-
const testLogDir = join(tmpdir(), `coder-pino-test-${Date.now()}`);
|
|
17
|
-
|
|
18
|
-
// Track all loggers created during tests for cleanup
|
|
19
|
-
const createdLoggers: any[] = [];
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Helper to create logger and track it for cleanup
|
|
23
|
-
*/
|
|
24
|
-
function createTrackedLogger(
|
|
25
|
-
config?: Partial<LoggerConfig>,
|
|
26
|
-
cliConfig?: LoggingCliConfig,
|
|
27
|
-
) {
|
|
28
|
-
const logger = createPinoLogger(config, cliConfig);
|
|
29
|
-
createdLoggers.push(logger);
|
|
30
|
-
return logger;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* Helper to create transport logger and track it for cleanup
|
|
35
|
-
*/
|
|
36
|
-
function createTrackedTransportLogger(
|
|
37
|
-
config?: Partial<LoggerConfig>,
|
|
38
|
-
transport?: any,
|
|
39
|
-
) {
|
|
40
|
-
const logger = createLoggerWithTransport(config, transport);
|
|
41
|
-
createdLoggers.push(logger);
|
|
42
|
-
return logger;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
test.before(() => {
|
|
46
|
-
mkdirSync(testLogDir, {recursive: true});
|
|
47
|
-
process.env.NODE_ENV = 'test';
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
test.after.always(async () => {
|
|
51
|
-
// Flush and end all tracked loggers first
|
|
52
|
-
await Promise.all(
|
|
53
|
-
createdLoggers.map(async logger => {
|
|
54
|
-
try {
|
|
55
|
-
// Flush any pending writes first
|
|
56
|
-
await logger.flush();
|
|
57
|
-
// Then end the logger
|
|
58
|
-
await logger.end();
|
|
59
|
-
} catch {
|
|
60
|
-
// Ignore errors during cleanup
|
|
61
|
-
}
|
|
62
|
-
}),
|
|
63
|
-
);
|
|
64
|
-
|
|
65
|
-
// Clear the array
|
|
66
|
-
createdLoggers.length = 0;
|
|
67
|
-
|
|
68
|
-
// Give Pino transport workers time to shut down gracefully
|
|
69
|
-
// Pino uses worker threads that need time to clean up
|
|
70
|
-
// Increased timeout to ensure worker threads can terminate
|
|
71
|
-
await new Promise(resolve => setTimeout(resolve, 500));
|
|
72
|
-
|
|
73
|
-
// Clean up test directory
|
|
74
|
-
if (existsSync(testLogDir)) {
|
|
75
|
-
rmSync(testLogDir, {recursive: true, force: true});
|
|
76
|
-
}
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
test('createPinoLogger creates logger with default configuration', async t => {
|
|
80
|
-
const logger = createTrackedLogger();
|
|
81
|
-
|
|
82
|
-
t.truthy(logger, 'Should create logger instance');
|
|
83
|
-
t.truthy(typeof logger.info === 'function', 'Should have info method');
|
|
84
|
-
t.truthy(typeof logger.error === 'function', 'Should have error method');
|
|
85
|
-
t.truthy(typeof logger.warn === 'function', 'Should have warn method');
|
|
86
|
-
t.truthy(typeof logger.debug === 'function', 'Should have debug method');
|
|
87
|
-
t.truthy(typeof logger.child === 'function', 'Should have child method');
|
|
88
|
-
t.truthy(
|
|
89
|
-
typeof logger.isLevelEnabled === 'function',
|
|
90
|
-
'Should have isLevelEnabled method',
|
|
91
|
-
);
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
test('createPinoLogger respects configuration options', async t => {
|
|
95
|
-
const config: Partial<LoggerConfig> = {
|
|
96
|
-
level: 'warn',
|
|
97
|
-
pretty: false,
|
|
98
|
-
correlation: false,
|
|
99
|
-
redact: ['apiKey', 'secret'],
|
|
100
|
-
};
|
|
101
|
-
|
|
102
|
-
const logger = createTrackedLogger(config);
|
|
103
|
-
|
|
104
|
-
t.true(logger.isLevelEnabled('warn'), 'Should enable warn level');
|
|
105
|
-
t.true(logger.isLevelEnabled('error'), 'Should enable error level');
|
|
106
|
-
t.false(logger.isLevelEnabled('info'), 'Should disable info level');
|
|
107
|
-
t.false(logger.isLevelEnabled('debug'), 'Should disable debug level');
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
test('createPinoLogger includes Node.js version in base configuration', async t => {
|
|
111
|
-
// This tests the feature from the previous session
|
|
112
|
-
const logger = createTrackedLogger({level: 'silent'});
|
|
113
|
-
|
|
114
|
-
// Verify logger was created successfully
|
|
115
|
-
t.truthy(logger, 'Should create logger with Node.js version');
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
test('createPinoLogger handles CLI configuration', async t => {
|
|
119
|
-
const cliConfig: LoggingCliConfig = {
|
|
120
|
-
logToFile: true,
|
|
121
|
-
logToConsole: false,
|
|
122
|
-
};
|
|
123
|
-
|
|
124
|
-
const logger = createTrackedLogger(undefined, cliConfig);
|
|
125
|
-
|
|
126
|
-
t.truthy(logger, 'Should create logger with CLI config');
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
test('createPinoLogger creates file transport in test environment', async t => {
|
|
130
|
-
const originalEnv = process.env.NODE_ENV;
|
|
131
|
-
process.env.NODE_ENV = 'test';
|
|
132
|
-
|
|
133
|
-
const logger = createTrackedLogger({level: 'info'});
|
|
134
|
-
|
|
135
|
-
t.truthy(logger, 'Should create logger in test environment');
|
|
136
|
-
|
|
137
|
-
// Log a test message
|
|
138
|
-
logger.info('Test message for file transport');
|
|
139
|
-
|
|
140
|
-
// Verify log directory is created
|
|
141
|
-
const logDir = getDefaultLogDirectory();
|
|
142
|
-
t.true(existsSync(logDir), 'Should create log directory');
|
|
143
|
-
|
|
144
|
-
process.env.NODE_ENV = originalEnv;
|
|
145
|
-
});
|
|
146
|
-
|
|
147
|
-
test('createLoggerWithTransport creates logger with custom transport', async t => {
|
|
148
|
-
const customTransport = {
|
|
149
|
-
target: 'pino/file',
|
|
150
|
-
options: {
|
|
151
|
-
destination: join(testLogDir, 'custom-test.log'),
|
|
152
|
-
},
|
|
153
|
-
};
|
|
154
|
-
|
|
155
|
-
const logger = createTrackedTransportLogger(
|
|
156
|
-
{
|
|
157
|
-
level: 'debug',
|
|
158
|
-
pretty: false,
|
|
159
|
-
},
|
|
160
|
-
customTransport,
|
|
161
|
-
);
|
|
162
|
-
|
|
163
|
-
t.truthy(logger, 'Should create logger with custom transport');
|
|
164
|
-
t.true(logger.isLevelEnabled('debug'), 'Should enable debug level');
|
|
165
|
-
|
|
166
|
-
logger.info('Test message with custom transport');
|
|
167
|
-
|
|
168
|
-
// Note: File creation might be asynchronous, so we'll just verify the transport was configured correctly
|
|
169
|
-
t.is(
|
|
170
|
-
customTransport.options.destination,
|
|
171
|
-
join(testLogDir, 'custom-test.log'),
|
|
172
|
-
);
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
test('createLoggerWithTransport includes Node.js version', async t => {
|
|
176
|
-
const logger = createTrackedTransportLogger({level: 'silent'});
|
|
177
|
-
|
|
178
|
-
t.truthy(
|
|
179
|
-
logger,
|
|
180
|
-
'Should create logger with Node.js version in custom transport',
|
|
181
|
-
);
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
test('logger handles different message formats', async t => {
|
|
185
|
-
const logger = createTrackedLogger({level: 'debug'});
|
|
186
|
-
|
|
187
|
-
// Test string message
|
|
188
|
-
t.notThrows(() => {
|
|
189
|
-
logger.info('Simple string message');
|
|
190
|
-
}, 'Should handle string messages');
|
|
191
|
-
|
|
192
|
-
// Test object message
|
|
193
|
-
t.notThrows(() => {
|
|
194
|
-
logger.info({key: 'value'}, 'Message with object');
|
|
195
|
-
}, 'Should handle object messages');
|
|
196
|
-
|
|
197
|
-
// Test message with additional arguments
|
|
198
|
-
t.notThrows(() => {
|
|
199
|
-
logger.info('Message with args', {arg1: 'value1'}, {arg2: 'value2'});
|
|
200
|
-
}, 'Should handle multiple arguments');
|
|
201
|
-
|
|
202
|
-
});
|
|
203
|
-
|
|
204
|
-
test('logger handles correlation context', async t => {
|
|
205
|
-
const logger = createTrackedLogger({
|
|
206
|
-
level: 'debug',
|
|
207
|
-
correlation: true,
|
|
208
|
-
});
|
|
209
|
-
|
|
210
|
-
// Test with correlation enabled (if correlation module is available)
|
|
211
|
-
t.notThrows(() => {
|
|
212
|
-
logger.info('Message with potential correlation');
|
|
213
|
-
}, 'Should handle correlation context gracefully');
|
|
214
|
-
|
|
215
|
-
});
|
|
216
|
-
|
|
217
|
-
test('logger handles redaction', async t => {
|
|
218
|
-
const logger = createTrackedLogger({
|
|
219
|
-
level: 'debug',
|
|
220
|
-
redact: ['apiKey', 'password', 'secret'],
|
|
221
|
-
});
|
|
222
|
-
|
|
223
|
-
const sensitiveData = {
|
|
224
|
-
username: 'testuser',
|
|
225
|
-
apiKey: 'secret-key-123',
|
|
226
|
-
password: 'secret-pass',
|
|
227
|
-
safeField: 'safe-value',
|
|
228
|
-
};
|
|
229
|
-
|
|
230
|
-
t.notThrows(() => {
|
|
231
|
-
logger.info('Message with sensitive data', sensitiveData);
|
|
232
|
-
}, 'Should handle redaction without errors');
|
|
233
|
-
|
|
234
|
-
});
|
|
235
|
-
|
|
236
|
-
test('child logger inherits parent configuration', async t => {
|
|
237
|
-
const parentLogger = createTrackedLogger({
|
|
238
|
-
level: 'debug',
|
|
239
|
-
redact: ['secret'],
|
|
240
|
-
});
|
|
241
|
-
|
|
242
|
-
const childLogger = parentLogger.child({
|
|
243
|
-
module: 'test-module',
|
|
244
|
-
version: '1.0.0',
|
|
245
|
-
});
|
|
246
|
-
|
|
247
|
-
t.truthy(childLogger, 'Should create child logger');
|
|
248
|
-
t.true(childLogger.isLevelEnabled('debug'), 'Child should inherit log level');
|
|
249
|
-
t.not(parentLogger === childLogger, 'Child should be different instance');
|
|
250
|
-
|
|
251
|
-
// Test child logger functionality
|
|
252
|
-
t.notThrows(() => {
|
|
253
|
-
childLogger.info('Child logger message');
|
|
254
|
-
}, 'Child logger should work');
|
|
255
|
-
|
|
256
|
-
});
|
|
257
|
-
|
|
258
|
-
test('nested child loggers work correctly', async t => {
|
|
259
|
-
const parentLogger = createTrackedLogger({level: 'info'});
|
|
260
|
-
const childLogger = parentLogger.child({module: 'parent'});
|
|
261
|
-
const grandchildLogger = childLogger.child({submodule: 'child'});
|
|
262
|
-
|
|
263
|
-
t.truthy(grandchildLogger, 'Should create grandchild logger');
|
|
264
|
-
|
|
265
|
-
t.notThrows(() => {
|
|
266
|
-
grandchildLogger.info('Grandchild message');
|
|
267
|
-
}, 'Grandchild logger should work');
|
|
268
|
-
|
|
269
|
-
});
|
|
270
|
-
|
|
271
|
-
test('logger handles edge cases gracefully', async t => {
|
|
272
|
-
const logger = createTrackedLogger({level: 'debug'});
|
|
273
|
-
|
|
274
|
-
// Test circular references - with a simpler approach to avoid redaction recursion
|
|
275
|
-
const circular: any = {id: 1};
|
|
276
|
-
circular.self = circular;
|
|
277
|
-
|
|
278
|
-
// The logger should handle circular references, but we'll test without triggering the redaction system
|
|
279
|
-
t.notThrows(() => {
|
|
280
|
-
logger.info('Circular reference test', {id: circular.id});
|
|
281
|
-
}, 'Should handle object with circular reference properties');
|
|
282
|
-
|
|
283
|
-
// Test undefined/null values
|
|
284
|
-
t.notThrows(() => {
|
|
285
|
-
logger.info('Edge cases', {
|
|
286
|
-
nullValue: null,
|
|
287
|
-
undefinedValue: undefined,
|
|
288
|
-
emptyString: '',
|
|
289
|
-
zero: 0,
|
|
290
|
-
false: false,
|
|
291
|
-
});
|
|
292
|
-
}, 'Should handle undefined/null values');
|
|
293
|
-
|
|
294
|
-
// Test very large strings
|
|
295
|
-
t.notThrows(() => {
|
|
296
|
-
logger.info('Large string test', {largeData: 'x'.repeat(10000)});
|
|
297
|
-
}, 'Should handle large data');
|
|
298
|
-
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
test('logger handles high volume efficiently', async t => {
|
|
302
|
-
const logger = createTrackedLogger({level: 'info'});
|
|
303
|
-
const messageCount = 1000;
|
|
304
|
-
|
|
305
|
-
const startTime = performance.now();
|
|
306
|
-
|
|
307
|
-
for (let i = 0; i < messageCount; i++) {
|
|
308
|
-
logger.info(`High volume message ${i}`, {index: i});
|
|
309
|
-
}
|
|
310
|
-
|
|
311
|
-
const endTime = performance.now();
|
|
312
|
-
const duration = endTime - startTime;
|
|
313
|
-
const avgTime = duration / messageCount;
|
|
314
|
-
|
|
315
|
-
// Should handle high volume efficiently (less than 1ms per log)
|
|
316
|
-
t.true(
|
|
317
|
-
avgTime < 1,
|
|
318
|
-
`Should handle high volume efficiently (${avgTime.toFixed(
|
|
319
|
-
4,
|
|
320
|
-
)}ms per message)`,
|
|
321
|
-
);
|
|
322
|
-
|
|
323
|
-
});
|
|
324
|
-
|
|
325
|
-
test('getLoggerStats returns correct information', t => {
|
|
326
|
-
const stats = getLoggerStats();
|
|
327
|
-
|
|
328
|
-
t.truthy(stats, 'Should return stats object');
|
|
329
|
-
t.truthy(typeof stats.level === 'string', 'Should have level');
|
|
330
|
-
t.truthy(typeof stats.silent === 'boolean', 'Should have silent flag');
|
|
331
|
-
t.truthy(typeof stats.environment === 'string', 'Should have environment');
|
|
332
|
-
});
|
|
333
|
-
|
|
334
|
-
test('logger cleanup methods work', async t => {
|
|
335
|
-
const logger = createTrackedLogger({level: 'info'});
|
|
336
|
-
|
|
337
|
-
logger.info('Message before cleanup');
|
|
338
|
-
|
|
339
|
-
// Test flush method - may not be available with all transport configurations
|
|
340
|
-
try {
|
|
341
|
-
await logger.flush();
|
|
342
|
-
t.pass('Flush completed successfully');
|
|
343
|
-
} catch (error) {
|
|
344
|
-
// Flush may not be available with certain transport configurations
|
|
345
|
-
t.pass('Flush handled gracefully when not available');
|
|
346
|
-
}
|
|
347
|
-
|
|
348
|
-
// Test end method - tracked loggers are cleaned up automatically
|
|
349
|
-
t.pass('Logger will be cleaned up in test.after.always');
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
test('different log levels work correctly', async t => {
|
|
353
|
-
const logger = createTrackedLogger({level: 'trace'}); // Use trace to enable all levels
|
|
354
|
-
|
|
355
|
-
const testMessage = 'Test log message';
|
|
356
|
-
|
|
357
|
-
t.notThrows(() => logger.fatal(testMessage), 'fatal level should work');
|
|
358
|
-
t.notThrows(() => logger.error(testMessage), 'error level should work');
|
|
359
|
-
t.notThrows(() => logger.warn(testMessage), 'warn level should work');
|
|
360
|
-
t.notThrows(() => logger.info(testMessage), 'info level should work');
|
|
361
|
-
|
|
362
|
-
// Test http level - it exists as a method but might not be available at all log levels
|
|
363
|
-
t.truthy(typeof logger.http === 'function', 'http method should exist');
|
|
364
|
-
|
|
365
|
-
// Only test http if it's actually enabled at this log level
|
|
366
|
-
if (logger.isLevelEnabled('http')) {
|
|
367
|
-
t.notThrows(
|
|
368
|
-
() => logger.http(testMessage),
|
|
369
|
-
'http level should work when enabled',
|
|
370
|
-
);
|
|
371
|
-
}
|
|
372
|
-
|
|
373
|
-
t.notThrows(() => logger.debug(testMessage), 'debug level should work');
|
|
374
|
-
t.notThrows(() => logger.trace(testMessage), 'trace level should work');
|
|
375
|
-
|
|
376
|
-
});
|
|
377
|
-
|
|
378
|
-
test('silent logger creates no output', async t => {
|
|
379
|
-
const silentLogger = createTrackedLogger({level: 'silent'});
|
|
380
|
-
|
|
381
|
-
t.false(
|
|
382
|
-
silentLogger.isLevelEnabled('info'),
|
|
383
|
-
'Silent logger should not enable info level',
|
|
384
|
-
);
|
|
385
|
-
t.false(
|
|
386
|
-
silentLogger.isLevelEnabled('error'),
|
|
387
|
-
'Silent logger should not enable error level',
|
|
388
|
-
);
|
|
389
|
-
t.false(
|
|
390
|
-
silentLogger.isLevelEnabled('debug'),
|
|
391
|
-
'Silent logger should not enable debug level',
|
|
392
|
-
);
|
|
393
|
-
|
|
394
|
-
// Should not throw when logging at any level
|
|
395
|
-
t.notThrows(() => {
|
|
396
|
-
silentLogger.info('This should not be logged');
|
|
397
|
-
silentLogger.error('This should not be logged');
|
|
398
|
-
silentLogger.debug('This should not be logged');
|
|
399
|
-
}, 'Silent logger should handle all levels without error');
|
|
400
|
-
|
|
401
|
-
});
|
|
402
|
-
|
|
403
|
-
test('logger redaction works for configured fields', async t => {
|
|
404
|
-
const logger = createTrackedLogger({
|
|
405
|
-
level: 'debug',
|
|
406
|
-
redact: ['apiKey', 'password', 'userCredentials.secret'],
|
|
407
|
-
});
|
|
408
|
-
|
|
409
|
-
const sensitiveData = {
|
|
410
|
-
username: 'testuser',
|
|
411
|
-
apiKey: 'secret-api-key',
|
|
412
|
-
password: 'secret-password',
|
|
413
|
-
userCredentials: {
|
|
414
|
-
id: 'user123',
|
|
415
|
-
secret: 'super-secret-value',
|
|
416
|
-
},
|
|
417
|
-
safeField: 'this-is-safe',
|
|
418
|
-
};
|
|
419
|
-
|
|
420
|
-
// Should not throw and should redact sensitive fields
|
|
421
|
-
t.notThrows(() => {
|
|
422
|
-
logger.info('Testing redaction', sensitiveData);
|
|
423
|
-
}, 'Redaction should work without errors');
|
|
424
|
-
|
|
425
|
-
});
|