@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,796 +0,0 @@
|
|
|
1
|
-
import test from 'ava';
|
|
2
|
-
import {render} from 'ink-testing-library';
|
|
3
|
-
import React from 'react';
|
|
4
|
-
import {themes} from '../config/themes';
|
|
5
|
-
import {ThemeContext} from '../hooks/useTheme';
|
|
6
|
-
import {
|
|
7
|
-
type Colors,
|
|
8
|
-
decodeHtmlEntities,
|
|
9
|
-
parseMarkdown,
|
|
10
|
-
parseMarkdownTable,
|
|
11
|
-
} from '../markdown-parser/index';
|
|
12
|
-
import AssistantMessage from './assistant-message';
|
|
13
|
-
|
|
14
|
-
// Mock theme colors for testing
|
|
15
|
-
const mockColors: any = {
|
|
16
|
-
primary: '#3b82f6',
|
|
17
|
-
secondary: '#6b7280',
|
|
18
|
-
success: '#10b981',
|
|
19
|
-
error: '#ef4444',
|
|
20
|
-
warning: '#f59e0b',
|
|
21
|
-
info: '#3b82f6',
|
|
22
|
-
white: '#ffffff',
|
|
23
|
-
black: '#000000',
|
|
24
|
-
tool: '#8b5cf6',
|
|
25
|
-
diffAdded: '#10b981',
|
|
26
|
-
diffRemoved: '#ef4444',
|
|
27
|
-
diffAddedText: '#d1fae5',
|
|
28
|
-
diffRemovedText: '#fee2e2',
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
console.log(`\nassistant-message.spec.tsx – ${React.version}`);
|
|
32
|
-
|
|
33
|
-
// Mock ThemeProvider for testing
|
|
34
|
-
const MockThemeProvider = ({children}: {children: React.ReactNode}) => {
|
|
35
|
-
const mockTheme = {
|
|
36
|
-
currentTheme: 'tokyo-night' as const,
|
|
37
|
-
colors: themes['tokyo-night'].colors,
|
|
38
|
-
setCurrentTheme: () => {},
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
return (
|
|
42
|
-
<ThemeContext.Provider value={mockTheme}>{children}</ThemeContext.Provider>
|
|
43
|
-
);
|
|
44
|
-
};
|
|
45
|
-
|
|
46
|
-
// ============================================================================
|
|
47
|
-
// Component Rendering Tests
|
|
48
|
-
// ============================================================================
|
|
49
|
-
|
|
50
|
-
test('AssistantMessage renders with basic message', t => {
|
|
51
|
-
const {lastFrame} = render(
|
|
52
|
-
<MockThemeProvider>
|
|
53
|
-
<AssistantMessage message="Hello world" model="test-model" />
|
|
54
|
-
</MockThemeProvider>,
|
|
55
|
-
);
|
|
56
|
-
|
|
57
|
-
const output = lastFrame();
|
|
58
|
-
t.truthy(output);
|
|
59
|
-
t.regex(output!, /test-model:/);
|
|
60
|
-
t.regex(output!, /Hello world/);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
test('AssistantMessage renders with bold text', t => {
|
|
64
|
-
const {lastFrame} = render(
|
|
65
|
-
<MockThemeProvider>
|
|
66
|
-
<AssistantMessage message="This is **bold** text" model="test-model" />
|
|
67
|
-
</MockThemeProvider>,
|
|
68
|
-
);
|
|
69
|
-
|
|
70
|
-
const output = lastFrame();
|
|
71
|
-
t.truthy(output);
|
|
72
|
-
t.regex(output!, /bold/);
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
test('AssistantMessage renders with inline code', t => {
|
|
76
|
-
const {lastFrame} = render(
|
|
77
|
-
<MockThemeProvider>
|
|
78
|
-
<AssistantMessage
|
|
79
|
-
message="Use `const` for constants"
|
|
80
|
-
model="test-model"
|
|
81
|
-
/>
|
|
82
|
-
</MockThemeProvider>,
|
|
83
|
-
);
|
|
84
|
-
|
|
85
|
-
const output = lastFrame();
|
|
86
|
-
t.truthy(output);
|
|
87
|
-
t.regex(output!, /const/);
|
|
88
|
-
t.regex(output!, /for constants/);
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
test('AssistantMessage renders with HTML entities', t => {
|
|
92
|
-
const {lastFrame} = render(
|
|
93
|
-
<MockThemeProvider>
|
|
94
|
-
<AssistantMessage
|
|
95
|
-
message="Price: €100 only"
|
|
96
|
-
model="test-model"
|
|
97
|
-
/>
|
|
98
|
-
</MockThemeProvider>,
|
|
99
|
-
);
|
|
100
|
-
|
|
101
|
-
const output = lastFrame();
|
|
102
|
-
t.truthy(output);
|
|
103
|
-
// Should have decoded entities
|
|
104
|
-
t.regex(output!, /Price:/);
|
|
105
|
-
t.regex(output!, /100/);
|
|
106
|
-
t.regex(output!, /only/);
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
test('AssistantMessage renders with markdown table', t => {
|
|
110
|
-
const message = `| Name | Age |
|
|
111
|
-
|------|-----|
|
|
112
|
-
| John | 30 |
|
|
113
|
-
| Jane | 25 |`;
|
|
114
|
-
|
|
115
|
-
const {lastFrame} = render(
|
|
116
|
-
<MockThemeProvider>
|
|
117
|
-
<AssistantMessage message={message} model="test-model" />
|
|
118
|
-
</MockThemeProvider>,
|
|
119
|
-
);
|
|
120
|
-
|
|
121
|
-
const output = lastFrame();
|
|
122
|
-
t.truthy(output);
|
|
123
|
-
t.regex(output!, /Name/);
|
|
124
|
-
t.regex(output!, /Age/);
|
|
125
|
-
t.regex(output!, /John/);
|
|
126
|
-
t.regex(output!, /Jane/);
|
|
127
|
-
// Should contain table separators
|
|
128
|
-
t.regex(output!, /│/);
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
test('AssistantMessage renders with headings', t => {
|
|
132
|
-
const {lastFrame} = render(
|
|
133
|
-
<MockThemeProvider>
|
|
134
|
-
<AssistantMessage message="# Main Heading" model="test-model" />
|
|
135
|
-
</MockThemeProvider>,
|
|
136
|
-
);
|
|
137
|
-
|
|
138
|
-
const output = lastFrame();
|
|
139
|
-
t.truthy(output);
|
|
140
|
-
t.regex(output!, /Main Heading/);
|
|
141
|
-
});
|
|
142
|
-
|
|
143
|
-
test('AssistantMessage renders with lists', t => {
|
|
144
|
-
const message = `- Item 1
|
|
145
|
-
- Item 2
|
|
146
|
-
- Item 3`;
|
|
147
|
-
|
|
148
|
-
const {lastFrame} = render(
|
|
149
|
-
<MockThemeProvider>
|
|
150
|
-
<AssistantMessage message={message} model="test-model" />
|
|
151
|
-
</MockThemeProvider>,
|
|
152
|
-
);
|
|
153
|
-
|
|
154
|
-
const output = lastFrame();
|
|
155
|
-
t.truthy(output);
|
|
156
|
-
t.regex(output!, /Item 1/);
|
|
157
|
-
t.regex(output!, /Item 2/);
|
|
158
|
-
t.regex(output!, /Item 3/);
|
|
159
|
-
// Should contain bullets
|
|
160
|
-
t.regex(output!, /•/);
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
test('AssistantMessage renders with blockquotes', t => {
|
|
164
|
-
const {lastFrame} = render(
|
|
165
|
-
<MockThemeProvider>
|
|
166
|
-
<AssistantMessage message="> This is a quote" model="test-model" />
|
|
167
|
-
</MockThemeProvider>,
|
|
168
|
-
);
|
|
169
|
-
|
|
170
|
-
const output = lastFrame();
|
|
171
|
-
t.truthy(output);
|
|
172
|
-
t.regex(output!, /This is a quote/);
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
test('AssistantMessage renders with links', t => {
|
|
176
|
-
const {lastFrame} = render(
|
|
177
|
-
<MockThemeProvider>
|
|
178
|
-
<AssistantMessage
|
|
179
|
-
message="Check [this link](https://example.com)"
|
|
180
|
-
model="test-model"
|
|
181
|
-
/>
|
|
182
|
-
</MockThemeProvider>,
|
|
183
|
-
);
|
|
184
|
-
|
|
185
|
-
const output = lastFrame();
|
|
186
|
-
t.truthy(output);
|
|
187
|
-
t.regex(output!, /this link/);
|
|
188
|
-
t.regex(output!, /https:\/\/example\.com/);
|
|
189
|
-
});
|
|
190
|
-
|
|
191
|
-
test('AssistantMessage renders with mixed markdown', t => {
|
|
192
|
-
const message = `# Title
|
|
193
|
-
|
|
194
|
-
This has **bold** and *italic* text.
|
|
195
|
-
|
|
196
|
-
- List item
|
|
197
|
-
|
|
198
|
-
Price: €50`;
|
|
199
|
-
|
|
200
|
-
const {lastFrame} = render(
|
|
201
|
-
<MockThemeProvider>
|
|
202
|
-
<AssistantMessage message={message} model="test-model" />
|
|
203
|
-
</MockThemeProvider>,
|
|
204
|
-
);
|
|
205
|
-
|
|
206
|
-
const output = lastFrame();
|
|
207
|
-
t.truthy(output);
|
|
208
|
-
t.regex(output!, /Title/);
|
|
209
|
-
t.regex(output!, /bold/);
|
|
210
|
-
t.regex(output!, /italic/);
|
|
211
|
-
t.regex(output!, /List item/);
|
|
212
|
-
t.regex(output!, /50/);
|
|
213
|
-
});
|
|
214
|
-
|
|
215
|
-
test('AssistantMessage renders without crashing with empty message', t => {
|
|
216
|
-
const {lastFrame} = render(
|
|
217
|
-
<MockThemeProvider>
|
|
218
|
-
<AssistantMessage message="" model="test-model" />
|
|
219
|
-
</MockThemeProvider>,
|
|
220
|
-
);
|
|
221
|
-
|
|
222
|
-
const output = lastFrame();
|
|
223
|
-
t.truthy(output);
|
|
224
|
-
t.regex(output!, /test-model:/);
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
test('AssistantMessage renders model name correctly', t => {
|
|
228
|
-
const {lastFrame} = render(
|
|
229
|
-
<MockThemeProvider>
|
|
230
|
-
<AssistantMessage message="Test" model="gpt-4" />
|
|
231
|
-
</MockThemeProvider>,
|
|
232
|
-
);
|
|
233
|
-
|
|
234
|
-
const output = lastFrame();
|
|
235
|
-
t.truthy(output);
|
|
236
|
-
t.regex(output!, /gpt-4:/);
|
|
237
|
-
});
|
|
238
|
-
|
|
239
|
-
// ============================================================================
|
|
240
|
-
// HTML Entity Decoding Tests
|
|
241
|
-
// ============================================================================
|
|
242
|
-
|
|
243
|
-
test('decodeHtmlEntities handles common entities', t => {
|
|
244
|
-
const input = 'Hello world&test';
|
|
245
|
-
const result = decodeHtmlEntities(input);
|
|
246
|
-
t.is(result, 'Hello world&test');
|
|
247
|
-
});
|
|
248
|
-
|
|
249
|
-
test('decodeHtmlEntities handles less-than and greater-than', t => {
|
|
250
|
-
const input = '<div>content</div>';
|
|
251
|
-
const result = decodeHtmlEntities(input);
|
|
252
|
-
t.is(result, '<div>content</div>');
|
|
253
|
-
});
|
|
254
|
-
|
|
255
|
-
test('decodeHtmlEntities handles quotes', t => {
|
|
256
|
-
const input = '"Hello" 'World'';
|
|
257
|
-
const result = decodeHtmlEntities(input);
|
|
258
|
-
t.is(result, '"Hello" \'World\'');
|
|
259
|
-
});
|
|
260
|
-
|
|
261
|
-
test('decodeHtmlEntities handles copyright and trademark symbols', t => {
|
|
262
|
-
const input = '© 2024 ® ™';
|
|
263
|
-
const result = decodeHtmlEntities(input);
|
|
264
|
-
t.is(result, '© 2024 ® ™');
|
|
265
|
-
});
|
|
266
|
-
|
|
267
|
-
test('decodeHtmlEntities handles currency symbols', t => {
|
|
268
|
-
const input = '€100 £50 ¥1000 ¢25';
|
|
269
|
-
const result = decodeHtmlEntities(input);
|
|
270
|
-
t.is(result, '€100 £50 ¥1000 ¢25');
|
|
271
|
-
});
|
|
272
|
-
|
|
273
|
-
test('decodeHtmlEntities handles mathematical symbols', t => {
|
|
274
|
-
const input = '45° ±5 2×3 10÷2';
|
|
275
|
-
const result = decodeHtmlEntities(input);
|
|
276
|
-
t.is(result, '45° ±5 2×3 10÷2');
|
|
277
|
-
});
|
|
278
|
-
|
|
279
|
-
test('decodeHtmlEntities handles typography symbols', t => {
|
|
280
|
-
const input =
|
|
281
|
-
'– — ‘text’ “quote” … •';
|
|
282
|
-
const result = decodeHtmlEntities(input);
|
|
283
|
-
t.is(result, '– — \u2018text\u2019 \u201Cquote\u201D … •');
|
|
284
|
-
});
|
|
285
|
-
|
|
286
|
-
test('decodeHtmlEntities handles numeric entities (decimal)', t => {
|
|
287
|
-
const input = 'Space here and there';
|
|
288
|
-
const result = decodeHtmlEntities(input);
|
|
289
|
-
//   is non-breaking space,   is regular space
|
|
290
|
-
t.is(result, 'Space\u00A0here and there');
|
|
291
|
-
});
|
|
292
|
-
|
|
293
|
-
test('decodeHtmlEntities handles numeric entities (hexadecimal)', t => {
|
|
294
|
-
const input = 'Unicode space and space';
|
|
295
|
-
const result = decodeHtmlEntities(input);
|
|
296
|
-
//   is non-breaking space,   is regular space
|
|
297
|
-
t.is(result, 'Unicode\u00A0space and space');
|
|
298
|
-
});
|
|
299
|
-
|
|
300
|
-
test('decodeHtmlEntities handles mixed entities', t => {
|
|
301
|
-
const input =
|
|
302
|
-
'<p>Price: €100 ± €5</p>';
|
|
303
|
-
const result = decodeHtmlEntities(input);
|
|
304
|
-
t.is(result, '<p>Price: €100 ± €5</p>');
|
|
305
|
-
});
|
|
306
|
-
|
|
307
|
-
test('decodeHtmlEntities leaves normal text unchanged', t => {
|
|
308
|
-
const input = 'Normal text without entities';
|
|
309
|
-
const result = decodeHtmlEntities(input);
|
|
310
|
-
t.is(result, input);
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
test('decodeHtmlEntities handles multiple occurrences of same entity', t => {
|
|
314
|
-
const input = ' ';
|
|
315
|
-
const result = decodeHtmlEntities(input);
|
|
316
|
-
t.is(result, ' ');
|
|
317
|
-
});
|
|
318
|
-
|
|
319
|
-
// ============================================================================
|
|
320
|
-
// Markdown Table Parsing Tests
|
|
321
|
-
// ============================================================================
|
|
322
|
-
|
|
323
|
-
test('parseMarkdownTable handles simple two-column table', t => {
|
|
324
|
-
const table = `| Header 1 | Header 2 |
|
|
325
|
-
|----------|----------|
|
|
326
|
-
| Cell 1 | Cell 2 |
|
|
327
|
-
| Cell 3 | Cell 4 |
|
|
328
|
-
`;
|
|
329
|
-
const result = parseMarkdownTable(table, mockColors);
|
|
330
|
-
t.true(result.includes('Header 1'));
|
|
331
|
-
t.true(result.includes('Header 2'));
|
|
332
|
-
t.true(result.includes('Cell 1'));
|
|
333
|
-
t.true(result.includes('Cell 4'));
|
|
334
|
-
t.true(result.includes('│')); // Contains column separator
|
|
335
|
-
t.true(result.includes('─')); // Contains row separator
|
|
336
|
-
});
|
|
337
|
-
|
|
338
|
-
test('parseMarkdownTable handles table with varying cell lengths', t => {
|
|
339
|
-
const table = `| Short | Very Long Header Text |
|
|
340
|
-
|-------|----------------------|
|
|
341
|
-
| A | B |
|
|
342
|
-
| Long text here | X |
|
|
343
|
-
`;
|
|
344
|
-
const result = parseMarkdownTable(table, mockColors);
|
|
345
|
-
t.true(result.includes('Short'));
|
|
346
|
-
t.true(result.includes('Very Long Header Text'));
|
|
347
|
-
t.true(result.includes('Long text here'));
|
|
348
|
-
});
|
|
349
|
-
|
|
350
|
-
test('parseMarkdownTable returns original text for invalid table', t => {
|
|
351
|
-
const notATable = 'Just some text without table structure';
|
|
352
|
-
const result = parseMarkdownTable(notATable, mockColors);
|
|
353
|
-
t.is(result, notATable);
|
|
354
|
-
});
|
|
355
|
-
|
|
356
|
-
test('parseMarkdownTable returns original text for table without data rows', t => {
|
|
357
|
-
const table = `| Header 1 | Header 2 |
|
|
358
|
-
|----------|----------|
|
|
359
|
-
`;
|
|
360
|
-
const result = parseMarkdownTable(table, mockColors);
|
|
361
|
-
t.is(result, table);
|
|
362
|
-
});
|
|
363
|
-
|
|
364
|
-
test('parseMarkdownTable handles table with empty cells', t => {
|
|
365
|
-
const table = `| Col1 | Col2 |
|
|
366
|
-
|------|------|
|
|
367
|
-
| Text | |
|
|
368
|
-
| | Text |
|
|
369
|
-
`;
|
|
370
|
-
const result = parseMarkdownTable(table, mockColors);
|
|
371
|
-
t.true(result.includes('Col1'));
|
|
372
|
-
t.true(result.includes('Col2'));
|
|
373
|
-
t.true(result.includes('Text'));
|
|
374
|
-
});
|
|
375
|
-
|
|
376
|
-
test('parseMarkdownTable normalizes column count', t => {
|
|
377
|
-
const table = `| A | B |
|
|
378
|
-
|---|---|
|
|
379
|
-
| 1 | 2 |
|
|
380
|
-
| 3 |
|
|
381
|
-
`;
|
|
382
|
-
const result = parseMarkdownTable(table, mockColors);
|
|
383
|
-
// Should handle the missing cell gracefully
|
|
384
|
-
t.true(result.includes('A'));
|
|
385
|
-
t.true(result.includes('B'));
|
|
386
|
-
t.true(result.includes('1'));
|
|
387
|
-
t.true(result.includes('3'));
|
|
388
|
-
});
|
|
389
|
-
|
|
390
|
-
test('parseMarkdownTable handles markdown formatting in cells', t => {
|
|
391
|
-
const table = `| Command | Description |
|
|
392
|
-
|---------|-------------|
|
|
393
|
-
| \`npm run build\` | Compile TypeScript |
|
|
394
|
-
| **Important** | Do this first |
|
|
395
|
-
| [Link](url) | External reference |
|
|
396
|
-
`;
|
|
397
|
-
const result = parseMarkdownTable(table, mockColors);
|
|
398
|
-
// Should strip markdown for proper alignment
|
|
399
|
-
t.true(result.includes('Command'));
|
|
400
|
-
t.true(result.includes('Description'));
|
|
401
|
-
t.true(result.includes('npm run build'));
|
|
402
|
-
t.true(result.includes('Important'));
|
|
403
|
-
t.true(result.includes('Link'));
|
|
404
|
-
// Should have proper table structure
|
|
405
|
-
t.true(result.includes('│'));
|
|
406
|
-
t.true(result.includes('─'));
|
|
407
|
-
});
|
|
408
|
-
|
|
409
|
-
// ============================================================================
|
|
410
|
-
// Markdown Parsing Tests
|
|
411
|
-
// ============================================================================
|
|
412
|
-
|
|
413
|
-
test('parseMarkdown handles inline code', t => {
|
|
414
|
-
const text = 'Use `const` for constants';
|
|
415
|
-
const result = parseMarkdown(text, mockColors);
|
|
416
|
-
t.true(result.includes('const'));
|
|
417
|
-
// Should still contain the word even if styled
|
|
418
|
-
t.true(result.includes('for constants'));
|
|
419
|
-
});
|
|
420
|
-
|
|
421
|
-
test('parseMarkdown handles bold text', t => {
|
|
422
|
-
const text = 'This is **bold** text';
|
|
423
|
-
const result = parseMarkdown(text, mockColors);
|
|
424
|
-
t.true(result.includes('bold'));
|
|
425
|
-
t.true(result.includes('This is'));
|
|
426
|
-
});
|
|
427
|
-
|
|
428
|
-
test('parseMarkdown handles italic text', t => {
|
|
429
|
-
const text = 'This is *italic* text';
|
|
430
|
-
const result = parseMarkdown(text, mockColors);
|
|
431
|
-
t.true(result.includes('italic'));
|
|
432
|
-
t.true(result.includes('text'));
|
|
433
|
-
});
|
|
434
|
-
|
|
435
|
-
test('parseMarkdown preserves underscores in identifiers', t => {
|
|
436
|
-
const text =
|
|
437
|
-
'Use `create_file`, `read_file`, or `search_file_contents` functions';
|
|
438
|
-
const result = parseMarkdown(text, mockColors);
|
|
439
|
-
// Underscores should be preserved in code identifiers
|
|
440
|
-
t.true(result.includes('create_file'));
|
|
441
|
-
t.true(result.includes('read_file'));
|
|
442
|
-
t.true(result.includes('search_file_contents'));
|
|
443
|
-
});
|
|
444
|
-
|
|
445
|
-
test('parseMarkdown preserves underscores in regular text', t => {
|
|
446
|
-
const text = 'The variable_name and function_call should remain intact';
|
|
447
|
-
const result = parseMarkdown(text, mockColors);
|
|
448
|
-
// Underscores should NOT be treated as markdown formatting
|
|
449
|
-
t.true(result.includes('variable_name'));
|
|
450
|
-
t.true(result.includes('function_call'));
|
|
451
|
-
});
|
|
452
|
-
|
|
453
|
-
test('parseMarkdown handles headings', t => {
|
|
454
|
-
const text = '# Main Heading\n## Subheading';
|
|
455
|
-
const result = parseMarkdown(text, mockColors);
|
|
456
|
-
t.true(result.includes('Main Heading'));
|
|
457
|
-
t.true(result.includes('Subheading'));
|
|
458
|
-
});
|
|
459
|
-
|
|
460
|
-
test('parseMarkdown handles links', t => {
|
|
461
|
-
const text = 'Check [this link](https://example.com)';
|
|
462
|
-
const result = parseMarkdown(text, mockColors);
|
|
463
|
-
t.true(result.includes('this link'));
|
|
464
|
-
t.true(result.includes('https://example.com'));
|
|
465
|
-
});
|
|
466
|
-
|
|
467
|
-
test('parseMarkdown handles blockquotes', t => {
|
|
468
|
-
const text = '> This is a quote\n> Another line';
|
|
469
|
-
const result = parseMarkdown(text, mockColors);
|
|
470
|
-
t.true(result.includes('This is a quote'));
|
|
471
|
-
t.true(result.includes('Another line'));
|
|
472
|
-
});
|
|
473
|
-
|
|
474
|
-
test('parseMarkdown handles unordered lists', t => {
|
|
475
|
-
const text = '- Item 1\n- Item 2\n* Item 3';
|
|
476
|
-
const result = parseMarkdown(text, mockColors);
|
|
477
|
-
t.true(result.includes('Item 1'));
|
|
478
|
-
t.true(result.includes('Item 2'));
|
|
479
|
-
t.true(result.includes('Item 3'));
|
|
480
|
-
// Should convert to bullets
|
|
481
|
-
t.true(result.includes('•'));
|
|
482
|
-
});
|
|
483
|
-
|
|
484
|
-
test('parseMarkdown handles ordered lists', t => {
|
|
485
|
-
const text = '1. First item\n2. Second item\n3. Third item';
|
|
486
|
-
const result = parseMarkdown(text, mockColors);
|
|
487
|
-
// Should preserve the numbers
|
|
488
|
-
t.true(result.includes('1.'));
|
|
489
|
-
t.true(result.includes('2.'));
|
|
490
|
-
t.true(result.includes('3.'));
|
|
491
|
-
t.true(result.includes('First item'));
|
|
492
|
-
t.true(result.includes('Second item'));
|
|
493
|
-
t.true(result.includes('Third item'));
|
|
494
|
-
});
|
|
495
|
-
|
|
496
|
-
test('parseMarkdown decodes HTML entities', t => {
|
|
497
|
-
const text = 'Price: €100 only';
|
|
498
|
-
const result = parseMarkdown(text, mockColors);
|
|
499
|
-
t.true(result.includes('€'));
|
|
500
|
-
t.true(result.includes('100'));
|
|
501
|
-
t.true(result.includes('only'));
|
|
502
|
-
t.false(result.includes('€'));
|
|
503
|
-
t.false(result.includes(' '));
|
|
504
|
-
});
|
|
505
|
-
|
|
506
|
-
test('parseMarkdown handles tables', t => {
|
|
507
|
-
const text = `
|
|
508
|
-
Here is a table:
|
|
509
|
-
|
|
510
|
-
| Name | Age |
|
|
511
|
-
|------|-----|
|
|
512
|
-
| John | 30 |
|
|
513
|
-
| Jane | 25 |
|
|
514
|
-
|
|
515
|
-
That was the table.
|
|
516
|
-
`;
|
|
517
|
-
const result = parseMarkdown(text, mockColors);
|
|
518
|
-
t.true(result.includes('Name'));
|
|
519
|
-
t.true(result.includes('Age'));
|
|
520
|
-
t.true(result.includes('John'));
|
|
521
|
-
t.true(result.includes('Jane'));
|
|
522
|
-
t.true(result.includes('│'));
|
|
523
|
-
});
|
|
524
|
-
|
|
525
|
-
test('parseMarkdown handles mixed markdown features', t => {
|
|
526
|
-
const text = `
|
|
527
|
-
# Title
|
|
528
|
-
|
|
529
|
-
This has **bold** and *italic* text.
|
|
530
|
-
|
|
531
|
-
- List item 1
|
|
532
|
-
- List item 2
|
|
533
|
-
|
|
534
|
-
\`code here\`
|
|
535
|
-
|
|
536
|
-
> A quote
|
|
537
|
-
|
|
538
|
-
Price: €50
|
|
539
|
-
`;
|
|
540
|
-
const result = parseMarkdown(text, mockColors);
|
|
541
|
-
t.true(result.includes('Title'));
|
|
542
|
-
t.true(result.includes('bold'));
|
|
543
|
-
t.true(result.includes('italic'));
|
|
544
|
-
t.true(result.includes('List item 1'));
|
|
545
|
-
t.true(result.includes('code here'));
|
|
546
|
-
t.true(result.includes('A quote'));
|
|
547
|
-
t.true(result.includes('€'));
|
|
548
|
-
t.false(result.includes('€'));
|
|
549
|
-
});
|
|
550
|
-
|
|
551
|
-
test('parseMarkdown handles plain text without markdown', t => {
|
|
552
|
-
const text = 'Just plain text with no special formatting';
|
|
553
|
-
const result = parseMarkdown(text, mockColors);
|
|
554
|
-
t.is(result, text);
|
|
555
|
-
});
|
|
556
|
-
|
|
557
|
-
test('parseMarkdown handles empty string', t => {
|
|
558
|
-
const result = parseMarkdown('', mockColors);
|
|
559
|
-
t.is(result, '');
|
|
560
|
-
});
|
|
561
|
-
|
|
562
|
-
test('parseMarkdown handles code blocks with language', t => {
|
|
563
|
-
const text = '```javascript\nconst x = 5;\n```';
|
|
564
|
-
const result = parseMarkdown(text, mockColors);
|
|
565
|
-
t.true(result.includes('const'));
|
|
566
|
-
t.true(result.includes('x'));
|
|
567
|
-
});
|
|
568
|
-
|
|
569
|
-
test('parseMarkdown handles code blocks without language', t => {
|
|
570
|
-
const text = '```\nplain code\n```';
|
|
571
|
-
const result = parseMarkdown(text, mockColors);
|
|
572
|
-
t.true(result.includes('plain code'));
|
|
573
|
-
});
|
|
574
|
-
|
|
575
|
-
// ============================================================================
|
|
576
|
-
// Edge Case Tests - Things That Should NOT Be Formatted
|
|
577
|
-
// ============================================================================
|
|
578
|
-
|
|
579
|
-
test('parseMarkdown does not create bullet list from hyphen in middle of line', t => {
|
|
580
|
-
const text = 'The file path is C:\\Users\\John - Documents\\file.txt';
|
|
581
|
-
const result = parseMarkdown(text, mockColors);
|
|
582
|
-
// Should not have bullet point character
|
|
583
|
-
t.false(result.includes('•'));
|
|
584
|
-
t.true(result.includes('C:\\Users\\John - Documents\\file.txt'));
|
|
585
|
-
});
|
|
586
|
-
|
|
587
|
-
test('parseMarkdown does not format asterisks in math expressions', t => {
|
|
588
|
-
const text = 'Calculate 5 * 3 * 2 = 30';
|
|
589
|
-
const result = parseMarkdown(text, mockColors);
|
|
590
|
-
// Should preserve the asterisks and not apply formatting
|
|
591
|
-
t.true(result.includes('5 * 3 * 2'));
|
|
592
|
-
});
|
|
593
|
-
|
|
594
|
-
test('parseMarkdown does not format asterisks in file globs', t => {
|
|
595
|
-
const text = 'Use glob pattern *.tsx or **/*.js to match files';
|
|
596
|
-
const result = parseMarkdown(text, mockColors);
|
|
597
|
-
// Should preserve asterisks in glob patterns
|
|
598
|
-
t.true(result.includes('*.tsx'));
|
|
599
|
-
t.true(result.includes('**/*.js'));
|
|
600
|
-
});
|
|
601
|
-
|
|
602
|
-
test('parseMarkdown does not create heading from hash in middle of line', t => {
|
|
603
|
-
const text = 'The commit hash is abc123 #main branch';
|
|
604
|
-
const result = parseMarkdown(text, mockColors);
|
|
605
|
-
// Should not be formatted as heading since # is not at line start
|
|
606
|
-
t.true(result.includes('#main'));
|
|
607
|
-
});
|
|
608
|
-
|
|
609
|
-
test('parseMarkdown does not create heading from hex color', t => {
|
|
610
|
-
const text = 'Use color #3b82f6 for the button';
|
|
611
|
-
const result = parseMarkdown(text, mockColors);
|
|
612
|
-
// Should not format as heading
|
|
613
|
-
t.true(result.includes('#3b82f6'));
|
|
614
|
-
});
|
|
615
|
-
|
|
616
|
-
test('parseMarkdown preserves asterisks inside code blocks', t => {
|
|
617
|
-
const text = '```javascript\nconst pattern = /\\*\\*/g;\n```';
|
|
618
|
-
const result = parseMarkdown(text, mockColors);
|
|
619
|
-
// Asterisks inside code block should not trigger bold formatting
|
|
620
|
-
t.true(result.includes('pattern'));
|
|
621
|
-
// Code block content should be preserved
|
|
622
|
-
t.true(result.includes('/\\*\\*/g'));
|
|
623
|
-
});
|
|
624
|
-
|
|
625
|
-
test('parseMarkdown preserves markdown-like syntax inside inline code', t => {
|
|
626
|
-
const text = 'Use the pattern `**bold**` to make text bold';
|
|
627
|
-
const result = parseMarkdown(text, mockColors);
|
|
628
|
-
// The **bold** inside backticks should NOT be formatted
|
|
629
|
-
t.true(result.includes('**bold**'));
|
|
630
|
-
});
|
|
631
|
-
|
|
632
|
-
test('parseMarkdown does not format bullet with no space after hyphen', t => {
|
|
633
|
-
const text = 'The range is 1-10 and 20-30';
|
|
634
|
-
const result = parseMarkdown(text, mockColors);
|
|
635
|
-
// Should not create bullets for hyphens without spaces
|
|
636
|
-
t.false(result.includes('•'));
|
|
637
|
-
t.true(result.includes('1-10'));
|
|
638
|
-
t.true(result.includes('20-30'));
|
|
639
|
-
});
|
|
640
|
-
|
|
641
|
-
test('parseMarkdown handles mixed asterisks and bullet points', t => {
|
|
642
|
-
const text = '* First item\n* Second item with 2 * 3 = 6 calculation';
|
|
643
|
-
const result = parseMarkdown(text, mockColors);
|
|
644
|
-
// Should have bullets for list items
|
|
645
|
-
t.true(result.includes('•'));
|
|
646
|
-
t.true(result.includes('First item'));
|
|
647
|
-
// But preserve asterisks in math
|
|
648
|
-
t.true(result.includes('2 * 3'));
|
|
649
|
-
});
|
|
650
|
-
|
|
651
|
-
test('parseMarkdown does not format single asterisk surrounded by word chars', t => {
|
|
652
|
-
const text = 'The pointer syntax is char*ptr or int*value';
|
|
653
|
-
const result = parseMarkdown(text, mockColors);
|
|
654
|
-
// Should preserve pointer syntax
|
|
655
|
-
t.true(result.includes('char*ptr'));
|
|
656
|
-
t.true(result.includes('int*value'));
|
|
657
|
-
});
|
|
658
|
-
|
|
659
|
-
test('parseMarkdown preserves double asterisks in code comments', t => {
|
|
660
|
-
const text = 'In C: /* comment */ and /** doc comment */';
|
|
661
|
-
const result = parseMarkdown(text, mockColors);
|
|
662
|
-
// Should not treat /* or /** as bold markers
|
|
663
|
-
t.true(result.includes('/*'));
|
|
664
|
-
t.true(result.includes('/**'));
|
|
665
|
-
});
|
|
666
|
-
|
|
667
|
-
test('parseMarkdown handles hyphen in URL correctly', t => {
|
|
668
|
-
const text = 'Visit [my-site](https://example-domain.com/my-page)';
|
|
669
|
-
const result = parseMarkdown(text, mockColors);
|
|
670
|
-
// Should not create bullets from hyphens in URLs
|
|
671
|
-
t.false(result.includes('•'));
|
|
672
|
-
t.true(result.includes('example-domain.com/my-page'));
|
|
673
|
-
});
|
|
674
|
-
|
|
675
|
-
test('parseMarkdown handles bullet list with bold text correctly', t => {
|
|
676
|
-
const text = `* **Reading and understanding code** – view files
|
|
677
|
-
* **Creating new files** – scaffold components
|
|
678
|
-
* **Editing existing code** – insert, replace, or delete`;
|
|
679
|
-
const result = parseMarkdown(text, mockColors);
|
|
680
|
-
// Should have bullets
|
|
681
|
-
t.true(result.includes('•'));
|
|
682
|
-
// Should have the text (bold markers may be removed)
|
|
683
|
-
t.true(result.includes('Reading and understanding code'));
|
|
684
|
-
t.true(result.includes('Creating new files'));
|
|
685
|
-
t.true(result.includes('Editing existing code'));
|
|
686
|
-
// Should NOT have italic formatting bleeding across lines
|
|
687
|
-
// (checking that all items have similar formatting)
|
|
688
|
-
});
|
|
689
|
-
|
|
690
|
-
test('parseMarkdown handles nested/indented bullet lists', t => {
|
|
691
|
-
const text = `- Top level item
|
|
692
|
-
- Nested item 1
|
|
693
|
-
- Nested item 2
|
|
694
|
-
- Double nested
|
|
695
|
-
- Another top level`;
|
|
696
|
-
const result = parseMarkdown(text, mockColors);
|
|
697
|
-
// Should have bullets
|
|
698
|
-
t.true(result.includes('•'));
|
|
699
|
-
t.true(result.includes('Top level item'));
|
|
700
|
-
t.true(result.includes('Nested item 1'));
|
|
701
|
-
t.true(result.includes('Double nested'));
|
|
702
|
-
// Check indentation is preserved (should have 2 spaces before nested bullets)
|
|
703
|
-
t.true(result.includes(' • Nested item 1'));
|
|
704
|
-
t.true(result.includes(' • Double nested'));
|
|
705
|
-
});
|
|
706
|
-
|
|
707
|
-
test('parseMarkdown handles nested numbered lists', t => {
|
|
708
|
-
const text = `1. First item
|
|
709
|
-
1. Nested first
|
|
710
|
-
2. Nested second
|
|
711
|
-
2. Second item`;
|
|
712
|
-
const result = parseMarkdown(text, mockColors);
|
|
713
|
-
t.true(result.includes('1. First item'));
|
|
714
|
-
t.true(result.includes('2. Second item'));
|
|
715
|
-
// Check nested numbering preserved
|
|
716
|
-
t.true(result.includes(' 1. Nested first'));
|
|
717
|
-
t.true(result.includes(' 2. Nested second'));
|
|
718
|
-
});
|
|
719
|
-
|
|
720
|
-
test('parseMarkdown restores inline code placeholders correctly', t => {
|
|
721
|
-
const text = 'Use `npm install` and `npm start` commands';
|
|
722
|
-
const result = parseMarkdown(text, mockColors);
|
|
723
|
-
// Should have the code content
|
|
724
|
-
t.true(result.includes('npm install'));
|
|
725
|
-
t.true(result.includes('npm start'));
|
|
726
|
-
// Should NOT have placeholder remnants
|
|
727
|
-
t.false(result.includes('__INLINE_CODE'));
|
|
728
|
-
t.false(result.includes('_INLINE'));
|
|
729
|
-
t.false(result.includes('CODE_'));
|
|
730
|
-
});
|
|
731
|
-
|
|
732
|
-
test('parseMarkdown renders tables with plain text (no markdown)', t => {
|
|
733
|
-
const text = `| Command | Description |
|
|
734
|
-
|---------|-------------|
|
|
735
|
-
| \`npm install\` | Install dependencies |
|
|
736
|
-
| \`npm start\` | Start the application |`;
|
|
737
|
-
const result = parseMarkdown(text, mockColors);
|
|
738
|
-
// Should have the plain text content (backticks removed)
|
|
739
|
-
t.true(result.includes('npm install'));
|
|
740
|
-
t.true(result.includes('npm start'));
|
|
741
|
-
t.true(result.includes('Install dependencies'));
|
|
742
|
-
// Should NOT have backticks in table
|
|
743
|
-
t.false(result.includes('`npm install`'));
|
|
744
|
-
t.false(result.includes('`npm start`'));
|
|
745
|
-
// Should NOT have placeholder remnants or corruption
|
|
746
|
-
t.false(result.includes('__INLINE_CODE'));
|
|
747
|
-
t.false(result.includes('_INLINE'));
|
|
748
|
-
t.false(result.includes('CODE_'));
|
|
749
|
-
t.false(result.includes('INLINECODE'));
|
|
750
|
-
});
|
|
751
|
-
|
|
752
|
-
test('parseMarkdown converts <br> tags to newlines', t => {
|
|
753
|
-
const text = 'Line one<br>Line two<br/>Line three<BR>Line four';
|
|
754
|
-
const result = parseMarkdown(text, mockColors);
|
|
755
|
-
const lines = result.split('\n');
|
|
756
|
-
t.true(lines.length >= 4);
|
|
757
|
-
t.true(result.includes('Line one'));
|
|
758
|
-
t.true(result.includes('Line two'));
|
|
759
|
-
t.true(result.includes('Line three'));
|
|
760
|
-
t.true(result.includes('Line four'));
|
|
761
|
-
t.false(result.includes('<br'));
|
|
762
|
-
t.false(result.includes('<BR'));
|
|
763
|
-
});
|
|
764
|
-
|
|
765
|
-
test('parseMarkdown preserves spacing before bullet lists', t => {
|
|
766
|
-
const text = `I can assist with tasks such as:
|
|
767
|
-
|
|
768
|
-
- First item
|
|
769
|
-
- Second item
|
|
770
|
-
|
|
771
|
-
Let me know what you'd like to work on.`;
|
|
772
|
-
const result = parseMarkdown(text, mockColors);
|
|
773
|
-
|
|
774
|
-
// Should have the paragraph text
|
|
775
|
-
t.true(result.includes('I can assist with tasks such as:'));
|
|
776
|
-
|
|
777
|
-
// Should have bullets
|
|
778
|
-
t.true(result.includes('•'));
|
|
779
|
-
t.true(result.includes('First item'));
|
|
780
|
-
t.true(result.includes('Second item'));
|
|
781
|
-
|
|
782
|
-
// Should have the closing text
|
|
783
|
-
t.true(result.includes("Let me know what you'd like to work on."));
|
|
784
|
-
|
|
785
|
-
// Should have proper spacing - check for double newline before list
|
|
786
|
-
// (The blank line should be preserved)
|
|
787
|
-
const lines = result.split('\n');
|
|
788
|
-
const suchAsIndex = lines.findIndex(l => l.includes('I can assist'));
|
|
789
|
-
const firstBulletIndex = lines.findIndex(l => l.includes('• First'));
|
|
790
|
-
|
|
791
|
-
// There should be at least one empty line between them
|
|
792
|
-
t.true(
|
|
793
|
-
firstBulletIndex - suchAsIndex >= 2,
|
|
794
|
-
'Should have blank line before list',
|
|
795
|
-
);
|
|
796
|
-
});
|