osagent-core 0.1.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/.last_build +0 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/src/__mocks__/fs/promises.d.ts +11 -0
- package/dist/src/__mocks__/fs/promises.js +17 -0
- package/dist/src/__mocks__/fs/promises.js.map +1 -0
- package/dist/src/code_assist/codeAssist.d.ts +12 -0
- package/dist/src/code_assist/codeAssist.js +31 -0
- package/dist/src/code_assist/codeAssist.js.map +1 -0
- package/dist/src/code_assist/converter.d.ts +74 -0
- package/dist/src/code_assist/converter.js +160 -0
- package/dist/src/code_assist/converter.js.map +1 -0
- package/dist/src/code_assist/converter.test.d.ts +6 -0
- package/dist/src/code_assist/converter.test.js +372 -0
- package/dist/src/code_assist/converter.test.js.map +1 -0
- package/dist/src/code_assist/oauth-credential-storage.d.ts +25 -0
- package/dist/src/code_assist/oauth-credential-storage.js +109 -0
- package/dist/src/code_assist/oauth-credential-storage.js.map +1 -0
- package/dist/src/code_assist/oauth-credential-storage.test.d.ts +6 -0
- package/dist/src/code_assist/oauth-credential-storage.test.js +136 -0
- package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -0
- package/dist/src/code_assist/oauth2.d.ts +22 -0
- package/dist/src/code_assist/oauth2.js +431 -0
- package/dist/src/code_assist/oauth2.js.map +1 -0
- package/dist/src/code_assist/oauth2.test.d.ts +6 -0
- package/dist/src/code_assist/oauth2.test.js +818 -0
- package/dist/src/code_assist/oauth2.test.js.map +1 -0
- package/dist/src/code_assist/server.d.ts +37 -0
- package/dist/src/code_assist/server.js +148 -0
- package/dist/src/code_assist/server.js.map +1 -0
- package/dist/src/code_assist/server.test.d.ts +6 -0
- package/dist/src/code_assist/server.test.js +159 -0
- package/dist/src/code_assist/server.test.js.map +1 -0
- package/dist/src/code_assist/setup.d.ts +20 -0
- package/dist/src/code_assist/setup.js +101 -0
- package/dist/src/code_assist/setup.js.map +1 -0
- package/dist/src/code_assist/setup.test.d.ts +6 -0
- package/dist/src/code_assist/setup.test.js +171 -0
- package/dist/src/code_assist/setup.test.js.map +1 -0
- package/dist/src/code_assist/types.d.ts +163 -0
- package/dist/src/code_assist/types.js +46 -0
- package/dist/src/code_assist/types.js.map +1 -0
- package/dist/src/config/config.d.ts +429 -0
- package/dist/src/config/config.js +863 -0
- package/dist/src/config/config.js.map +1 -0
- package/dist/src/config/config.test.d.ts +6 -0
- package/dist/src/config/config.test.js +896 -0
- package/dist/src/config/config.test.js.map +1 -0
- package/dist/src/config/constants.d.ts +11 -0
- package/dist/src/config/constants.js +16 -0
- package/dist/src/config/constants.js.map +1 -0
- package/dist/src/config/flashFallback.test.d.ts +6 -0
- package/dist/src/config/flashFallback.test.js +87 -0
- package/dist/src/config/flashFallback.test.js.map +1 -0
- package/dist/src/config/models.d.ts +28 -0
- package/dist/src/config/models.js +44 -0
- package/dist/src/config/models.js.map +1 -0
- package/dist/src/config/models.test.d.ts +6 -0
- package/dist/src/config/models.test.js +55 -0
- package/dist/src/config/models.test.js.map +1 -0
- package/dist/src/config/storage.d.ts +36 -0
- package/dist/src/config/storage.js +103 -0
- package/dist/src/config/storage.js.map +1 -0
- package/dist/src/config/storage.test.d.ts +6 -0
- package/dist/src/config/storage.test.js +43 -0
- package/dist/src/config/storage.test.js.map +1 -0
- package/dist/src/core/__tests__/openaiTimeoutHandling.test.d.ts +6 -0
- package/dist/src/core/__tests__/openaiTimeoutHandling.test.js +295 -0
- package/dist/src/core/__tests__/openaiTimeoutHandling.test.js.map +1 -0
- package/dist/src/core/__tests__/orphanedToolCallsTest.d.ts +64 -0
- package/dist/src/core/__tests__/orphanedToolCallsTest.js +122 -0
- package/dist/src/core/__tests__/orphanedToolCallsTest.js.map +1 -0
- package/dist/src/core/baseLlmClient.d.ts +49 -0
- package/dist/src/core/baseLlmClient.js +104 -0
- package/dist/src/core/baseLlmClient.js.map +1 -0
- package/dist/src/core/baseLlmClient.test.d.ts +6 -0
- package/dist/src/core/baseLlmClient.test.js +323 -0
- package/dist/src/core/baseLlmClient.test.js.map +1 -0
- package/dist/src/core/client.d.ts +56 -0
- package/dist/src/core/client.js +522 -0
- package/dist/src/core/client.js.map +1 -0
- package/dist/src/core/client.test.d.ts +6 -0
- package/dist/src/core/client.test.js +1829 -0
- package/dist/src/core/client.test.js.map +1 -0
- package/dist/src/core/contentGenerator.d.ts +54 -0
- package/dist/src/core/contentGenerator.js +170 -0
- package/dist/src/core/contentGenerator.js.map +1 -0
- package/dist/src/core/contentGenerator.test.d.ts +6 -0
- package/dist/src/core/contentGenerator.test.js +77 -0
- package/dist/src/core/contentGenerator.test.js.map +1 -0
- package/dist/src/core/coreToolScheduler.d.ts +134 -0
- package/dist/src/core/coreToolScheduler.js +774 -0
- package/dist/src/core/coreToolScheduler.js.map +1 -0
- package/dist/src/core/coreToolScheduler.test.d.ts +6 -0
- package/dist/src/core/coreToolScheduler.test.js +1802 -0
- package/dist/src/core/coreToolScheduler.test.js.map +1 -0
- package/dist/src/core/geminiChat.d.ts +124 -0
- package/dist/src/core/geminiChat.js +518 -0
- package/dist/src/core/geminiChat.js.map +1 -0
- package/dist/src/core/geminiChat.test.d.ts +6 -0
- package/dist/src/core/geminiChat.test.js +1149 -0
- package/dist/src/core/geminiChat.test.js.map +1 -0
- package/dist/src/core/geminiRequest.d.ts +13 -0
- package/dist/src/core/geminiRequest.js +11 -0
- package/dist/src/core/geminiRequest.js.map +1 -0
- package/dist/src/core/geminiRequest.test.d.ts +6 -0
- package/dist/src/core/geminiRequest.test.js +73 -0
- package/dist/src/core/geminiRequest.test.js.map +1 -0
- package/dist/src/core/logger.d.ts +67 -0
- package/dist/src/core/logger.js +361 -0
- package/dist/src/core/logger.js.map +1 -0
- package/dist/src/core/logger.test.d.ts +6 -0
- package/dist/src/core/logger.test.js +534 -0
- package/dist/src/core/logger.test.js.map +1 -0
- package/dist/src/core/loggingContentGenerator.d.ts +25 -0
- package/dist/src/core/loggingContentGenerator.js +94 -0
- package/dist/src/core/loggingContentGenerator.js.map +1 -0
- package/dist/src/core/nonInteractiveToolExecutor.d.ts +16 -0
- package/dist/src/core/nonInteractiveToolExecutor.js +29 -0
- package/dist/src/core/nonInteractiveToolExecutor.js.map +1 -0
- package/dist/src/core/nonInteractiveToolExecutor.test.d.ts +6 -0
- package/dist/src/core/nonInteractiveToolExecutor.test.js +294 -0
- package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -0
- package/dist/src/core/ollamaContentGenerator/index.d.ts +70 -0
- package/dist/src/core/ollamaContentGenerator/index.js +450 -0
- package/dist/src/core/ollamaContentGenerator/index.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/constants.d.ts +7 -0
- package/dist/src/core/openaiContentGenerator/constants.js +8 -0
- package/dist/src/core/openaiContentGenerator/constants.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/converter.d.ts +108 -0
- package/dist/src/core/openaiContentGenerator/converter.js +851 -0
- package/dist/src/core/openaiContentGenerator/converter.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/converter.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/converter.test.js +108 -0
- package/dist/src/core/openaiContentGenerator/converter.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/errorHandler.d.ts +20 -0
- package/dist/src/core/openaiContentGenerator/errorHandler.js +82 -0
- package/dist/src/core/openaiContentGenerator/errorHandler.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/errorHandler.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/errorHandler.test.js +287 -0
- package/dist/src/core/openaiContentGenerator/errorHandler.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/index.d.ts +22 -0
- package/dist/src/core/openaiContentGenerator/index.js +57 -0
- package/dist/src/core/openaiContentGenerator/index.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/openaiContentGenerator.d.ts +21 -0
- package/dist/src/core/openaiContentGenerator/openaiContentGenerator.js +105 -0
- package/dist/src/core/openaiContentGenerator/openaiContentGenerator.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js +230 -0
- package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/pipeline.d.ts +66 -0
- package/dist/src/core/openaiContentGenerator/pipeline.js +265 -0
- package/dist/src/core/openaiContentGenerator/pipeline.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/pipeline.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/pipeline.test.js +1028 -0
- package/dist/src/core/openaiContentGenerator/pipeline.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/README.md +61 -0
- package/dist/src/core/openaiContentGenerator/provider/anthropic.d.ts +14 -0
- package/dist/src/core/openaiContentGenerator/provider/anthropic.js +28 -0
- package/dist/src/core/openaiContentGenerator/provider/anthropic.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/anthropic.test.d.ts +1 -0
- package/dist/src/core/openaiContentGenerator/provider/anthropic.test.js +138 -0
- package/dist/src/core/openaiContentGenerator/provider/anthropic.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/dashscope.d.ts +63 -0
- package/dist/src/core/openaiContentGenerator/provider/dashscope.js +241 -0
- package/dist/src/core/openaiContentGenerator/provider/dashscope.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/dashscope.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/provider/dashscope.test.js +707 -0
- package/dist/src/core/openaiContentGenerator/provider/dashscope.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/deepseek.d.ts +14 -0
- package/dist/src/core/openaiContentGenerator/provider/deepseek.js +70 -0
- package/dist/src/core/openaiContentGenerator/provider/deepseek.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/deepseek.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/provider/deepseek.test.js +151 -0
- package/dist/src/core/openaiContentGenerator/provider/deepseek.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/default.d.ts +15 -0
- package/dist/src/core/openaiContentGenerator/provider/default.js +38 -0
- package/dist/src/core/openaiContentGenerator/provider/default.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/default.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/provider/default.test.js +176 -0
- package/dist/src/core/openaiContentGenerator/provider/default.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/groq.d.ts +30 -0
- package/dist/src/core/openaiContentGenerator/provider/groq.js +60 -0
- package/dist/src/core/openaiContentGenerator/provider/groq.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/index.d.ts +9 -0
- package/dist/src/core/openaiContentGenerator/provider/index.js +9 -0
- package/dist/src/core/openaiContentGenerator/provider/index.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/modelscope.d.ts +17 -0
- package/dist/src/core/openaiContentGenerator/provider/modelscope.js +25 -0
- package/dist/src/core/openaiContentGenerator/provider/modelscope.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/modelscope.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/provider/modelscope.test.js +66 -0
- package/dist/src/core/openaiContentGenerator/provider/modelscope.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/ollama.d.ts +31 -0
- package/dist/src/core/openaiContentGenerator/provider/ollama.js +70 -0
- package/dist/src/core/openaiContentGenerator/provider/ollama.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/openrouter.d.ts +10 -0
- package/dist/src/core/openaiContentGenerator/provider/openrouter.js +33 -0
- package/dist/src/core/openaiContentGenerator/provider/openrouter.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/openrouter.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/provider/openrouter.test.js +175 -0
- package/dist/src/core/openaiContentGenerator/provider/openrouter.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/provider/types.d.ts +23 -0
- package/dist/src/core/openaiContentGenerator/provider/types.js +2 -0
- package/dist/src/core/openaiContentGenerator/provider/types.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/streamingToolCallParser.d.ts +145 -0
- package/dist/src/core/openaiContentGenerator/streamingToolCallParser.js +381 -0
- package/dist/src/core/openaiContentGenerator/streamingToolCallParser.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js +537 -0
- package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/telemetryService.d.ts +36 -0
- package/dist/src/core/openaiContentGenerator/telemetryService.js +150 -0
- package/dist/src/core/openaiContentGenerator/telemetryService.js.map +1 -0
- package/dist/src/core/openaiContentGenerator/telemetryService.test.d.ts +6 -0
- package/dist/src/core/openaiContentGenerator/telemetryService.test.js +978 -0
- package/dist/src/core/openaiContentGenerator/telemetryService.test.js.map +1 -0
- package/dist/src/core/prompts.d.ts +73 -0
- package/dist/src/core/prompts.js +813 -0
- package/dist/src/core/prompts.js.map +1 -0
- package/dist/src/core/prompts.test.d.ts +6 -0
- package/dist/src/core/prompts.test.js +488 -0
- package/dist/src/core/prompts.test.js.map +1 -0
- package/dist/src/core/tokenLimits.d.ts +25 -0
- package/dist/src/core/tokenLimits.js +200 -0
- package/dist/src/core/tokenLimits.js.map +1 -0
- package/dist/src/core/tokenLimits.test.d.ts +1 -0
- package/dist/src/core/tokenLimits.test.js +304 -0
- package/dist/src/core/tokenLimits.test.js.map +1 -0
- package/dist/src/core/turn.d.ts +152 -0
- package/dist/src/core/turn.js +187 -0
- package/dist/src/core/turn.js.map +1 -0
- package/dist/src/core/turn.test.d.ts +6 -0
- package/dist/src/core/turn.test.js +628 -0
- package/dist/src/core/turn.test.js.map +1 -0
- package/dist/src/fallback/handler.d.ts +7 -0
- package/dist/src/fallback/handler.js +97 -0
- package/dist/src/fallback/handler.js.map +1 -0
- package/dist/src/fallback/handler.test.d.ts +6 -0
- package/dist/src/fallback/handler.test.js +130 -0
- package/dist/src/fallback/handler.test.js.map +1 -0
- package/dist/src/fallback/types.d.ts +14 -0
- package/dist/src/fallback/types.js +7 -0
- package/dist/src/fallback/types.js.map +1 -0
- package/dist/src/generated/git-commit.d.ts +7 -0
- package/dist/src/generated/git-commit.js +10 -0
- package/dist/src/generated/git-commit.js.map +1 -0
- package/dist/src/ide/constants.d.ts +10 -0
- package/dist/src/ide/constants.js +12 -0
- package/dist/src/ide/constants.js.map +1 -0
- package/dist/src/ide/detect-ide.d.ts +56 -0
- package/dist/src/ide/detect-ide.js +68 -0
- package/dist/src/ide/detect-ide.js.map +1 -0
- package/dist/src/ide/detect-ide.test.d.ts +6 -0
- package/dist/src/ide/detect-ide.test.js +113 -0
- package/dist/src/ide/detect-ide.test.js.map +1 -0
- package/dist/src/ide/ide-client.d.ts +110 -0
- package/dist/src/ide/ide-client.js +651 -0
- package/dist/src/ide/ide-client.js.map +1 -0
- package/dist/src/ide/ide-client.test.d.ts +6 -0
- package/dist/src/ide/ide-client.test.js +390 -0
- package/dist/src/ide/ide-client.test.js.map +1 -0
- package/dist/src/ide/ide-installer.d.ts +14 -0
- package/dist/src/ide/ide-installer.js +112 -0
- package/dist/src/ide/ide-installer.js.map +1 -0
- package/dist/src/ide/ide-installer.test.d.ts +6 -0
- package/dist/src/ide/ide-installer.test.js +134 -0
- package/dist/src/ide/ide-installer.test.js.map +1 -0
- package/dist/src/ide/ideContext.d.ts +44 -0
- package/dist/src/ide/ideContext.js +101 -0
- package/dist/src/ide/ideContext.js.map +1 -0
- package/dist/src/ide/ideContext.test.d.ts +6 -0
- package/dist/src/ide/ideContext.test.js +393 -0
- package/dist/src/ide/ideContext.test.js.map +1 -0
- package/dist/src/ide/process-utils.d.ts +21 -0
- package/dist/src/ide/process-utils.js +171 -0
- package/dist/src/ide/process-utils.js.map +1 -0
- package/dist/src/ide/process-utils.test.d.ts +6 -0
- package/dist/src/ide/process-utils.test.js +158 -0
- package/dist/src/ide/process-utils.test.js.map +1 -0
- package/dist/src/ide/types.d.ts +486 -0
- package/dist/src/ide/types.js +138 -0
- package/dist/src/ide/types.js.map +1 -0
- package/dist/src/index.d.ts +97 -0
- package/dist/src/index.js +110 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/index.test.d.ts +6 -0
- package/dist/src/index.test.js +12 -0
- package/dist/src/index.test.js.map +1 -0
- package/dist/src/mcp/google-auth-provider.d.ts +23 -0
- package/dist/src/mcp/google-auth-provider.js +72 -0
- package/dist/src/mcp/google-auth-provider.js.map +1 -0
- package/dist/src/mcp/google-auth-provider.test.d.ts +6 -0
- package/dist/src/mcp/google-auth-provider.test.js +89 -0
- package/dist/src/mcp/google-auth-provider.test.js.map +1 -0
- package/dist/src/mcp/oauth-provider.d.ts +150 -0
- package/dist/src/mcp/oauth-provider.js +613 -0
- package/dist/src/mcp/oauth-provider.js.map +1 -0
- package/dist/src/mcp/oauth-provider.test.d.ts +6 -0
- package/dist/src/mcp/oauth-provider.test.js +847 -0
- package/dist/src/mcp/oauth-provider.test.js.map +1 -0
- package/dist/src/mcp/oauth-token-storage.d.ts +65 -0
- package/dist/src/mcp/oauth-token-storage.js +180 -0
- package/dist/src/mcp/oauth-token-storage.js.map +1 -0
- package/dist/src/mcp/oauth-token-storage.test.d.ts +6 -0
- package/dist/src/mcp/oauth-token-storage.test.js +299 -0
- package/dist/src/mcp/oauth-token-storage.test.js.map +1 -0
- package/dist/src/mcp/oauth-utils.d.ts +119 -0
- package/dist/src/mcp/oauth-utils.js +236 -0
- package/dist/src/mcp/oauth-utils.js.map +1 -0
- package/dist/src/mcp/oauth-utils.test.d.ts +6 -0
- package/dist/src/mcp/oauth-utils.test.js +199 -0
- package/dist/src/mcp/oauth-utils.test.js.map +1 -0
- package/dist/src/mcp/sa-impersonation-provider.d.ts +33 -0
- package/dist/src/mcp/sa-impersonation-provider.js +130 -0
- package/dist/src/mcp/sa-impersonation-provider.js.map +1 -0
- package/dist/src/mcp/sa-impersonation-provider.test.d.ts +6 -0
- package/dist/src/mcp/sa-impersonation-provider.test.js +117 -0
- package/dist/src/mcp/sa-impersonation-provider.test.js.map +1 -0
- package/dist/src/mcp/token-storage/base-token-storage.d.ts +19 -0
- package/dist/src/mcp/token-storage/base-token-storage.js +36 -0
- package/dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
- package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +6 -0
- package/dist/src/mcp/token-storage/base-token-storage.test.js +160 -0
- package/dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
- package/dist/src/mcp/token-storage/file-token-storage.d.ts +24 -0
- package/dist/src/mcp/token-storage/file-token-storage.js +144 -0
- package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -0
- package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +6 -0
- package/dist/src/mcp/token-storage/file-token-storage.test.js +235 -0
- package/dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -0
- package/dist/src/mcp/token-storage/hybrid-token-storage.d.ts +23 -0
- package/dist/src/mcp/token-storage/hybrid-token-storage.js +78 -0
- package/dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -0
- package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +6 -0
- package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +193 -0
- package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +1 -0
- package/dist/src/mcp/token-storage/index.d.ts +11 -0
- package/dist/src/mcp/token-storage/index.js +12 -0
- package/dist/src/mcp/token-storage/index.js.map +1 -0
- package/dist/src/mcp/token-storage/keychain-token-storage.d.ts +31 -0
- package/dist/src/mcp/token-storage/keychain-token-storage.js +190 -0
- package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -0
- package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +6 -0
- package/dist/src/mcp/token-storage/keychain-token-storage.test.js +254 -0
- package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -0
- package/dist/src/mcp/token-storage/types.d.ts +38 -0
- package/dist/src/mcp/token-storage/types.js +11 -0
- package/dist/src/mcp/token-storage/types.js.map +1 -0
- package/dist/src/mocks/msw.d.ts +6 -0
- package/dist/src/mocks/msw.js +8 -0
- package/dist/src/mocks/msw.js.map +1 -0
- package/dist/src/orchestration/agent-registry.d.ts +92 -0
- package/dist/src/orchestration/agent-registry.js +248 -0
- package/dist/src/orchestration/agent-registry.js.map +1 -0
- package/dist/src/orchestration/agents.d.ts +16 -0
- package/dist/src/orchestration/agents.js +857 -0
- package/dist/src/orchestration/agents.js.map +1 -0
- package/dist/src/orchestration/context-manager.d.ts +115 -0
- package/dist/src/orchestration/context-manager.js +609 -0
- package/dist/src/orchestration/context-manager.js.map +1 -0
- package/dist/src/orchestration/dynamic-factory.d.ts +204 -0
- package/dist/src/orchestration/dynamic-factory.js +496 -0
- package/dist/src/orchestration/dynamic-factory.js.map +1 -0
- package/dist/src/orchestration/index.d.ts +17 -0
- package/dist/src/orchestration/index.js +41 -0
- package/dist/src/orchestration/index.js.map +1 -0
- package/dist/src/orchestration/orchestration-queue.d.ts +107 -0
- package/dist/src/orchestration/orchestration-queue.js +268 -0
- package/dist/src/orchestration/orchestration-queue.js.map +1 -0
- package/dist/src/orchestration/orchestrator.d.ts +129 -0
- package/dist/src/orchestration/orchestrator.js +436 -0
- package/dist/src/orchestration/orchestrator.js.map +1 -0
- package/dist/src/orchestration/response-formatter.d.ts +118 -0
- package/dist/src/orchestration/response-formatter.js +302 -0
- package/dist/src/orchestration/response-formatter.js.map +1 -0
- package/dist/src/orchestration/skill-detector.d.ts +35 -0
- package/dist/src/orchestration/skill-detector.js +241 -0
- package/dist/src/orchestration/skill-detector.js.map +1 -0
- package/dist/src/orchestration/skills.d.ts +88 -0
- package/dist/src/orchestration/skills.js +987 -0
- package/dist/src/orchestration/skills.js.map +1 -0
- package/dist/src/orchestration/types.d.ts +371 -0
- package/dist/src/orchestration/types.js +7 -0
- package/dist/src/orchestration/types.js.map +1 -0
- package/dist/src/output/json-formatter.d.ts +11 -0
- package/dist/src/output/json-formatter.js +30 -0
- package/dist/src/output/json-formatter.js.map +1 -0
- package/dist/src/output/json-formatter.test.d.ts +6 -0
- package/dist/src/output/json-formatter.test.js +266 -0
- package/dist/src/output/json-formatter.test.js.map +1 -0
- package/dist/src/output/types.d.ts +25 -0
- package/dist/src/output/types.js +17 -0
- package/dist/src/output/types.js.map +1 -0
- package/dist/src/prompts/mcp-prompts.d.ts +8 -0
- package/dist/src/prompts/mcp-prompts.js +13 -0
- package/dist/src/prompts/mcp-prompts.js.map +1 -0
- package/dist/src/prompts/prompt-registry.d.ts +34 -0
- package/dist/src/prompts/prompt-registry.js +63 -0
- package/dist/src/prompts/prompt-registry.js.map +1 -0
- package/dist/src/qwen/qwenContentGenerator.d.ts +70 -0
- package/dist/src/qwen/qwenContentGenerator.js +180 -0
- package/dist/src/qwen/qwenContentGenerator.js.map +1 -0
- package/dist/src/qwen/qwenContentGenerator.test.d.ts +6 -0
- package/dist/src/qwen/qwenContentGenerator.test.js +1178 -0
- package/dist/src/qwen/qwenContentGenerator.test.js.map +1 -0
- package/dist/src/qwen/qwenOAuth2.d.ts +194 -0
- package/dist/src/qwen/qwenOAuth2.js +594 -0
- package/dist/src/qwen/qwenOAuth2.js.map +1 -0
- package/dist/src/qwen/qwenOAuth2.test.d.ts +6 -0
- package/dist/src/qwen/qwenOAuth2.test.js +1724 -0
- package/dist/src/qwen/qwenOAuth2.test.js.map +1 -0
- package/dist/src/qwen/sharedTokenManager.d.ts +196 -0
- package/dist/src/qwen/sharedTokenManager.js +647 -0
- package/dist/src/qwen/sharedTokenManager.js.map +1 -0
- package/dist/src/qwen/sharedTokenManager.test.d.ts +7 -0
- package/dist/src/qwen/sharedTokenManager.test.js +662 -0
- package/dist/src/qwen/sharedTokenManager.test.js.map +1 -0
- package/dist/src/services/chatCompressionService.d.ts +32 -0
- package/dist/src/services/chatCompressionService.js +180 -0
- package/dist/src/services/chatCompressionService.js.map +1 -0
- package/dist/src/services/chatCompressionService.test.d.ts +6 -0
- package/dist/src/services/chatCompressionService.test.js +292 -0
- package/dist/src/services/chatCompressionService.test.js.map +1 -0
- package/dist/src/services/chatRecordingService.d.ts +144 -0
- package/dist/src/services/chatRecordingService.js +330 -0
- package/dist/src/services/chatRecordingService.js.map +1 -0
- package/dist/src/services/chatRecordingService.test.d.ts +6 -0
- package/dist/src/services/chatRecordingService.test.js +332 -0
- package/dist/src/services/chatRecordingService.test.js.map +1 -0
- package/dist/src/services/fileDiscoveryService.d.ts +45 -0
- package/dist/src/services/fileDiscoveryService.js +104 -0
- package/dist/src/services/fileDiscoveryService.js.map +1 -0
- package/dist/src/services/fileDiscoveryService.test.d.ts +6 -0
- package/dist/src/services/fileDiscoveryService.test.js +143 -0
- package/dist/src/services/fileDiscoveryService.test.js.map +1 -0
- package/dist/src/services/fileSystemService.d.ts +40 -0
- package/dist/src/services/fileSystemService.js +29 -0
- package/dist/src/services/fileSystemService.js.map +1 -0
- package/dist/src/services/fileSystemService.test.d.ts +6 -0
- package/dist/src/services/fileSystemService.test.js +41 -0
- package/dist/src/services/fileSystemService.test.js.map +1 -0
- package/dist/src/services/gitService.d.ts +22 -0
- package/dist/src/services/gitService.js +98 -0
- package/dist/src/services/gitService.js.map +1 -0
- package/dist/src/services/gitService.test.d.ts +6 -0
- package/dist/src/services/gitService.test.js +187 -0
- package/dist/src/services/gitService.test.js.map +1 -0
- package/dist/src/services/loopDetectionService.d.ts +103 -0
- package/dist/src/services/loopDetectionService.js +379 -0
- package/dist/src/services/loopDetectionService.js.map +1 -0
- package/dist/src/services/loopDetectionService.test.d.ts +6 -0
- package/dist/src/services/loopDetectionService.test.js +588 -0
- package/dist/src/services/loopDetectionService.test.js.map +1 -0
- package/dist/src/services/shellExecutionService.d.ts +102 -0
- package/dist/src/services/shellExecutionService.js +522 -0
- package/dist/src/services/shellExecutionService.js.map +1 -0
- package/dist/src/services/shellExecutionService.test.d.ts +6 -0
- package/dist/src/services/shellExecutionService.test.js +655 -0
- package/dist/src/services/shellExecutionService.test.js.map +1 -0
- package/dist/src/subagents/builtin-agents.d.ts +36 -0
- package/dist/src/subagents/builtin-agents.js +351 -0
- package/dist/src/subagents/builtin-agents.js.map +1 -0
- package/dist/src/subagents/builtin-agents.test.d.ts +6 -0
- package/dist/src/subagents/builtin-agents.test.js +78 -0
- package/dist/src/subagents/builtin-agents.test.js.map +1 -0
- package/dist/src/subagents/index.d.ts +29 -0
- package/dist/src/subagents/index.js +15 -0
- package/dist/src/subagents/index.js.map +1 -0
- package/dist/src/subagents/subagent-events.d.ts +95 -0
- package/dist/src/subagents/subagent-events.js +31 -0
- package/dist/src/subagents/subagent-events.js.map +1 -0
- package/dist/src/subagents/subagent-hooks.d.ts +29 -0
- package/dist/src/subagents/subagent-hooks.js +7 -0
- package/dist/src/subagents/subagent-hooks.js.map +1 -0
- package/dist/src/subagents/subagent-manager.d.ts +170 -0
- package/dist/src/subagents/subagent-manager.js +596 -0
- package/dist/src/subagents/subagent-manager.js.map +1 -0
- package/dist/src/subagents/subagent-manager.test.d.ts +6 -0
- package/dist/src/subagents/subagent-manager.test.js +822 -0
- package/dist/src/subagents/subagent-manager.test.js.map +1 -0
- package/dist/src/subagents/subagent-statistics.d.ts +46 -0
- package/dist/src/subagents/subagent-statistics.js +193 -0
- package/dist/src/subagents/subagent-statistics.js.map +1 -0
- package/dist/src/subagents/subagent-statistics.test.d.ts +6 -0
- package/dist/src/subagents/subagent-statistics.test.js +231 -0
- package/dist/src/subagents/subagent-statistics.test.js.map +1 -0
- package/dist/src/subagents/subagent.d.ts +162 -0
- package/dist/src/subagents/subagent.js +677 -0
- package/dist/src/subagents/subagent.js.map +1 -0
- package/dist/src/subagents/subagent.test.d.ts +6 -0
- package/dist/src/subagents/subagent.test.js +477 -0
- package/dist/src/subagents/subagent.test.js.map +1 -0
- package/dist/src/subagents/types.d.ts +218 -0
- package/dist/src/subagents/types.js +58 -0
- package/dist/src/subagents/types.js.map +1 -0
- package/dist/src/subagents/types.test.d.ts +6 -0
- package/dist/src/subagents/types.test.js +31 -0
- package/dist/src/subagents/types.test.js.map +1 -0
- package/dist/src/subagents/validation.d.ts +63 -0
- package/dist/src/subagents/validation.js +293 -0
- package/dist/src/subagents/validation.js.map +1 -0
- package/dist/src/subagents/validation.test.d.ts +6 -0
- package/dist/src/subagents/validation.test.js +330 -0
- package/dist/src/subagents/validation.test.js.map +1 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +137 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +915 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +18 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +594 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -0
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +115 -0
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +291 -0
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -0
- package/dist/src/telemetry/config.d.ts +31 -0
- package/dist/src/telemetry/config.js +76 -0
- package/dist/src/telemetry/config.js.map +1 -0
- package/dist/src/telemetry/config.test.d.ts +6 -0
- package/dist/src/telemetry/config.test.js +124 -0
- package/dist/src/telemetry/config.test.js.map +1 -0
- package/dist/src/telemetry/constants.d.ts +36 -0
- package/dist/src/telemetry/constants.js +38 -0
- package/dist/src/telemetry/constants.js.map +1 -0
- package/dist/src/telemetry/file-exporters.d.ts +29 -0
- package/dist/src/telemetry/file-exporters.js +62 -0
- package/dist/src/telemetry/file-exporters.js.map +1 -0
- package/dist/src/telemetry/index.d.ts +25 -0
- package/dist/src/telemetry/index.js +31 -0
- package/dist/src/telemetry/index.js.map +1 -0
- package/dist/src/telemetry/integration.test.circular.d.ts +6 -0
- package/dist/src/telemetry/integration.test.circular.js +95 -0
- package/dist/src/telemetry/integration.test.circular.js.map +1 -0
- package/dist/src/telemetry/loggers.d.ts +37 -0
- package/dist/src/telemetry/loggers.js +651 -0
- package/dist/src/telemetry/loggers.js.map +1 -0
- package/dist/src/telemetry/loggers.test.circular.d.ts +6 -0
- package/dist/src/telemetry/loggers.test.circular.js +107 -0
- package/dist/src/telemetry/loggers.test.circular.js.map +1 -0
- package/dist/src/telemetry/loggers.test.d.ts +6 -0
- package/dist/src/telemetry/loggers.test.js +978 -0
- package/dist/src/telemetry/loggers.test.js.map +1 -0
- package/dist/src/telemetry/metrics.d.ts +320 -0
- package/dist/src/telemetry/metrics.js +532 -0
- package/dist/src/telemetry/metrics.js.map +1 -0
- package/dist/src/telemetry/metrics.test.d.ts +6 -0
- package/dist/src/telemetry/metrics.test.js +744 -0
- package/dist/src/telemetry/metrics.test.js.map +1 -0
- package/dist/src/telemetry/qwen-logger/event-types.d.ts +88 -0
- package/dist/src/telemetry/qwen-logger/event-types.js +2 -0
- package/dist/src/telemetry/qwen-logger/event-types.js.map +1 -0
- package/dist/src/telemetry/qwen-logger/qwen-logger.d.ts +91 -0
- package/dist/src/telemetry/qwen-logger/qwen-logger.js +685 -0
- package/dist/src/telemetry/qwen-logger/qwen-logger.js.map +1 -0
- package/dist/src/telemetry/qwen-logger/qwen-logger.test.d.ts +6 -0
- package/dist/src/telemetry/qwen-logger/qwen-logger.test.js +317 -0
- package/dist/src/telemetry/qwen-logger/qwen-logger.test.js.map +1 -0
- package/dist/src/telemetry/sdk.d.ts +9 -0
- package/dist/src/telemetry/sdk.js +164 -0
- package/dist/src/telemetry/sdk.js.map +1 -0
- package/dist/src/telemetry/sdk.test.d.ts +6 -0
- package/dist/src/telemetry/sdk.test.js +116 -0
- package/dist/src/telemetry/sdk.test.js.map +1 -0
- package/dist/src/telemetry/telemetry-utils.d.ts +6 -0
- package/dist/src/telemetry/telemetry-utils.js +14 -0
- package/dist/src/telemetry/telemetry-utils.js.map +1 -0
- package/dist/src/telemetry/telemetry-utils.test.d.ts +6 -0
- package/dist/src/telemetry/telemetry-utils.test.js +40 -0
- package/dist/src/telemetry/telemetry-utils.test.js.map +1 -0
- package/dist/src/telemetry/telemetry.test.d.ts +6 -0
- package/dist/src/telemetry/telemetry.test.js +50 -0
- package/dist/src/telemetry/telemetry.test.js.map +1 -0
- package/dist/src/telemetry/tool-call-decision.d.ts +13 -0
- package/dist/src/telemetry/tool-call-decision.js +29 -0
- package/dist/src/telemetry/tool-call-decision.js.map +1 -0
- package/dist/src/telemetry/types.d.ts +327 -0
- package/dist/src/telemetry/types.js +558 -0
- package/dist/src/telemetry/types.js.map +1 -0
- package/dist/src/telemetry/uiTelemetry.d.ts +75 -0
- package/dist/src/telemetry/uiTelemetry.js +152 -0
- package/dist/src/telemetry/uiTelemetry.js.map +1 -0
- package/dist/src/telemetry/uiTelemetry.test.d.ts +6 -0
- package/dist/src/telemetry/uiTelemetry.test.js +625 -0
- package/dist/src/telemetry/uiTelemetry.test.js.map +1 -0
- package/dist/src/test-utils/config.d.ts +17 -0
- package/dist/src/test-utils/config.js +32 -0
- package/dist/src/test-utils/config.js.map +1 -0
- package/dist/src/test-utils/index.d.ts +6 -0
- package/dist/src/test-utils/index.js +7 -0
- package/dist/src/test-utils/index.js.map +1 -0
- package/dist/src/test-utils/mock-tool.d.ts +66 -0
- package/dist/src/test-utils/mock-tool.js +121 -0
- package/dist/src/test-utils/mock-tool.js.map +1 -0
- package/dist/src/test-utils/mockWorkspaceContext.d.ts +13 -0
- package/dist/src/test-utils/mockWorkspaceContext.js +24 -0
- package/dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
- package/dist/src/tools/diffOptions.d.ts +9 -0
- package/dist/src/tools/diffOptions.js +46 -0
- package/dist/src/tools/diffOptions.js.map +1 -0
- package/dist/src/tools/diffOptions.test.d.ts +6 -0
- package/dist/src/tools/diffOptions.test.js +155 -0
- package/dist/src/tools/diffOptions.test.js.map +1 -0
- package/dist/src/tools/edit.d.ts +55 -0
- package/dist/src/tools/edit.js +421 -0
- package/dist/src/tools/edit.js.map +1 -0
- package/dist/src/tools/edit.test.d.ts +6 -0
- package/dist/src/tools/edit.test.js +684 -0
- package/dist/src/tools/edit.test.js.map +1 -0
- package/dist/src/tools/exitPlanMode.d.ts +28 -0
- package/dist/src/tools/exitPlanMode.js +132 -0
- package/dist/src/tools/exitPlanMode.js.map +1 -0
- package/dist/src/tools/exitPlanMode.test.d.ts +6 -0
- package/dist/src/tools/exitPlanMode.test.js +178 -0
- package/dist/src/tools/exitPlanMode.test.js.map +1 -0
- package/dist/src/tools/glob.d.ts +44 -0
- package/dist/src/tools/glob.js +190 -0
- package/dist/src/tools/glob.js.map +1 -0
- package/dist/src/tools/glob.test.d.ts +6 -0
- package/dist/src/tools/glob.test.js +442 -0
- package/dist/src/tools/glob.test.js.map +1 -0
- package/dist/src/tools/grep.d.ts +44 -0
- package/dist/src/tools/grep.js +425 -0
- package/dist/src/tools/grep.js.map +1 -0
- package/dist/src/tools/grep.test.d.ts +6 -0
- package/dist/src/tools/grep.test.js +360 -0
- package/dist/src/tools/grep.test.js.map +1 -0
- package/dist/src/tools/ls.d.ts +68 -0
- package/dist/src/tools/ls.js +215 -0
- package/dist/src/tools/ls.js.map +1 -0
- package/dist/src/tools/ls.test.d.ts +6 -0
- package/dist/src/tools/ls.test.js +249 -0
- package/dist/src/tools/ls.test.js.map +1 -0
- package/dist/src/tools/mcp-client-manager.d.ts +40 -0
- package/dist/src/tools/mcp-client-manager.js +83 -0
- package/dist/src/tools/mcp-client-manager.js.map +1 -0
- package/dist/src/tools/mcp-client-manager.test.d.ts +6 -0
- package/dist/src/tools/mcp-client-manager.test.js +58 -0
- package/dist/src/tools/mcp-client-manager.test.js.map +1 -0
- package/dist/src/tools/mcp-client.d.ts +189 -0
- package/dist/src/tools/mcp-client.js +957 -0
- package/dist/src/tools/mcp-client.js.map +1 -0
- package/dist/src/tools/mcp-client.test.d.ts +6 -0
- package/dist/src/tools/mcp-client.test.js +309 -0
- package/dist/src/tools/mcp-client.test.js.map +1 -0
- package/dist/src/tools/mcp-tool.d.ts +24 -0
- package/dist/src/tools/mcp-tool.js +268 -0
- package/dist/src/tools/mcp-tool.js.map +1 -0
- package/dist/src/tools/mcp-tool.test.d.ts +6 -0
- package/dist/src/tools/mcp-tool.test.js +714 -0
- package/dist/src/tools/mcp-tool.test.js.map +1 -0
- package/dist/src/tools/memoryTool.d.ts +42 -0
- package/dist/src/tools/memoryTool.js +397 -0
- package/dist/src/tools/memoryTool.js.map +1 -0
- package/dist/src/tools/memoryTool.test.d.ts +6 -0
- package/dist/src/tools/memoryTool.test.js +419 -0
- package/dist/src/tools/memoryTool.test.js.map +1 -0
- package/dist/src/tools/modifiable-tool.d.ts +32 -0
- package/dist/src/tools/modifiable-tool.js +88 -0
- package/dist/src/tools/modifiable-tool.js.map +1 -0
- package/dist/src/tools/modifiable-tool.test.d.ts +6 -0
- package/dist/src/tools/modifiable-tool.test.js +193 -0
- package/dist/src/tools/modifiable-tool.test.js.map +1 -0
- package/dist/src/tools/read-file.d.ts +35 -0
- package/dist/src/tools/read-file.js +124 -0
- package/dist/src/tools/read-file.js.map +1 -0
- package/dist/src/tools/read-file.test.d.ts +6 -0
- package/dist/src/tools/read-file.test.js +339 -0
- package/dist/src/tools/read-file.test.js.map +1 -0
- package/dist/src/tools/read-many-files.d.ts +60 -0
- package/dist/src/tools/read-many-files.js +391 -0
- package/dist/src/tools/read-many-files.js.map +1 -0
- package/dist/src/tools/read-many-files.test.d.ts +6 -0
- package/dist/src/tools/read-many-files.test.js +566 -0
- package/dist/src/tools/read-many-files.test.js.map +1 -0
- package/dist/src/tools/ripGrep.d.ts +44 -0
- package/dist/src/tools/ripGrep.js +233 -0
- package/dist/src/tools/ripGrep.js.map +1 -0
- package/dist/src/tools/ripGrep.test.d.ts +6 -0
- package/dist/src/tools/ripGrep.test.js +529 -0
- package/dist/src/tools/ripGrep.test.js.map +1 -0
- package/dist/src/tools/shell.d.ts +33 -0
- package/dist/src/tools/shell.js +395 -0
- package/dist/src/tools/shell.js.map +1 -0
- package/dist/src/tools/shell.test.d.ts +6 -0
- package/dist/src/tools/shell.test.js +566 -0
- package/dist/src/tools/shell.test.js.map +1 -0
- package/dist/src/tools/smart-edit.d.ts +91 -0
- package/dist/src/tools/smart-edit.js +703 -0
- package/dist/src/tools/smart-edit.js.map +1 -0
- package/dist/src/tools/smart-edit.test.d.ts +6 -0
- package/dist/src/tools/smart-edit.test.js +542 -0
- package/dist/src/tools/smart-edit.test.js.map +1 -0
- package/dist/src/tools/task.d.ts +59 -0
- package/dist/src/tools/task.js +412 -0
- package/dist/src/tools/task.js.map +1 -0
- package/dist/src/tools/task.test.d.ts +6 -0
- package/dist/src/tools/task.test.js +369 -0
- package/dist/src/tools/task.test.js.map +1 -0
- package/dist/src/tools/todoWrite.d.ts +42 -0
- package/dist/src/tools/todoWrite.js +407 -0
- package/dist/src/tools/todoWrite.js.map +1 -0
- package/dist/src/tools/todoWrite.test.d.ts +6 -0
- package/dist/src/tools/todoWrite.test.js +234 -0
- package/dist/src/tools/todoWrite.test.js.map +1 -0
- package/dist/src/tools/tool-error.d.ts +45 -0
- package/dist/src/tools/tool-error.js +61 -0
- package/dist/src/tools/tool-error.js.map +1 -0
- package/dist/src/tools/tool-names.d.ts +56 -0
- package/dist/src/tools/tool-names.js +62 -0
- package/dist/src/tools/tool-names.js.map +1 -0
- package/dist/src/tools/tool-registry.d.ts +87 -0
- package/dist/src/tools/tool-registry.js +370 -0
- package/dist/src/tools/tool-registry.js.map +1 -0
- package/dist/src/tools/tool-registry.test.d.ts +6 -0
- package/dist/src/tools/tool-registry.test.js +332 -0
- package/dist/src/tools/tool-registry.test.js.map +1 -0
- package/dist/src/tools/tools.d.ts +327 -0
- package/dist/src/tools/tools.js +258 -0
- package/dist/src/tools/tools.js.map +1 -0
- package/dist/src/tools/tools.test.d.ts +6 -0
- package/dist/src/tools/tools.test.js +205 -0
- package/dist/src/tools/tools.test.js.map +1 -0
- package/dist/src/tools/web-fetch.d.ts +31 -0
- package/dist/src/tools/web-fetch.js +163 -0
- package/dist/src/tools/web-fetch.js.map +1 -0
- package/dist/src/tools/web-fetch.test.d.ts +6 -0
- package/dist/src/tools/web-fetch.test.js +133 -0
- package/dist/src/tools/web-fetch.test.js.map +1 -0
- package/dist/src/tools/web-search/base-provider.d.ts +31 -0
- package/dist/src/tools/web-search/base-provider.js +34 -0
- package/dist/src/tools/web-search/base-provider.js.map +1 -0
- package/dist/src/tools/web-search/index.d.ts +24 -0
- package/dist/src/tools/web-search/index.js +245 -0
- package/dist/src/tools/web-search/index.js.map +1 -0
- package/dist/src/tools/web-search/index.test.d.ts +6 -0
- package/dist/src/tools/web-search/index.test.js +237 -0
- package/dist/src/tools/web-search/index.test.js.map +1 -0
- package/dist/src/tools/web-search/providers/dashscope-provider.d.ts +23 -0
- package/dist/src/tools/web-search/providers/dashscope-provider.js +120 -0
- package/dist/src/tools/web-search/providers/dashscope-provider.js.map +1 -0
- package/dist/src/tools/web-search/providers/google-provider.d.ts +17 -0
- package/dist/src/tools/web-search/providers/google-provider.js +55 -0
- package/dist/src/tools/web-search/providers/google-provider.js.map +1 -0
- package/dist/src/tools/web-search/providers/tavily-provider.d.ts +17 -0
- package/dist/src/tools/web-search/providers/tavily-provider.js +54 -0
- package/dist/src/tools/web-search/providers/tavily-provider.js.map +1 -0
- package/dist/src/tools/web-search/types.d.ts +138 -0
- package/dist/src/tools/web-search/types.js +7 -0
- package/dist/src/tools/web-search/types.js.map +1 -0
- package/dist/src/tools/web-search/utils.d.ts +28 -0
- package/dist/src/tools/web-search/utils.js +35 -0
- package/dist/src/tools/web-search/utils.js.map +1 -0
- package/dist/src/tools/write-file.d.ts +52 -0
- package/dist/src/tools/write-file.js +293 -0
- package/dist/src/tools/write-file.js.map +1 -0
- package/dist/src/tools/write-file.test.d.ts +6 -0
- package/dist/src/tools/write-file.test.js +516 -0
- package/dist/src/tools/write-file.test.js.map +1 -0
- package/dist/src/utils/LruCache.d.ts +13 -0
- package/dist/src/utils/LruCache.js +38 -0
- package/dist/src/utils/LruCache.js.map +1 -0
- package/dist/src/utils/bfsFileSearch.d.ts +24 -0
- package/dist/src/utils/bfsFileSearch.js +95 -0
- package/dist/src/utils/bfsFileSearch.js.map +1 -0
- package/dist/src/utils/bfsFileSearch.test.d.ts +6 -0
- package/dist/src/utils/bfsFileSearch.test.js +163 -0
- package/dist/src/utils/bfsFileSearch.test.js.map +1 -0
- package/dist/src/utils/browser.d.ts +13 -0
- package/dist/src/utils/browser.js +50 -0
- package/dist/src/utils/browser.js.map +1 -0
- package/dist/src/utils/editHelper.d.ts +53 -0
- package/dist/src/utils/editHelper.js +359 -0
- package/dist/src/utils/editHelper.js.map +1 -0
- package/dist/src/utils/editHelper.test.d.ts +6 -0
- package/dist/src/utils/editHelper.test.js +93 -0
- package/dist/src/utils/editHelper.test.js.map +1 -0
- package/dist/src/utils/editor.d.ts +28 -0
- package/dist/src/utils/editor.js +177 -0
- package/dist/src/utils/editor.js.map +1 -0
- package/dist/src/utils/editor.test.d.ts +6 -0
- package/dist/src/utils/editor.test.js +437 -0
- package/dist/src/utils/editor.test.js.map +1 -0
- package/dist/src/utils/environmentContext.d.ts +22 -0
- package/dist/src/utils/environmentContext.js +108 -0
- package/dist/src/utils/environmentContext.js.map +1 -0
- package/dist/src/utils/environmentContext.test.d.ts +6 -0
- package/dist/src/utils/environmentContext.test.js +219 -0
- package/dist/src/utils/environmentContext.test.js.map +1 -0
- package/dist/src/utils/errorParsing.d.ts +8 -0
- package/dist/src/utils/errorParsing.js +93 -0
- package/dist/src/utils/errorParsing.js.map +1 -0
- package/dist/src/utils/errorParsing.test.d.ts +6 -0
- package/dist/src/utils/errorParsing.test.js +172 -0
- package/dist/src/utils/errorParsing.test.js.map +1 -0
- package/dist/src/utils/errorReporting.d.ts +14 -0
- package/dist/src/utils/errorReporting.js +88 -0
- package/dist/src/utils/errorReporting.js.map +1 -0
- package/dist/src/utils/errorReporting.test.d.ts +6 -0
- package/dist/src/utils/errorReporting.test.js +130 -0
- package/dist/src/utils/errorReporting.test.js.map +1 -0
- package/dist/src/utils/errors.d.ts +39 -0
- package/dist/src/utils/errors.js +96 -0
- package/dist/src/utils/errors.js.map +1 -0
- package/dist/src/utils/fetch.d.ts +11 -0
- package/dist/src/utils/fetch.js +51 -0
- package/dist/src/utils/fetch.js.map +1 -0
- package/dist/src/utils/fileUtils.d.ts +69 -0
- package/dist/src/utils/fileUtils.js +426 -0
- package/dist/src/utils/fileUtils.js.map +1 -0
- package/dist/src/utils/fileUtils.test.d.ts +6 -0
- package/dist/src/utils/fileUtils.test.js +685 -0
- package/dist/src/utils/fileUtils.test.js.map +1 -0
- package/dist/src/utils/filesearch/crawlCache.d.ts +25 -0
- package/dist/src/utils/filesearch/crawlCache.js +57 -0
- package/dist/src/utils/filesearch/crawlCache.js.map +1 -0
- package/dist/src/utils/filesearch/crawlCache.test.d.ts +6 -0
- package/dist/src/utils/filesearch/crawlCache.test.js +103 -0
- package/dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
- package/dist/src/utils/filesearch/crawler.d.ts +15 -0
- package/dist/src/utils/filesearch/crawler.js +50 -0
- package/dist/src/utils/filesearch/crawler.js.map +1 -0
- package/dist/src/utils/filesearch/crawler.test.d.ts +6 -0
- package/dist/src/utils/filesearch/crawler.test.js +468 -0
- package/dist/src/utils/filesearch/crawler.test.js.map +1 -0
- package/dist/src/utils/filesearch/fileSearch.d.ts +38 -0
- package/dist/src/utils/filesearch/fileSearch.js +191 -0
- package/dist/src/utils/filesearch/fileSearch.js.map +1 -0
- package/dist/src/utils/filesearch/fileSearch.test.d.ts +6 -0
- package/dist/src/utils/filesearch/fileSearch.test.js +642 -0
- package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
- package/dist/src/utils/filesearch/ignore.d.ts +42 -0
- package/dist/src/utils/filesearch/ignore.js +106 -0
- package/dist/src/utils/filesearch/ignore.js.map +1 -0
- package/dist/src/utils/filesearch/ignore.test.d.ts +6 -0
- package/dist/src/utils/filesearch/ignore.test.js +144 -0
- package/dist/src/utils/filesearch/ignore.test.js.map +1 -0
- package/dist/src/utils/filesearch/result-cache.d.ts +33 -0
- package/dist/src/utils/filesearch/result-cache.js +59 -0
- package/dist/src/utils/filesearch/result-cache.js.map +1 -0
- package/dist/src/utils/filesearch/result-cache.test.d.ts +6 -0
- package/dist/src/utils/filesearch/result-cache.test.js +46 -0
- package/dist/src/utils/filesearch/result-cache.test.js.map +1 -0
- package/dist/src/utils/flashFallback.test.d.ts +6 -0
- package/dist/src/utils/flashFallback.test.js +122 -0
- package/dist/src/utils/flashFallback.test.js.map +1 -0
- package/dist/src/utils/formatters.d.ts +6 -0
- package/dist/src/utils/formatters.js +16 -0
- package/dist/src/utils/formatters.js.map +1 -0
- package/dist/src/utils/generateContentResponseUtilities.d.ts +13 -0
- package/dist/src/utils/generateContentResponseUtilities.js +80 -0
- package/dist/src/utils/generateContentResponseUtilities.js.map +1 -0
- package/dist/src/utils/generateContentResponseUtilities.test.d.ts +6 -0
- package/dist/src/utils/generateContentResponseUtilities.test.js +235 -0
- package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
- package/dist/src/utils/getFolderStructure.d.ts +31 -0
- package/dist/src/utils/getFolderStructure.js +246 -0
- package/dist/src/utils/getFolderStructure.js.map +1 -0
- package/dist/src/utils/getFolderStructure.test.d.ts +6 -0
- package/dist/src/utils/getFolderStructure.test.js +282 -0
- package/dist/src/utils/getFolderStructure.test.js.map +1 -0
- package/dist/src/utils/getPty.d.ts +19 -0
- package/dist/src/utils/getPty.js +23 -0
- package/dist/src/utils/getPty.js.map +1 -0
- package/dist/src/utils/gitIgnoreParser.d.ts +16 -0
- package/dist/src/utils/gitIgnoreParser.js +152 -0
- package/dist/src/utils/gitIgnoreParser.js.map +1 -0
- package/dist/src/utils/gitIgnoreParser.test.d.ts +6 -0
- package/dist/src/utils/gitIgnoreParser.test.js +185 -0
- package/dist/src/utils/gitIgnoreParser.test.js.map +1 -0
- package/dist/src/utils/gitUtils.d.ts +17 -0
- package/dist/src/utils/gitUtils.js +61 -0
- package/dist/src/utils/gitUtils.js.map +1 -0
- package/dist/src/utils/ignorePatterns.d.ts +103 -0
- package/dist/src/utils/ignorePatterns.js +220 -0
- package/dist/src/utils/ignorePatterns.js.map +1 -0
- package/dist/src/utils/ignorePatterns.test.d.ts +6 -0
- package/dist/src/utils/ignorePatterns.test.js +250 -0
- package/dist/src/utils/ignorePatterns.test.js.map +1 -0
- package/dist/src/utils/installationManager.d.ts +16 -0
- package/dist/src/utils/installationManager.js +50 -0
- package/dist/src/utils/installationManager.js.map +1 -0
- package/dist/src/utils/installationManager.test.d.ts +6 -0
- package/dist/src/utils/installationManager.test.js +83 -0
- package/dist/src/utils/installationManager.test.js.map +1 -0
- package/dist/src/utils/language-detection.d.ts +6 -0
- package/dist/src/utils/language-detection.js +101 -0
- package/dist/src/utils/language-detection.js.map +1 -0
- package/dist/src/utils/llm-edit-fixer.d.ts +26 -0
- package/dist/src/utils/llm-edit-fixer.js +131 -0
- package/dist/src/utils/llm-edit-fixer.js.map +1 -0
- package/dist/src/utils/llm-edit-fixer.test.d.ts +6 -0
- package/dist/src/utils/llm-edit-fixer.test.js +186 -0
- package/dist/src/utils/llm-edit-fixer.test.js.map +1 -0
- package/dist/src/utils/memoryDiscovery.d.ts +16 -0
- package/dist/src/utils/memoryDiscovery.js +272 -0
- package/dist/src/utils/memoryDiscovery.js.map +1 -0
- package/dist/src/utils/memoryDiscovery.test.d.ts +6 -0
- package/dist/src/utils/memoryDiscovery.test.js +244 -0
- package/dist/src/utils/memoryDiscovery.test.js.map +1 -0
- package/dist/src/utils/memoryImportProcessor.d.ts +42 -0
- package/dist/src/utils/memoryImportProcessor.js +284 -0
- package/dist/src/utils/memoryImportProcessor.js.map +1 -0
- package/dist/src/utils/memoryImportProcessor.test.d.ts +6 -0
- package/dist/src/utils/memoryImportProcessor.test.js +587 -0
- package/dist/src/utils/memoryImportProcessor.test.js.map +1 -0
- package/dist/src/utils/messageInspectors.d.ts +8 -0
- package/dist/src/utils/messageInspectors.js +16 -0
- package/dist/src/utils/messageInspectors.js.map +1 -0
- package/dist/src/utils/nextSpeakerChecker.d.ts +12 -0
- package/dist/src/utils/nextSpeakerChecker.js +97 -0
- package/dist/src/utils/nextSpeakerChecker.js.map +1 -0
- package/dist/src/utils/nextSpeakerChecker.test.d.ts +6 -0
- package/dist/src/utils/nextSpeakerChecker.test.js +181 -0
- package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
- package/dist/src/utils/openaiLogger.d.ts +42 -0
- package/dist/src/utils/openaiLogger.js +138 -0
- package/dist/src/utils/openaiLogger.js.map +1 -0
- package/dist/src/utils/openaiLogger.test.d.ts +6 -0
- package/dist/src/utils/openaiLogger.test.js +304 -0
- package/dist/src/utils/openaiLogger.test.js.map +1 -0
- package/dist/src/utils/partUtils.d.ts +35 -0
- package/dist/src/utils/partUtils.js +133 -0
- package/dist/src/utils/partUtils.js.map +1 -0
- package/dist/src/utils/partUtils.test.d.ts +6 -0
- package/dist/src/utils/partUtils.test.js +241 -0
- package/dist/src/utils/partUtils.test.js.map +1 -0
- package/dist/src/utils/pathReader.d.ts +17 -0
- package/dist/src/utils/pathReader.js +92 -0
- package/dist/src/utils/pathReader.js.map +1 -0
- package/dist/src/utils/pathReader.test.d.ts +6 -0
- package/dist/src/utils/pathReader.test.js +365 -0
- package/dist/src/utils/pathReader.test.js.map +1 -0
- package/dist/src/utils/paths.d.ts +94 -0
- package/dist/src/utils/paths.js +231 -0
- package/dist/src/utils/paths.js.map +1 -0
- package/dist/src/utils/paths.test.d.ts +6 -0
- package/dist/src/utils/paths.test.js +438 -0
- package/dist/src/utils/paths.test.js.map +1 -0
- package/dist/src/utils/projectSummary.d.ts +22 -0
- package/dist/src/utils/projectSummary.js +86 -0
- package/dist/src/utils/projectSummary.js.map +1 -0
- package/dist/src/utils/promptIdContext.d.ts +7 -0
- package/dist/src/utils/promptIdContext.js +8 -0
- package/dist/src/utils/promptIdContext.js.map +1 -0
- package/dist/src/utils/quotaErrorDetection.d.ts +20 -0
- package/dist/src/utils/quotaErrorDetection.js +114 -0
- package/dist/src/utils/quotaErrorDetection.js.map +1 -0
- package/dist/src/utils/quotaErrorDetection.test.d.ts +6 -0
- package/dist/src/utils/quotaErrorDetection.test.js +153 -0
- package/dist/src/utils/quotaErrorDetection.test.js.map +1 -0
- package/dist/src/utils/qwenIgnoreParser.d.ts +18 -0
- package/dist/src/utils/qwenIgnoreParser.js +61 -0
- package/dist/src/utils/qwenIgnoreParser.js.map +1 -0
- package/dist/src/utils/qwenIgnoreParser.test.d.ts +6 -0
- package/dist/src/utils/qwenIgnoreParser.test.js +50 -0
- package/dist/src/utils/qwenIgnoreParser.test.js.map +1 -0
- package/dist/src/utils/request-tokenizer/imageTokenizer.d.ts +112 -0
- package/dist/src/utils/request-tokenizer/imageTokenizer.js +401 -0
- package/dist/src/utils/request-tokenizer/imageTokenizer.js.map +1 -0
- package/dist/src/utils/request-tokenizer/imageTokenizer.test.d.ts +6 -0
- package/dist/src/utils/request-tokenizer/imageTokenizer.test.js +114 -0
- package/dist/src/utils/request-tokenizer/imageTokenizer.test.js.map +1 -0
- package/dist/src/utils/request-tokenizer/index.d.ts +18 -0
- package/dist/src/utils/request-tokenizer/index.js +30 -0
- package/dist/src/utils/request-tokenizer/index.js.map +1 -0
- package/dist/src/utils/request-tokenizer/requestTokenizer.d.ts +56 -0
- package/dist/src/utils/request-tokenizer/requestTokenizer.js +263 -0
- package/dist/src/utils/request-tokenizer/requestTokenizer.js.map +1 -0
- package/dist/src/utils/request-tokenizer/requestTokenizer.test.d.ts +6 -0
- package/dist/src/utils/request-tokenizer/requestTokenizer.test.js +245 -0
- package/dist/src/utils/request-tokenizer/requestTokenizer.test.js.map +1 -0
- package/dist/src/utils/request-tokenizer/supportedImageFormats.d.ts +30 -0
- package/dist/src/utils/request-tokenizer/supportedImageFormats.js +41 -0
- package/dist/src/utils/request-tokenizer/supportedImageFormats.js.map +1 -0
- package/dist/src/utils/request-tokenizer/textTokenizer.d.ts +29 -0
- package/dist/src/utils/request-tokenizer/textTokenizer.js +88 -0
- package/dist/src/utils/request-tokenizer/textTokenizer.js.map +1 -0
- package/dist/src/utils/request-tokenizer/textTokenizer.test.d.ts +6 -0
- package/dist/src/utils/request-tokenizer/textTokenizer.test.js +253 -0
- package/dist/src/utils/request-tokenizer/textTokenizer.test.js.map +1 -0
- package/dist/src/utils/request-tokenizer/types.d.ts +55 -0
- package/dist/src/utils/request-tokenizer/types.js +7 -0
- package/dist/src/utils/request-tokenizer/types.js.map +1 -0
- package/dist/src/utils/retry.d.ts +32 -0
- package/dist/src/utils/retry.js +303 -0
- package/dist/src/utils/retry.js.map +1 -0
- package/dist/src/utils/retry.test.d.ts +6 -0
- package/dist/src/utils/retry.test.js +474 -0
- package/dist/src/utils/retry.test.js.map +1 -0
- package/dist/src/utils/ripgrepUtils.d.ts +62 -0
- package/dist/src/utils/ripgrepUtils.js +262 -0
- package/dist/src/utils/ripgrepUtils.js.map +1 -0
- package/dist/src/utils/ripgrepUtils.test.d.ts +6 -0
- package/dist/src/utils/ripgrepUtils.test.js +101 -0
- package/dist/src/utils/ripgrepUtils.test.js.map +1 -0
- package/dist/src/utils/safeJsonParse.d.ts +15 -0
- package/dist/src/utils/safeJsonParse.js +41 -0
- package/dist/src/utils/safeJsonParse.js.map +1 -0
- package/dist/src/utils/safeJsonParse.test.d.ts +6 -0
- package/dist/src/utils/safeJsonParse.test.js +112 -0
- package/dist/src/utils/safeJsonParse.test.js.map +1 -0
- package/dist/src/utils/safeJsonStringify.d.ts +13 -0
- package/dist/src/utils/safeJsonStringify.js +25 -0
- package/dist/src/utils/safeJsonStringify.js.map +1 -0
- package/dist/src/utils/safeJsonStringify.test.d.ts +6 -0
- package/dist/src/utils/safeJsonStringify.test.js +61 -0
- package/dist/src/utils/safeJsonStringify.test.js.map +1 -0
- package/dist/src/utils/schemaValidator.d.ts +15 -0
- package/dist/src/utils/schemaValidator.js +67 -0
- package/dist/src/utils/schemaValidator.js.map +1 -0
- package/dist/src/utils/schemaValidator.test.d.ts +6 -0
- package/dist/src/utils/schemaValidator.test.js +113 -0
- package/dist/src/utils/schemaValidator.test.js.map +1 -0
- package/dist/src/utils/secure-browser-launcher.d.ts +23 -0
- package/dist/src/utils/secure-browser-launcher.js +165 -0
- package/dist/src/utils/secure-browser-launcher.js.map +1 -0
- package/dist/src/utils/secure-browser-launcher.test.d.ts +6 -0
- package/dist/src/utils/secure-browser-launcher.test.js +149 -0
- package/dist/src/utils/secure-browser-launcher.test.js.map +1 -0
- package/dist/src/utils/session.d.ts +6 -0
- package/dist/src/utils/session.js +8 -0
- package/dist/src/utils/session.js.map +1 -0
- package/dist/src/utils/shell-utils.d.ts +152 -0
- package/dist/src/utils/shell-utils.js +467 -0
- package/dist/src/utils/shell-utils.js.map +1 -0
- package/dist/src/utils/shell-utils.test.d.ts +6 -0
- package/dist/src/utils/shell-utils.test.js +351 -0
- package/dist/src/utils/shell-utils.test.js.map +1 -0
- package/dist/src/utils/shellReadOnlyChecker.d.ts +6 -0
- package/dist/src/utils/shellReadOnlyChecker.js +247 -0
- package/dist/src/utils/shellReadOnlyChecker.js.map +1 -0
- package/dist/src/utils/shellReadOnlyChecker.test.d.ts +6 -0
- package/dist/src/utils/shellReadOnlyChecker.test.js +47 -0
- package/dist/src/utils/shellReadOnlyChecker.test.js.map +1 -0
- package/dist/src/utils/subagentGenerator.d.ts +20 -0
- package/dist/src/utils/subagentGenerator.js +120 -0
- package/dist/src/utils/subagentGenerator.js.map +1 -0
- package/dist/src/utils/subagentGenerator.test.d.ts +6 -0
- package/dist/src/utils/subagentGenerator.test.js +135 -0
- package/dist/src/utils/subagentGenerator.test.js.map +1 -0
- package/dist/src/utils/summarizer.d.ts +25 -0
- package/dist/src/utils/summarizer.js +51 -0
- package/dist/src/utils/summarizer.js.map +1 -0
- package/dist/src/utils/summarizer.test.d.ts +6 -0
- package/dist/src/utils/summarizer.test.js +131 -0
- package/dist/src/utils/summarizer.test.js.map +1 -0
- package/dist/src/utils/systemEncoding.d.ts +40 -0
- package/dist/src/utils/systemEncoding.js +149 -0
- package/dist/src/utils/systemEncoding.js.map +1 -0
- package/dist/src/utils/systemEncoding.test.d.ts +6 -0
- package/dist/src/utils/systemEncoding.test.js +368 -0
- package/dist/src/utils/systemEncoding.test.js.map +1 -0
- package/dist/src/utils/terminalSerializer.d.ts +25 -0
- package/dist/src/utils/terminalSerializer.js +432 -0
- package/dist/src/utils/terminalSerializer.js.map +1 -0
- package/dist/src/utils/terminalSerializer.test.d.ts +6 -0
- package/dist/src/utils/terminalSerializer.test.js +176 -0
- package/dist/src/utils/terminalSerializer.test.js.map +1 -0
- package/dist/src/utils/testUtils.d.ts +29 -0
- package/dist/src/utils/testUtils.js +70 -0
- package/dist/src/utils/testUtils.js.map +1 -0
- package/dist/src/utils/textUtils.d.ts +18 -0
- package/dist/src/utils/textUtils.js +42 -0
- package/dist/src/utils/textUtils.js.map +1 -0
- package/dist/src/utils/textUtils.test.d.ts +6 -0
- package/dist/src/utils/textUtils.test.js +59 -0
- package/dist/src/utils/textUtils.test.js.map +1 -0
- package/dist/src/utils/thoughtUtils.d.ts +21 -0
- package/dist/src/utils/thoughtUtils.js +39 -0
- package/dist/src/utils/thoughtUtils.js.map +1 -0
- package/dist/src/utils/thoughtUtils.test.d.ts +6 -0
- package/dist/src/utils/thoughtUtils.test.js +78 -0
- package/dist/src/utils/thoughtUtils.test.js.map +1 -0
- package/dist/src/utils/tool-utils.d.ts +22 -0
- package/dist/src/utils/tool-utils.js +121 -0
- package/dist/src/utils/tool-utils.js.map +1 -0
- package/dist/src/utils/tool-utils.test.d.ts +6 -0
- package/dist/src/utils/tool-utils.test.js +100 -0
- package/dist/src/utils/tool-utils.test.js.map +1 -0
- package/dist/src/utils/userAccountManager.d.ts +20 -0
- package/dist/src/utils/userAccountManager.js +114 -0
- package/dist/src/utils/userAccountManager.js.map +1 -0
- package/dist/src/utils/userAccountManager.test.d.ts +6 -0
- package/dist/src/utils/userAccountManager.test.js +223 -0
- package/dist/src/utils/userAccountManager.test.js.map +1 -0
- package/dist/src/utils/workspaceContext.d.ts +66 -0
- package/dist/src/utils/workspaceContext.js +171 -0
- package/dist/src/utils/workspaceContext.js.map +1 -0
- package/dist/src/utils/workspaceContext.test.d.ts +6 -0
- package/dist/src/utils/workspaceContext.test.js +318 -0
- package/dist/src/utils/workspaceContext.test.js.map +1 -0
- package/dist/src/utils/yaml-parser.d.ts +29 -0
- package/dist/src/utils/yaml-parser.js +172 -0
- package/dist/src/utils/yaml-parser.js.map +1 -0
- package/dist/src/utils/yaml-parser.test.d.ts +6 -0
- package/dist/src/utils/yaml-parser.test.js +170 -0
- package/dist/src/utils/yaml-parser.test.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +93 -0
- package/scripts/postinstall.js +100 -0
- package/vendor/ripgrep/COPYING +3 -0
- package/vendor/ripgrep/arm64-darwin/rg +0 -0
- package/vendor/ripgrep/arm64-linux/rg +0 -0
- package/vendor/ripgrep/x64-darwin/rg +0 -0
- package/vendor/ripgrep/x64-linux/rg +0 -0
- package/vendor/ripgrep/x64-win32/rg.exe +0 -0
|
@@ -0,0 +1,1178 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 OSA
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
7
|
+
import {} from './qwenOAuth2.js';
|
|
8
|
+
import { FinishReason } from '@google/genai';
|
|
9
|
+
import { OSAContentGenerator } from './qwenContentGenerator.js';
|
|
10
|
+
import { SharedTokenManager } from './sharedTokenManager.js';
|
|
11
|
+
import { AuthType } from '../core/contentGenerator.js';
|
|
12
|
+
// Mock OpenAI client to avoid real network calls
|
|
13
|
+
vi.mock('openai', () => ({
|
|
14
|
+
default: class MockOpenAI {
|
|
15
|
+
chat = {
|
|
16
|
+
completions: {
|
|
17
|
+
create: vi.fn(),
|
|
18
|
+
},
|
|
19
|
+
};
|
|
20
|
+
embeddings = {
|
|
21
|
+
create: vi.fn(),
|
|
22
|
+
};
|
|
23
|
+
apiKey = '';
|
|
24
|
+
baseURL = '';
|
|
25
|
+
constructor(config) {
|
|
26
|
+
this.apiKey = config.apiKey;
|
|
27
|
+
this.baseURL = config.baseURL;
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
}));
|
|
31
|
+
// Mock DashScope provider
|
|
32
|
+
vi.mock('../core/openaiContentGenerator/provider/dashscope.js', () => ({
|
|
33
|
+
DashScopeOpenAICompatibleProvider: class {
|
|
34
|
+
constructor(_config, _cliConfig) { }
|
|
35
|
+
},
|
|
36
|
+
}));
|
|
37
|
+
// Mock ContentGenerationPipeline
|
|
38
|
+
vi.mock('../core/openaiContentGenerator/pipeline.js', () => ({
|
|
39
|
+
ContentGenerationPipeline: class {
|
|
40
|
+
client;
|
|
41
|
+
constructor(_config) {
|
|
42
|
+
this.client = {
|
|
43
|
+
apiKey: '',
|
|
44
|
+
baseURL: '',
|
|
45
|
+
chat: {
|
|
46
|
+
completions: {
|
|
47
|
+
create: vi.fn(),
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
embeddings: {
|
|
51
|
+
create: vi.fn(),
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
async execute(_request, _userPromptId) {
|
|
56
|
+
return createMockResponse('Test response');
|
|
57
|
+
}
|
|
58
|
+
async executeStream(_request, _userPromptId) {
|
|
59
|
+
return (async function* () {
|
|
60
|
+
yield createMockResponse('Stream chunk 1');
|
|
61
|
+
yield createMockResponse('Stream chunk 2');
|
|
62
|
+
})();
|
|
63
|
+
}
|
|
64
|
+
async countTokens(_request) {
|
|
65
|
+
return { totalTokens: 15 };
|
|
66
|
+
}
|
|
67
|
+
async embedContent(_request) {
|
|
68
|
+
return { embeddings: [{ values: [0.1, 0.2, 0.3] }] };
|
|
69
|
+
}
|
|
70
|
+
},
|
|
71
|
+
}));
|
|
72
|
+
// Mock SharedTokenManager
|
|
73
|
+
vi.mock('./sharedTokenManager.js', () => ({
|
|
74
|
+
SharedTokenManager: class {
|
|
75
|
+
static instance = null;
|
|
76
|
+
mockCredentials = null;
|
|
77
|
+
shouldThrowError = false;
|
|
78
|
+
errorToThrow = null;
|
|
79
|
+
static getInstance() {
|
|
80
|
+
if (!this.instance) {
|
|
81
|
+
this.instance = new this();
|
|
82
|
+
}
|
|
83
|
+
return this.instance;
|
|
84
|
+
}
|
|
85
|
+
async getValidCredentials(OSAClient) {
|
|
86
|
+
// If we're configured to throw an error, do so
|
|
87
|
+
if (this.shouldThrowError && this.errorToThrow) {
|
|
88
|
+
throw this.errorToThrow;
|
|
89
|
+
}
|
|
90
|
+
// Try to get credentials from the mock client first to trigger auth errors
|
|
91
|
+
try {
|
|
92
|
+
const { token } = await OSAClient.getAccessToken();
|
|
93
|
+
if (token) {
|
|
94
|
+
const credentials = OSAClient.getCredentials();
|
|
95
|
+
return credentials;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
catch (error) {
|
|
99
|
+
// If it's an auth error and we need to simulate refresh behavior
|
|
100
|
+
const errorMessage = error instanceof Error
|
|
101
|
+
? error.message.toLowerCase()
|
|
102
|
+
: String(error).toLowerCase();
|
|
103
|
+
const errorCode = error?.status ||
|
|
104
|
+
error?.code;
|
|
105
|
+
const isAuthError = errorCode === 401 ||
|
|
106
|
+
errorCode === 403 ||
|
|
107
|
+
errorMessage.includes('unauthorized') ||
|
|
108
|
+
errorMessage.includes('forbidden') ||
|
|
109
|
+
errorMessage.includes('token expired');
|
|
110
|
+
if (isAuthError) {
|
|
111
|
+
// Try to refresh the token through the client
|
|
112
|
+
try {
|
|
113
|
+
const refreshResult = await OSAClient.refreshAccessToken();
|
|
114
|
+
if (refreshResult && !('error' in refreshResult)) {
|
|
115
|
+
// Refresh succeeded, update client credentials and return them
|
|
116
|
+
const updatedCredentials = OSAClient.getCredentials();
|
|
117
|
+
return updatedCredentials;
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
// Refresh failed, throw appropriate error
|
|
121
|
+
throw new Error('Failed to obtain valid OSA access token. Please re-authenticate.');
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
catch {
|
|
125
|
+
throw new Error('Failed to obtain valid OSA access token. Please re-authenticate.');
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
// Re-throw non-auth errors
|
|
130
|
+
throw error;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
// Return mock credentials only if they're set
|
|
134
|
+
if (this.mockCredentials && this.mockCredentials.access_token) {
|
|
135
|
+
return this.mockCredentials;
|
|
136
|
+
}
|
|
137
|
+
// Default fallback for tests that need credentials
|
|
138
|
+
return {
|
|
139
|
+
access_token: 'valid-token',
|
|
140
|
+
refresh_token: 'valid-refresh-token',
|
|
141
|
+
resource_url: 'https://test-endpoint.com/v1',
|
|
142
|
+
expiry_date: Date.now() + 3600000,
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
getCurrentCredentials() {
|
|
146
|
+
return this.mockCredentials;
|
|
147
|
+
}
|
|
148
|
+
clearCache() {
|
|
149
|
+
this.mockCredentials = null;
|
|
150
|
+
}
|
|
151
|
+
// Helper method for tests to set credentials
|
|
152
|
+
setMockCredentials(credentials) {
|
|
153
|
+
this.mockCredentials = credentials;
|
|
154
|
+
}
|
|
155
|
+
// Helper method for tests to simulate errors
|
|
156
|
+
setMockError(error) {
|
|
157
|
+
this.shouldThrowError = !!error;
|
|
158
|
+
this.errorToThrow = error;
|
|
159
|
+
}
|
|
160
|
+
},
|
|
161
|
+
}));
|
|
162
|
+
// Mock the OpenAIContentGenerator parent class
|
|
163
|
+
vi.mock('../core/openaiContentGenerator/index.js', () => ({
|
|
164
|
+
OpenAIContentGenerator: class {
|
|
165
|
+
pipeline;
|
|
166
|
+
constructor(_config, _provider) {
|
|
167
|
+
this.pipeline = {
|
|
168
|
+
client: {
|
|
169
|
+
apiKey: 'test-key',
|
|
170
|
+
baseURL: 'https://api.openai.com/v1',
|
|
171
|
+
},
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
async generateContent(_request) {
|
|
175
|
+
return createMockResponse('Generated content');
|
|
176
|
+
}
|
|
177
|
+
async generateContentStream(_request) {
|
|
178
|
+
return (async function* () {
|
|
179
|
+
yield createMockResponse('Stream chunk 1');
|
|
180
|
+
yield createMockResponse('Stream chunk 2');
|
|
181
|
+
})();
|
|
182
|
+
}
|
|
183
|
+
async countTokens(_request) {
|
|
184
|
+
return { totalTokens: 15 };
|
|
185
|
+
}
|
|
186
|
+
async embedContent(_request) {
|
|
187
|
+
return { embeddings: [{ values: [0.1, 0.2, 0.3] }] };
|
|
188
|
+
}
|
|
189
|
+
shouldSuppressErrorLogging(_error, _request) {
|
|
190
|
+
return false;
|
|
191
|
+
}
|
|
192
|
+
},
|
|
193
|
+
}));
|
|
194
|
+
const createMockResponse = (text) => ({
|
|
195
|
+
candidates: [
|
|
196
|
+
{
|
|
197
|
+
content: { role: 'model', parts: [{ text }] },
|
|
198
|
+
finishReason: FinishReason.STOP,
|
|
199
|
+
index: 0,
|
|
200
|
+
safetyRatings: [],
|
|
201
|
+
},
|
|
202
|
+
],
|
|
203
|
+
promptFeedback: { safetyRatings: [] },
|
|
204
|
+
text,
|
|
205
|
+
data: undefined,
|
|
206
|
+
functionCalls: [],
|
|
207
|
+
executableCode: '',
|
|
208
|
+
codeExecutionResult: '',
|
|
209
|
+
});
|
|
210
|
+
describe('OSAContentGenerator', () => {
|
|
211
|
+
let mockOSAClient;
|
|
212
|
+
let generator;
|
|
213
|
+
let mockConfig;
|
|
214
|
+
const mockCredentials = {
|
|
215
|
+
access_token: 'test-access-token',
|
|
216
|
+
refresh_token: 'test-refresh-token',
|
|
217
|
+
resource_url: 'https://test-endpoint.com/v1',
|
|
218
|
+
};
|
|
219
|
+
beforeEach(() => {
|
|
220
|
+
vi.clearAllMocks();
|
|
221
|
+
// Mock Config
|
|
222
|
+
mockConfig = {
|
|
223
|
+
getContentGeneratorConfig: vi.fn().mockReturnValue({
|
|
224
|
+
model: 'OSA-turbo',
|
|
225
|
+
apiKey: 'test-api-key',
|
|
226
|
+
authType: 'OSA',
|
|
227
|
+
baseUrl: 'https://dashscope.aliyuncs.com/compatible-mode/v1',
|
|
228
|
+
enableOpenAILogging: false,
|
|
229
|
+
timeout: 120000,
|
|
230
|
+
maxRetries: 3,
|
|
231
|
+
samplingParams: {
|
|
232
|
+
temperature: 0.7,
|
|
233
|
+
max_tokens: 1000,
|
|
234
|
+
top_p: 0.9,
|
|
235
|
+
},
|
|
236
|
+
}),
|
|
237
|
+
getCliVersion: vi.fn().mockReturnValue('1.0.0'),
|
|
238
|
+
getSessionId: vi.fn().mockReturnValue('test-session-id'),
|
|
239
|
+
getUsageStatisticsEnabled: vi.fn().mockReturnValue(false),
|
|
240
|
+
};
|
|
241
|
+
// Mock OSAOAuth2Client
|
|
242
|
+
mockOSAClient = {
|
|
243
|
+
getAccessToken: vi.fn(),
|
|
244
|
+
getCredentials: vi.fn(),
|
|
245
|
+
setCredentials: vi.fn(),
|
|
246
|
+
refreshAccessToken: vi.fn(),
|
|
247
|
+
requestDeviceAuthorization: vi.fn(),
|
|
248
|
+
pollDeviceToken: vi.fn(),
|
|
249
|
+
};
|
|
250
|
+
// Create OSAContentGenerator instance
|
|
251
|
+
const contentGeneratorConfig = {
|
|
252
|
+
model: 'OSA-turbo',
|
|
253
|
+
apiKey: 'test-api-key',
|
|
254
|
+
authType: AuthType.OSA_OAUTH,
|
|
255
|
+
baseUrl: 'https://dashscope.aliyuncs.com/compatible-mode/v1',
|
|
256
|
+
timeout: 120000,
|
|
257
|
+
maxRetries: 3,
|
|
258
|
+
};
|
|
259
|
+
generator = new OSAContentGenerator(mockOSAClient, contentGeneratorConfig, mockConfig);
|
|
260
|
+
});
|
|
261
|
+
afterEach(() => {
|
|
262
|
+
vi.restoreAllMocks();
|
|
263
|
+
});
|
|
264
|
+
describe('Core Content Generation Methods', () => {
|
|
265
|
+
it('should generate content with valid token', async () => {
|
|
266
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
267
|
+
token: 'valid-token',
|
|
268
|
+
});
|
|
269
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue(mockCredentials);
|
|
270
|
+
const request = {
|
|
271
|
+
model: 'OSA-turbo',
|
|
272
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
273
|
+
};
|
|
274
|
+
const result = await generator.generateContent(request, 'test-prompt-id');
|
|
275
|
+
expect(result.text).toBe('Generated content');
|
|
276
|
+
expect(mockOSAClient.getAccessToken).toHaveBeenCalled();
|
|
277
|
+
});
|
|
278
|
+
it('should generate content stream with valid token', async () => {
|
|
279
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
280
|
+
token: 'valid-token',
|
|
281
|
+
});
|
|
282
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue(mockCredentials);
|
|
283
|
+
const request = {
|
|
284
|
+
model: 'OSA-turbo',
|
|
285
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello stream' }] }],
|
|
286
|
+
};
|
|
287
|
+
const stream = await generator.generateContentStream(request, 'test-prompt-id');
|
|
288
|
+
const chunks = [];
|
|
289
|
+
for await (const chunk of stream) {
|
|
290
|
+
chunks.push(chunk.text || '');
|
|
291
|
+
}
|
|
292
|
+
expect(chunks).toEqual(['Stream chunk 1', 'Stream chunk 2']);
|
|
293
|
+
expect(mockOSAClient.getAccessToken).toHaveBeenCalled();
|
|
294
|
+
});
|
|
295
|
+
it('should count tokens without requiring authentication', async () => {
|
|
296
|
+
// Clear any previous mock calls
|
|
297
|
+
vi.clearAllMocks();
|
|
298
|
+
const request = {
|
|
299
|
+
model: 'OSA-turbo',
|
|
300
|
+
contents: [{ role: 'user', parts: [{ text: 'Count me' }] }],
|
|
301
|
+
};
|
|
302
|
+
const result = await generator.countTokens(request);
|
|
303
|
+
expect(result.totalTokens).toBe(15);
|
|
304
|
+
// countTokens is a local operation and should not require OAuth credentials
|
|
305
|
+
expect(mockOSAClient.getAccessToken).not.toHaveBeenCalled();
|
|
306
|
+
});
|
|
307
|
+
it('should embed content with valid token', async () => {
|
|
308
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
309
|
+
token: 'valid-token',
|
|
310
|
+
});
|
|
311
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue(mockCredentials);
|
|
312
|
+
const request = {
|
|
313
|
+
model: 'OSA-turbo',
|
|
314
|
+
contents: [{ parts: [{ text: 'Embed me' }] }],
|
|
315
|
+
};
|
|
316
|
+
const result = await generator.embedContent(request);
|
|
317
|
+
expect(result.embeddings).toHaveLength(1);
|
|
318
|
+
expect(result.embeddings?.[0]?.values).toEqual([0.1, 0.2, 0.3]);
|
|
319
|
+
expect(mockOSAClient.getAccessToken).toHaveBeenCalled();
|
|
320
|
+
});
|
|
321
|
+
});
|
|
322
|
+
describe('Token Management and Refresh Logic', () => {
|
|
323
|
+
it('should refresh token on auth error and retry', async () => {
|
|
324
|
+
const authError = { status: 401, message: 'Unauthorized' };
|
|
325
|
+
// First call fails with auth error, second call succeeds
|
|
326
|
+
vi.mocked(mockOSAClient.getAccessToken)
|
|
327
|
+
.mockRejectedValueOnce(authError)
|
|
328
|
+
.mockResolvedValueOnce({ token: 'refreshed-token' });
|
|
329
|
+
// Refresh succeeds
|
|
330
|
+
vi.mocked(mockOSAClient.refreshAccessToken).mockResolvedValue({
|
|
331
|
+
access_token: 'refreshed-token',
|
|
332
|
+
token_type: 'Bearer',
|
|
333
|
+
expires_in: 3600,
|
|
334
|
+
resource_url: 'https://refreshed-endpoint.com',
|
|
335
|
+
});
|
|
336
|
+
// Set credentials for second call
|
|
337
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
338
|
+
access_token: 'refreshed-token',
|
|
339
|
+
token_type: 'Bearer',
|
|
340
|
+
refresh_token: 'refresh-token',
|
|
341
|
+
resource_url: 'https://refreshed-endpoint.com',
|
|
342
|
+
expiry_date: Date.now() + 3600000,
|
|
343
|
+
});
|
|
344
|
+
const request = {
|
|
345
|
+
model: 'OSA-turbo',
|
|
346
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
347
|
+
};
|
|
348
|
+
const result = await generator.generateContent(request, 'test-prompt-id');
|
|
349
|
+
expect(result.text).toBe('Generated content');
|
|
350
|
+
expect(mockOSAClient.refreshAccessToken).toHaveBeenCalled();
|
|
351
|
+
});
|
|
352
|
+
it('should refresh token on auth error and retry for content stream', async () => {
|
|
353
|
+
const authError = { status: 401, message: 'Unauthorized' };
|
|
354
|
+
// Reset mocks for this test
|
|
355
|
+
vi.clearAllMocks();
|
|
356
|
+
// First call fails with auth error, second call succeeds
|
|
357
|
+
vi.mocked(mockOSAClient.getAccessToken)
|
|
358
|
+
.mockRejectedValueOnce(authError)
|
|
359
|
+
.mockResolvedValueOnce({ token: 'refreshed-stream-token' });
|
|
360
|
+
// Refresh succeeds
|
|
361
|
+
vi.mocked(mockOSAClient.refreshAccessToken).mockResolvedValue({
|
|
362
|
+
access_token: 'refreshed-stream-token',
|
|
363
|
+
token_type: 'Bearer',
|
|
364
|
+
expires_in: 3600,
|
|
365
|
+
resource_url: 'https://refreshed-stream-endpoint.com',
|
|
366
|
+
});
|
|
367
|
+
// Set credentials for second call
|
|
368
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
369
|
+
access_token: 'refreshed-stream-token',
|
|
370
|
+
token_type: 'Bearer',
|
|
371
|
+
refresh_token: 'refresh-token',
|
|
372
|
+
resource_url: 'https://refreshed-stream-endpoint.com',
|
|
373
|
+
expiry_date: Date.now() + 3600000,
|
|
374
|
+
});
|
|
375
|
+
const request = {
|
|
376
|
+
model: 'OSA-turbo',
|
|
377
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello stream' }] }],
|
|
378
|
+
};
|
|
379
|
+
const stream = await generator.generateContentStream(request, 'test-prompt-id');
|
|
380
|
+
const chunks = [];
|
|
381
|
+
for await (const chunk of stream) {
|
|
382
|
+
chunks.push(chunk.text || '');
|
|
383
|
+
}
|
|
384
|
+
expect(chunks).toEqual(['Stream chunk 1', 'Stream chunk 2']);
|
|
385
|
+
expect(mockOSAClient.refreshAccessToken).toHaveBeenCalled();
|
|
386
|
+
});
|
|
387
|
+
it('should handle token refresh failure', async () => {
|
|
388
|
+
// Mock the SharedTokenManager to throw an error
|
|
389
|
+
const mockTokenManager = SharedTokenManager.getInstance();
|
|
390
|
+
mockTokenManager.setMockError(new Error('Failed to obtain valid OSA access token. Please re-authenticate.'));
|
|
391
|
+
const request = {
|
|
392
|
+
model: 'OSA-turbo',
|
|
393
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
394
|
+
};
|
|
395
|
+
await expect(generator.generateContent(request, 'test-prompt-id')).rejects.toThrow('Failed to obtain valid OSA access token. Please re-authenticate.');
|
|
396
|
+
// Clean up
|
|
397
|
+
mockTokenManager.setMockError(null);
|
|
398
|
+
});
|
|
399
|
+
it('should update endpoint when token is refreshed', async () => {
|
|
400
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
401
|
+
token: 'valid-token',
|
|
402
|
+
});
|
|
403
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
404
|
+
...mockCredentials,
|
|
405
|
+
resource_url: 'https://new-endpoint.com',
|
|
406
|
+
});
|
|
407
|
+
const request = {
|
|
408
|
+
model: 'OSA-turbo',
|
|
409
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
410
|
+
};
|
|
411
|
+
await generator.generateContent(request, 'test-prompt-id');
|
|
412
|
+
expect(mockOSAClient.getCredentials).toHaveBeenCalled();
|
|
413
|
+
});
|
|
414
|
+
});
|
|
415
|
+
describe('Endpoint URL Normalization', () => {
|
|
416
|
+
it('should use default endpoint when no custom endpoint provided', async () => {
|
|
417
|
+
let capturedBaseURL = '';
|
|
418
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
419
|
+
token: 'valid-token',
|
|
420
|
+
});
|
|
421
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
422
|
+
access_token: 'test-token',
|
|
423
|
+
refresh_token: 'test-refresh',
|
|
424
|
+
// No resource_url provided
|
|
425
|
+
});
|
|
426
|
+
// Mock the parent's generateContent to capture the baseURL during the call
|
|
427
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
428
|
+
const originalGenerateContent = parentPrototype.generateContent;
|
|
429
|
+
parentPrototype.generateContent = vi.fn().mockImplementation(function () {
|
|
430
|
+
capturedBaseURL = this.pipeline.client.baseURL;
|
|
431
|
+
return createMockResponse('Generated content');
|
|
432
|
+
});
|
|
433
|
+
const request = {
|
|
434
|
+
model: 'OSA-turbo',
|
|
435
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
436
|
+
};
|
|
437
|
+
await generator.generateContent(request, 'test-prompt-id');
|
|
438
|
+
// Should use default endpoint with /v1 suffix
|
|
439
|
+
expect(capturedBaseURL).toBe('https://dashscope.aliyuncs.com/compatible-mode/v1');
|
|
440
|
+
// Restore original method
|
|
441
|
+
parentPrototype.generateContent = originalGenerateContent;
|
|
442
|
+
});
|
|
443
|
+
it('should normalize hostname-only endpoints by adding https protocol', async () => {
|
|
444
|
+
let capturedBaseURL = '';
|
|
445
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
446
|
+
token: 'valid-token',
|
|
447
|
+
});
|
|
448
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
449
|
+
...mockCredentials,
|
|
450
|
+
resource_url: 'custom-endpoint.com',
|
|
451
|
+
});
|
|
452
|
+
// Mock the parent's generateContent to capture the baseURL during the call
|
|
453
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
454
|
+
const originalGenerateContent = parentPrototype.generateContent;
|
|
455
|
+
parentPrototype.generateContent = vi.fn().mockImplementation(function () {
|
|
456
|
+
capturedBaseURL = this.pipeline.client.baseURL;
|
|
457
|
+
return createMockResponse('Generated content');
|
|
458
|
+
});
|
|
459
|
+
const request = {
|
|
460
|
+
model: 'OSA-turbo',
|
|
461
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
462
|
+
};
|
|
463
|
+
await generator.generateContent(request, 'test-prompt-id');
|
|
464
|
+
// Should add https:// and /v1
|
|
465
|
+
expect(capturedBaseURL).toBe('https://custom-endpoint.com/v1');
|
|
466
|
+
// Restore original method
|
|
467
|
+
parentPrototype.generateContent = originalGenerateContent;
|
|
468
|
+
});
|
|
469
|
+
it('should preserve existing protocol in endpoint URLs', async () => {
|
|
470
|
+
let capturedBaseURL = '';
|
|
471
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
472
|
+
token: 'valid-token',
|
|
473
|
+
});
|
|
474
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
475
|
+
...mockCredentials,
|
|
476
|
+
resource_url: 'https://custom-endpoint.com',
|
|
477
|
+
});
|
|
478
|
+
// Mock the parent's generateContent to capture the baseURL during the call
|
|
479
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
480
|
+
const originalGenerateContent = parentPrototype.generateContent;
|
|
481
|
+
parentPrototype.generateContent = vi.fn().mockImplementation(function () {
|
|
482
|
+
capturedBaseURL = this.pipeline.client.baseURL;
|
|
483
|
+
return createMockResponse('Generated content');
|
|
484
|
+
});
|
|
485
|
+
const request = {
|
|
486
|
+
model: 'OSA-turbo',
|
|
487
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
488
|
+
};
|
|
489
|
+
await generator.generateContent(request, 'test-prompt-id');
|
|
490
|
+
// Should preserve https:// and add /v1
|
|
491
|
+
expect(capturedBaseURL).toBe('https://custom-endpoint.com/v1');
|
|
492
|
+
// Restore original method
|
|
493
|
+
parentPrototype.generateContent = originalGenerateContent;
|
|
494
|
+
});
|
|
495
|
+
it('should not duplicate /v1 suffix if already present', async () => {
|
|
496
|
+
let capturedBaseURL = '';
|
|
497
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
498
|
+
token: 'valid-token',
|
|
499
|
+
});
|
|
500
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
501
|
+
...mockCredentials,
|
|
502
|
+
resource_url: 'https://custom-endpoint.com/v1',
|
|
503
|
+
});
|
|
504
|
+
// Mock the parent's generateContent to capture the baseURL during the call
|
|
505
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
506
|
+
const originalGenerateContent = parentPrototype.generateContent;
|
|
507
|
+
parentPrototype.generateContent = vi.fn().mockImplementation(function () {
|
|
508
|
+
capturedBaseURL = this.pipeline.client.baseURL;
|
|
509
|
+
return createMockResponse('Generated content');
|
|
510
|
+
});
|
|
511
|
+
const request = {
|
|
512
|
+
model: 'OSA-turbo',
|
|
513
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
514
|
+
};
|
|
515
|
+
await generator.generateContent(request, 'test-prompt-id');
|
|
516
|
+
// Should not duplicate /v1
|
|
517
|
+
expect(capturedBaseURL).toBe('https://custom-endpoint.com/v1');
|
|
518
|
+
// Restore original method
|
|
519
|
+
parentPrototype.generateContent = originalGenerateContent;
|
|
520
|
+
});
|
|
521
|
+
});
|
|
522
|
+
describe('Client State Management', () => {
|
|
523
|
+
it('should set dynamic credentials during operations', async () => {
|
|
524
|
+
const client = OSAContentGenerator.pipeline.client;
|
|
525
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
526
|
+
token: 'temp-token',
|
|
527
|
+
});
|
|
528
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
529
|
+
...mockCredentials,
|
|
530
|
+
access_token: 'temp-token',
|
|
531
|
+
resource_url: 'https://temp-endpoint.com',
|
|
532
|
+
});
|
|
533
|
+
const request = {
|
|
534
|
+
model: 'OSA-turbo',
|
|
535
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
536
|
+
};
|
|
537
|
+
await generator.generateContent(request, 'test-prompt-id');
|
|
538
|
+
// Should have dynamic credentials set
|
|
539
|
+
expect(client.apiKey).toBe('temp-token');
|
|
540
|
+
expect(client.baseURL).toBe('https://temp-endpoint.com/v1');
|
|
541
|
+
});
|
|
542
|
+
it('should set credentials even when operation throws', async () => {
|
|
543
|
+
const client = OSAContentGenerator.pipeline.client;
|
|
544
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
545
|
+
token: 'temp-token',
|
|
546
|
+
});
|
|
547
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
548
|
+
...mockCredentials,
|
|
549
|
+
access_token: 'temp-token',
|
|
550
|
+
});
|
|
551
|
+
// Mock the parent method to throw an error
|
|
552
|
+
const mockError = new Error('Network error');
|
|
553
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
554
|
+
const originalGenerateContent = parentPrototype.generateContent;
|
|
555
|
+
parentPrototype.generateContent = vi.fn().mockRejectedValue(mockError);
|
|
556
|
+
const request = {
|
|
557
|
+
model: 'OSA-turbo',
|
|
558
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
559
|
+
};
|
|
560
|
+
try {
|
|
561
|
+
await generator.generateContent(request, 'test-prompt-id');
|
|
562
|
+
}
|
|
563
|
+
catch (error) {
|
|
564
|
+
expect(error).toBe(mockError);
|
|
565
|
+
}
|
|
566
|
+
// Credentials should still be set before the error occurred
|
|
567
|
+
expect(client.apiKey).toBe('temp-token');
|
|
568
|
+
expect(client.baseURL).toBe('https://test-endpoint.com/v1');
|
|
569
|
+
// Restore original method
|
|
570
|
+
parentPrototype.generateContent = originalGenerateContent;
|
|
571
|
+
});
|
|
572
|
+
});
|
|
573
|
+
describe('Error Handling and Retry Logic', () => {
|
|
574
|
+
it('should retry once on authentication errors', async () => {
|
|
575
|
+
const authError = { status: 401, message: 'Unauthorized' };
|
|
576
|
+
// Mock first call to fail with auth error
|
|
577
|
+
const mockGenerateContent = vi
|
|
578
|
+
.fn()
|
|
579
|
+
.mockRejectedValueOnce(authError)
|
|
580
|
+
.mockResolvedValueOnce(createMockResponse('Success after retry'));
|
|
581
|
+
// Replace the parent method
|
|
582
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
583
|
+
const originalGenerateContent = parentPrototype.generateContent;
|
|
584
|
+
parentPrototype.generateContent = mockGenerateContent;
|
|
585
|
+
// Mock getAccessToken to fail initially, then succeed
|
|
586
|
+
let getAccessTokenCallCount = 0;
|
|
587
|
+
vi.mocked(mockOSAClient.getAccessToken).mockImplementation(async () => {
|
|
588
|
+
getAccessTokenCallCount++;
|
|
589
|
+
if (getAccessTokenCallCount <= 2) {
|
|
590
|
+
throw authError; // Fail on first two calls (initial + retry)
|
|
591
|
+
}
|
|
592
|
+
return { token: 'refreshed-token' }; // Succeed after refresh
|
|
593
|
+
});
|
|
594
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
595
|
+
access_token: 'refreshed-token',
|
|
596
|
+
token_type: 'Bearer',
|
|
597
|
+
refresh_token: 'refresh-token',
|
|
598
|
+
resource_url: 'https://test-endpoint.com',
|
|
599
|
+
expiry_date: Date.now() + 3600000,
|
|
600
|
+
});
|
|
601
|
+
vi.mocked(mockOSAClient.refreshAccessToken).mockResolvedValue({
|
|
602
|
+
access_token: 'refreshed-token',
|
|
603
|
+
token_type: 'Bearer',
|
|
604
|
+
expires_in: 3600,
|
|
605
|
+
});
|
|
606
|
+
const request = {
|
|
607
|
+
model: 'OSA-turbo',
|
|
608
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
609
|
+
};
|
|
610
|
+
const result = await generator.generateContent(request, 'test-prompt-id');
|
|
611
|
+
expect(result.text).toBe('Success after retry');
|
|
612
|
+
expect(mockGenerateContent).toHaveBeenCalledTimes(2);
|
|
613
|
+
expect(mockOSAClient.refreshAccessToken).toHaveBeenCalled();
|
|
614
|
+
// Restore original method
|
|
615
|
+
parentPrototype.generateContent = originalGenerateContent;
|
|
616
|
+
});
|
|
617
|
+
it('should not retry non-authentication errors', async () => {
|
|
618
|
+
const networkError = new Error('Network timeout');
|
|
619
|
+
const mockGenerateContent = vi.fn().mockRejectedValue(networkError);
|
|
620
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
621
|
+
const originalGenerateContent = parentPrototype.generateContent;
|
|
622
|
+
parentPrototype.generateContent = mockGenerateContent;
|
|
623
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
624
|
+
token: 'valid-token',
|
|
625
|
+
});
|
|
626
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue(mockCredentials);
|
|
627
|
+
const request = {
|
|
628
|
+
model: 'OSA-turbo',
|
|
629
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
630
|
+
};
|
|
631
|
+
await expect(generator.generateContent(request, 'test-prompt-id')).rejects.toThrow('Network timeout');
|
|
632
|
+
expect(mockGenerateContent).toHaveBeenCalledTimes(1);
|
|
633
|
+
expect(mockOSAClient.refreshAccessToken).not.toHaveBeenCalled();
|
|
634
|
+
// Restore original method
|
|
635
|
+
parentPrototype.generateContent = originalGenerateContent;
|
|
636
|
+
});
|
|
637
|
+
it('should handle error response from token refresh', async () => {
|
|
638
|
+
vi.mocked(mockOSAClient.getAccessToken).mockRejectedValue(new Error('Token expired'));
|
|
639
|
+
vi.mocked(mockOSAClient.refreshAccessToken).mockResolvedValue({
|
|
640
|
+
error: 'invalid_grant',
|
|
641
|
+
error_description: 'Refresh token expired',
|
|
642
|
+
});
|
|
643
|
+
const request = {
|
|
644
|
+
model: 'OSA-turbo',
|
|
645
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
646
|
+
};
|
|
647
|
+
await expect(generator.generateContent(request, 'test-prompt-id')).rejects.toThrow('Failed to obtain valid OSA access token');
|
|
648
|
+
});
|
|
649
|
+
});
|
|
650
|
+
describe('Token State Management', () => {
|
|
651
|
+
it('should cache and return current token', () => {
|
|
652
|
+
expect(generator.getCurrentToken()).toBeNull();
|
|
653
|
+
// Simulate setting a token internally
|
|
654
|
+
OSAContentGenerator.currentToken = 'cached-token';
|
|
655
|
+
expect(generator.getCurrentToken()).toBe('cached-token');
|
|
656
|
+
});
|
|
657
|
+
it('should clear token on clearToken()', () => {
|
|
658
|
+
// Simulate having cached token value
|
|
659
|
+
const OSAInstance = OSAContentGenerator;
|
|
660
|
+
OSAInstance.currentToken = 'cached-token';
|
|
661
|
+
generator.clearToken();
|
|
662
|
+
expect(generator.getCurrentToken()).toBeNull();
|
|
663
|
+
});
|
|
664
|
+
it('should handle concurrent token refresh requests', async () => {
|
|
665
|
+
let refreshCallCount = 0;
|
|
666
|
+
// Clear any existing cached token first
|
|
667
|
+
generator.clearToken();
|
|
668
|
+
// Mock to simulate auth error on first parent call, which should trigger refresh
|
|
669
|
+
const authError = { status: 401, message: 'Unauthorized' };
|
|
670
|
+
let parentCallCount = 0;
|
|
671
|
+
vi.mocked(mockOSAClient.getAccessToken).mockRejectedValue(authError);
|
|
672
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue(mockCredentials);
|
|
673
|
+
vi.mocked(mockOSAClient.refreshAccessToken).mockImplementation(async () => {
|
|
674
|
+
refreshCallCount++;
|
|
675
|
+
await new Promise((resolve) => setTimeout(resolve, 50)); // Longer delay to ensure concurrency
|
|
676
|
+
return {
|
|
677
|
+
access_token: 'refreshed-token',
|
|
678
|
+
token_type: 'Bearer',
|
|
679
|
+
expires_in: 3600,
|
|
680
|
+
};
|
|
681
|
+
});
|
|
682
|
+
// Mock the parent method to fail first then succeed
|
|
683
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
684
|
+
const originalGenerateContent = parentPrototype.generateContent;
|
|
685
|
+
parentPrototype.generateContent = vi.fn().mockImplementation(async () => {
|
|
686
|
+
parentCallCount++;
|
|
687
|
+
if (parentCallCount === 1) {
|
|
688
|
+
throw authError; // First call triggers auth error
|
|
689
|
+
}
|
|
690
|
+
return createMockResponse('Generated content');
|
|
691
|
+
});
|
|
692
|
+
const request = {
|
|
693
|
+
model: 'OSA-turbo',
|
|
694
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
695
|
+
};
|
|
696
|
+
// Make multiple concurrent requests - should all use the same refresh promise
|
|
697
|
+
const promises = [
|
|
698
|
+
generator.generateContent(request, 'test-prompt-id'),
|
|
699
|
+
generator.generateContent(request, 'test-prompt-id'),
|
|
700
|
+
generator.generateContent(request, 'test-prompt-id'),
|
|
701
|
+
];
|
|
702
|
+
const results = await Promise.all(promises);
|
|
703
|
+
// All should succeed
|
|
704
|
+
results.forEach((result) => {
|
|
705
|
+
expect(result.text).toBe('Generated content');
|
|
706
|
+
});
|
|
707
|
+
// The main test is that all requests succeed without crashing
|
|
708
|
+
expect(results).toHaveLength(3);
|
|
709
|
+
// With our new implementation through SharedTokenManager, refresh should still be called
|
|
710
|
+
expect(refreshCallCount).toBeGreaterThanOrEqual(1);
|
|
711
|
+
// Restore original method
|
|
712
|
+
parentPrototype.generateContent = originalGenerateContent;
|
|
713
|
+
});
|
|
714
|
+
});
|
|
715
|
+
describe('Error Logging Suppression', () => {
|
|
716
|
+
it('should suppress logging for authentication errors', () => {
|
|
717
|
+
const authErrors = [
|
|
718
|
+
{ status: 401 },
|
|
719
|
+
{ code: 403 },
|
|
720
|
+
new Error('Unauthorized access'),
|
|
721
|
+
new Error('Token expired'),
|
|
722
|
+
new Error('Invalid API key'),
|
|
723
|
+
];
|
|
724
|
+
authErrors.forEach((error) => {
|
|
725
|
+
const shouldSuppress = OSAContentGenerator.shouldSuppressErrorLogging(error, {});
|
|
726
|
+
expect(shouldSuppress).toBe(true);
|
|
727
|
+
});
|
|
728
|
+
});
|
|
729
|
+
it('should not suppress logging for non-auth errors', () => {
|
|
730
|
+
const nonAuthErrors = [
|
|
731
|
+
new Error('Network timeout'),
|
|
732
|
+
new Error('Rate limit exceeded'),
|
|
733
|
+
{ status: 500 },
|
|
734
|
+
new Error('Internal server error'),
|
|
735
|
+
];
|
|
736
|
+
nonAuthErrors.forEach((error) => {
|
|
737
|
+
const shouldSuppress = OSAContentGenerator.shouldSuppressErrorLogging(error, {});
|
|
738
|
+
expect(shouldSuppress).toBe(false);
|
|
739
|
+
});
|
|
740
|
+
});
|
|
741
|
+
});
|
|
742
|
+
describe('Integration Tests', () => {
|
|
743
|
+
it('should handle complete workflow: get token, use it, refresh on auth error, retry', async () => {
|
|
744
|
+
const authError = { status: 401, message: 'Token expired' };
|
|
745
|
+
// Setup complex scenario
|
|
746
|
+
let callCount = 0;
|
|
747
|
+
const mockGenerateContent = vi.fn().mockImplementation(async () => {
|
|
748
|
+
callCount++;
|
|
749
|
+
if (callCount === 1) {
|
|
750
|
+
throw authError; // First call fails
|
|
751
|
+
}
|
|
752
|
+
return createMockResponse('Success after refresh'); // Second call succeeds
|
|
753
|
+
});
|
|
754
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
755
|
+
parentPrototype.generateContent = mockGenerateContent;
|
|
756
|
+
// Mock getAccessToken to fail initially, then succeed
|
|
757
|
+
let getAccessTokenCallCount = 0;
|
|
758
|
+
vi.mocked(mockOSAClient.getAccessToken).mockImplementation(async () => {
|
|
759
|
+
getAccessTokenCallCount++;
|
|
760
|
+
if (getAccessTokenCallCount <= 2) {
|
|
761
|
+
throw authError; // Fail on first two calls (initial + retry)
|
|
762
|
+
}
|
|
763
|
+
return { token: 'new-token' }; // Succeed after refresh
|
|
764
|
+
});
|
|
765
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
766
|
+
access_token: 'new-token',
|
|
767
|
+
token_type: 'Bearer',
|
|
768
|
+
refresh_token: 'refresh-token',
|
|
769
|
+
resource_url: 'https://new-endpoint.com',
|
|
770
|
+
expiry_date: Date.now() + 7200000,
|
|
771
|
+
});
|
|
772
|
+
vi.mocked(mockOSAClient.refreshAccessToken).mockResolvedValue({
|
|
773
|
+
access_token: 'new-token',
|
|
774
|
+
token_type: 'Bearer',
|
|
775
|
+
expires_in: 7200,
|
|
776
|
+
resource_url: 'https://new-endpoint.com',
|
|
777
|
+
});
|
|
778
|
+
const request = {
|
|
779
|
+
model: 'OSA-turbo',
|
|
780
|
+
contents: [{ role: 'user', parts: [{ text: 'Test message' }] }],
|
|
781
|
+
};
|
|
782
|
+
const result = await generator.generateContent(request, 'test-prompt-id');
|
|
783
|
+
expect(result.text).toBe('Success after refresh');
|
|
784
|
+
expect(mockOSAClient.getAccessToken).toHaveBeenCalled();
|
|
785
|
+
expect(mockOSAClient.refreshAccessToken).toHaveBeenCalled();
|
|
786
|
+
expect(callCount).toBe(2); // Initial call + retry
|
|
787
|
+
});
|
|
788
|
+
});
|
|
789
|
+
describe('SharedTokenManager Integration', () => {
|
|
790
|
+
it('should use SharedTokenManager to get valid credentials', async () => {
|
|
791
|
+
const mockTokenManager = {
|
|
792
|
+
getValidCredentials: vi.fn().mockResolvedValue({
|
|
793
|
+
access_token: 'manager-token',
|
|
794
|
+
resource_url: 'https://manager-endpoint.com',
|
|
795
|
+
}),
|
|
796
|
+
getCurrentCredentials: vi.fn(),
|
|
797
|
+
clearCache: vi.fn(),
|
|
798
|
+
};
|
|
799
|
+
// Mock the SharedTokenManager.getInstance()
|
|
800
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
801
|
+
SharedTokenManager.getInstance = vi
|
|
802
|
+
.fn()
|
|
803
|
+
.mockReturnValue(mockTokenManager);
|
|
804
|
+
// Create new instance to pick up the mock
|
|
805
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
806
|
+
const request = {
|
|
807
|
+
model: 'OSA-turbo',
|
|
808
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
809
|
+
};
|
|
810
|
+
await newGenerator.generateContent(request, 'test-prompt-id');
|
|
811
|
+
expect(mockTokenManager.getValidCredentials).toHaveBeenCalledWith(mockOSAClient);
|
|
812
|
+
// Restore original
|
|
813
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
814
|
+
});
|
|
815
|
+
it('should handle SharedTokenManager errors gracefully', async () => {
|
|
816
|
+
const mockTokenManager = {
|
|
817
|
+
getValidCredentials: vi
|
|
818
|
+
.fn()
|
|
819
|
+
.mockRejectedValue(new Error('Token manager error')),
|
|
820
|
+
getCurrentCredentials: vi.fn(),
|
|
821
|
+
clearCache: vi.fn(),
|
|
822
|
+
};
|
|
823
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
824
|
+
SharedTokenManager.getInstance = vi
|
|
825
|
+
.fn()
|
|
826
|
+
.mockReturnValue(mockTokenManager);
|
|
827
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
828
|
+
const request = {
|
|
829
|
+
model: 'OSA-turbo',
|
|
830
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
831
|
+
};
|
|
832
|
+
await expect(newGenerator.generateContent(request, 'test-prompt-id')).rejects.toThrow('Failed to obtain valid OSA access token');
|
|
833
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
834
|
+
});
|
|
835
|
+
it('should handle missing access token from credentials', async () => {
|
|
836
|
+
const mockTokenManager = {
|
|
837
|
+
getValidCredentials: vi.fn().mockResolvedValue({
|
|
838
|
+
access_token: undefined,
|
|
839
|
+
resource_url: 'https://test-endpoint.com',
|
|
840
|
+
}),
|
|
841
|
+
getCurrentCredentials: vi.fn(),
|
|
842
|
+
clearCache: vi.fn(),
|
|
843
|
+
};
|
|
844
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
845
|
+
SharedTokenManager.getInstance = vi
|
|
846
|
+
.fn()
|
|
847
|
+
.mockReturnValue(mockTokenManager);
|
|
848
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
849
|
+
const request = {
|
|
850
|
+
model: 'OSA-turbo',
|
|
851
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
852
|
+
};
|
|
853
|
+
await expect(newGenerator.generateContent(request, 'test-prompt-id')).rejects.toThrow('Failed to obtain valid OSA access token');
|
|
854
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
855
|
+
});
|
|
856
|
+
});
|
|
857
|
+
describe('getCurrentEndpoint Method', () => {
|
|
858
|
+
it('should handle URLs with custom ports', () => {
|
|
859
|
+
const endpoints = [
|
|
860
|
+
{ input: 'localhost:8080', expected: 'https://localhost:8080/v1' },
|
|
861
|
+
{
|
|
862
|
+
input: 'http://localhost:8080',
|
|
863
|
+
expected: 'http://localhost:8080/v1',
|
|
864
|
+
},
|
|
865
|
+
{
|
|
866
|
+
input: 'https://api.example.com:443',
|
|
867
|
+
expected: 'https://api.example.com:443/v1',
|
|
868
|
+
},
|
|
869
|
+
{
|
|
870
|
+
input: 'api.example.com:9000/api',
|
|
871
|
+
expected: 'https://api.example.com:9000/api/v1',
|
|
872
|
+
},
|
|
873
|
+
];
|
|
874
|
+
endpoints.forEach(({ input, expected }) => {
|
|
875
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
876
|
+
token: 'test-token',
|
|
877
|
+
});
|
|
878
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
879
|
+
...mockCredentials,
|
|
880
|
+
resource_url: input,
|
|
881
|
+
});
|
|
882
|
+
const generator = OSAContentGenerator;
|
|
883
|
+
expect(generator.getCurrentEndpoint(input)).toBe(expected);
|
|
884
|
+
});
|
|
885
|
+
});
|
|
886
|
+
it('should handle URLs with existing paths', () => {
|
|
887
|
+
const endpoints = [
|
|
888
|
+
{
|
|
889
|
+
input: 'https://api.example.com/api',
|
|
890
|
+
expected: 'https://api.example.com/api/v1',
|
|
891
|
+
},
|
|
892
|
+
{
|
|
893
|
+
input: 'api.example.com/api/v2',
|
|
894
|
+
expected: 'https://api.example.com/api/v2/v1',
|
|
895
|
+
},
|
|
896
|
+
{
|
|
897
|
+
input: 'https://api.example.com/api/v1',
|
|
898
|
+
expected: 'https://api.example.com/api/v1',
|
|
899
|
+
},
|
|
900
|
+
];
|
|
901
|
+
endpoints.forEach(({ input, expected }) => {
|
|
902
|
+
const generator = OSAContentGenerator;
|
|
903
|
+
expect(generator.getCurrentEndpoint(input)).toBe(expected);
|
|
904
|
+
});
|
|
905
|
+
});
|
|
906
|
+
it('should handle undefined resource URL', () => {
|
|
907
|
+
const generator = OSAContentGenerator;
|
|
908
|
+
expect(generator.getCurrentEndpoint(undefined)).toBe('https://dashscope.aliyuncs.com/compatible-mode/v1');
|
|
909
|
+
});
|
|
910
|
+
it('should handle empty resource URL', () => {
|
|
911
|
+
const generator = OSAContentGenerator;
|
|
912
|
+
// Empty string should fall back to default endpoint
|
|
913
|
+
expect(generator.getCurrentEndpoint('')).toBe('https://dashscope.aliyuncs.com/compatible-mode/v1');
|
|
914
|
+
});
|
|
915
|
+
});
|
|
916
|
+
describe('isAuthError Method Enhanced', () => {
|
|
917
|
+
it('should identify auth errors by numeric status codes', () => {
|
|
918
|
+
const authErrors = [
|
|
919
|
+
{ code: 401 },
|
|
920
|
+
{ status: 403 },
|
|
921
|
+
{ code: '401' }, // String status codes
|
|
922
|
+
{ status: '403' },
|
|
923
|
+
];
|
|
924
|
+
authErrors.forEach((error) => {
|
|
925
|
+
const generator = OSAContentGenerator;
|
|
926
|
+
expect(generator.isAuthError(error)).toBe(true);
|
|
927
|
+
});
|
|
928
|
+
// 400 is not typically an auth error, it's bad request
|
|
929
|
+
const nonAuthError = { status: 400 };
|
|
930
|
+
const generator = OSAContentGenerator;
|
|
931
|
+
expect(generator.isAuthError(nonAuthError)).toBe(false);
|
|
932
|
+
});
|
|
933
|
+
it('should identify auth errors by message content variations', () => {
|
|
934
|
+
const authMessages = [
|
|
935
|
+
'UNAUTHORIZED access',
|
|
936
|
+
'Access is FORBIDDEN',
|
|
937
|
+
'Invalid API Key provided',
|
|
938
|
+
'Invalid Access Token',
|
|
939
|
+
'Token has Expired',
|
|
940
|
+
'Authentication Required',
|
|
941
|
+
'Access Denied by server',
|
|
942
|
+
'The token has expired and needs refresh',
|
|
943
|
+
'Bearer token expired',
|
|
944
|
+
];
|
|
945
|
+
authMessages.forEach((message) => {
|
|
946
|
+
const error = new Error(message);
|
|
947
|
+
const generator = OSAContentGenerator;
|
|
948
|
+
expect(generator.isAuthError(error)).toBe(true);
|
|
949
|
+
});
|
|
950
|
+
});
|
|
951
|
+
it('should not identify non-auth errors', () => {
|
|
952
|
+
const nonAuthErrors = [
|
|
953
|
+
new Error('Network timeout'),
|
|
954
|
+
new Error('Rate limit exceeded'),
|
|
955
|
+
{ status: 500 },
|
|
956
|
+
{ code: 429 },
|
|
957
|
+
'Internal server error',
|
|
958
|
+
null,
|
|
959
|
+
undefined,
|
|
960
|
+
'',
|
|
961
|
+
{ status: 200 },
|
|
962
|
+
new Error('Model not found'),
|
|
963
|
+
];
|
|
964
|
+
nonAuthErrors.forEach((error) => {
|
|
965
|
+
const generator = OSAContentGenerator;
|
|
966
|
+
expect(generator.isAuthError(error)).toBe(false);
|
|
967
|
+
});
|
|
968
|
+
});
|
|
969
|
+
it('should handle complex error objects', () => {
|
|
970
|
+
const complexErrors = [
|
|
971
|
+
{ error: { status: 401, message: 'Unauthorized' } },
|
|
972
|
+
{ response: { status: 403 } },
|
|
973
|
+
{ details: { code: 401 } },
|
|
974
|
+
];
|
|
975
|
+
// These should not be identified as auth errors because the method only looks at top-level properties
|
|
976
|
+
complexErrors.forEach((error) => {
|
|
977
|
+
const generator = OSAContentGenerator;
|
|
978
|
+
expect(generator.isAuthError(error)).toBe(false);
|
|
979
|
+
});
|
|
980
|
+
});
|
|
981
|
+
});
|
|
982
|
+
describe('Stream Error Handling', () => {
|
|
983
|
+
it('should set credentials when stream generation fails', async () => {
|
|
984
|
+
const client = OSAContentGenerator.pipeline.client;
|
|
985
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
986
|
+
token: 'stream-token',
|
|
987
|
+
});
|
|
988
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue({
|
|
989
|
+
...mockCredentials,
|
|
990
|
+
access_token: 'stream-token',
|
|
991
|
+
resource_url: 'https://stream-endpoint.com',
|
|
992
|
+
});
|
|
993
|
+
// Mock parent method to throw error
|
|
994
|
+
const parentPrototype = Object.getPrototypeOf(Object.getPrototypeOf(OSAContentGenerator));
|
|
995
|
+
const originalGenerateContentStream = parentPrototype.generateContentStream;
|
|
996
|
+
parentPrototype.generateContentStream = vi
|
|
997
|
+
.fn()
|
|
998
|
+
.mockRejectedValue(new Error('Stream error'));
|
|
999
|
+
const request = {
|
|
1000
|
+
model: 'OSA-turbo',
|
|
1001
|
+
contents: [{ role: 'user', parts: [{ text: 'Stream test' }] }],
|
|
1002
|
+
};
|
|
1003
|
+
try {
|
|
1004
|
+
await generator.generateContentStream(request, 'test-prompt-id');
|
|
1005
|
+
}
|
|
1006
|
+
catch (error) {
|
|
1007
|
+
expect(error).toBeInstanceOf(Error);
|
|
1008
|
+
}
|
|
1009
|
+
// Credentials should be set before the error occurred
|
|
1010
|
+
expect(client.apiKey).toBe('stream-token');
|
|
1011
|
+
expect(client.baseURL).toBe('https://stream-endpoint.com/v1');
|
|
1012
|
+
// Restore original method
|
|
1013
|
+
parentPrototype.generateContentStream = originalGenerateContentStream;
|
|
1014
|
+
});
|
|
1015
|
+
it('should set credentials for successful streams', async () => {
|
|
1016
|
+
const client = OSAContentGenerator.pipeline.client;
|
|
1017
|
+
// Set up the mock to return stream credentials
|
|
1018
|
+
const streamCredentials = {
|
|
1019
|
+
access_token: 'stream-token',
|
|
1020
|
+
refresh_token: 'stream-refresh-token',
|
|
1021
|
+
resource_url: 'https://stream-endpoint.com',
|
|
1022
|
+
expiry_date: Date.now() + 3600000,
|
|
1023
|
+
};
|
|
1024
|
+
vi.mocked(mockOSAClient.getAccessToken).mockResolvedValue({
|
|
1025
|
+
token: 'stream-token',
|
|
1026
|
+
});
|
|
1027
|
+
vi.mocked(mockOSAClient.getCredentials).mockReturnValue(streamCredentials);
|
|
1028
|
+
// Set the SharedTokenManager mock to return stream credentials
|
|
1029
|
+
const mockTokenManager = SharedTokenManager.getInstance();
|
|
1030
|
+
mockTokenManager.setMockCredentials(streamCredentials);
|
|
1031
|
+
const request = {
|
|
1032
|
+
model: 'OSA-turbo',
|
|
1033
|
+
contents: [{ role: 'user', parts: [{ text: 'Stream test' }] }],
|
|
1034
|
+
};
|
|
1035
|
+
const stream = await generator.generateContentStream(request, 'test-prompt-id');
|
|
1036
|
+
// After successful stream creation, credentials should be set for the stream
|
|
1037
|
+
expect(client.apiKey).toBe('stream-token');
|
|
1038
|
+
expect(client.baseURL).toBe('https://stream-endpoint.com/v1');
|
|
1039
|
+
// Verify stream is iterable and consume it
|
|
1040
|
+
expect(stream).toBeDefined();
|
|
1041
|
+
const chunks = [];
|
|
1042
|
+
for await (const chunk of stream) {
|
|
1043
|
+
chunks.push(chunk);
|
|
1044
|
+
}
|
|
1045
|
+
expect(chunks).toHaveLength(2);
|
|
1046
|
+
// Clean up
|
|
1047
|
+
mockTokenManager.setMockCredentials(null);
|
|
1048
|
+
});
|
|
1049
|
+
});
|
|
1050
|
+
describe('Token and Endpoint Management', () => {
|
|
1051
|
+
it('should get current token from SharedTokenManager', () => {
|
|
1052
|
+
const mockTokenManager = {
|
|
1053
|
+
getCurrentCredentials: vi.fn().mockReturnValue({
|
|
1054
|
+
access_token: 'current-token',
|
|
1055
|
+
}),
|
|
1056
|
+
};
|
|
1057
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
1058
|
+
SharedTokenManager.getInstance = vi
|
|
1059
|
+
.fn()
|
|
1060
|
+
.mockReturnValue(mockTokenManager);
|
|
1061
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
1062
|
+
expect(newGenerator.getCurrentToken()).toBe('current-token');
|
|
1063
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
1064
|
+
});
|
|
1065
|
+
it('should return null when no credentials available', () => {
|
|
1066
|
+
const mockTokenManager = {
|
|
1067
|
+
getCurrentCredentials: vi.fn().mockReturnValue(null),
|
|
1068
|
+
};
|
|
1069
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
1070
|
+
SharedTokenManager.getInstance = vi
|
|
1071
|
+
.fn()
|
|
1072
|
+
.mockReturnValue(mockTokenManager);
|
|
1073
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
1074
|
+
expect(newGenerator.getCurrentToken()).toBeNull();
|
|
1075
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
1076
|
+
});
|
|
1077
|
+
it('should return null when credentials have no access token', () => {
|
|
1078
|
+
const mockTokenManager = {
|
|
1079
|
+
getCurrentCredentials: vi.fn().mockReturnValue({
|
|
1080
|
+
access_token: undefined,
|
|
1081
|
+
}),
|
|
1082
|
+
};
|
|
1083
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
1084
|
+
SharedTokenManager.getInstance = vi
|
|
1085
|
+
.fn()
|
|
1086
|
+
.mockReturnValue(mockTokenManager);
|
|
1087
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
1088
|
+
expect(newGenerator.getCurrentToken()).toBeNull();
|
|
1089
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
1090
|
+
});
|
|
1091
|
+
it('should clear token through SharedTokenManager', () => {
|
|
1092
|
+
const mockTokenManager = {
|
|
1093
|
+
clearCache: vi.fn(),
|
|
1094
|
+
};
|
|
1095
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
1096
|
+
SharedTokenManager.getInstance = vi
|
|
1097
|
+
.fn()
|
|
1098
|
+
.mockReturnValue(mockTokenManager);
|
|
1099
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
1100
|
+
newGenerator.clearToken();
|
|
1101
|
+
expect(mockTokenManager.clearCache).toHaveBeenCalled();
|
|
1102
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
1103
|
+
});
|
|
1104
|
+
});
|
|
1105
|
+
describe('Constructor and Initialization', () => {
|
|
1106
|
+
it('should initialize with configured base URL when provided', () => {
|
|
1107
|
+
const generator = new OSAContentGenerator(mockOSAClient, {
|
|
1108
|
+
model: 'OSA-turbo',
|
|
1109
|
+
authType: AuthType.OSA_OAUTH,
|
|
1110
|
+
baseUrl: 'https://dashscope.aliyuncs.com/compatible-mode/v1',
|
|
1111
|
+
apiKey: 'test-key',
|
|
1112
|
+
}, mockConfig);
|
|
1113
|
+
const client = generator.pipeline.client;
|
|
1114
|
+
expect(client.baseURL).toBe('https://dashscope.aliyuncs.com/compatible-mode/v1');
|
|
1115
|
+
});
|
|
1116
|
+
it('should get SharedTokenManager instance', () => {
|
|
1117
|
+
const generator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
1118
|
+
const sharedManager = generator.sharedManager;
|
|
1119
|
+
expect(sharedManager).toBeDefined();
|
|
1120
|
+
});
|
|
1121
|
+
});
|
|
1122
|
+
describe('Edge Cases and Error Conditions', () => {
|
|
1123
|
+
it('should handle token retrieval with warning when SharedTokenManager fails', async () => {
|
|
1124
|
+
const consoleSpy = vi.spyOn(console, 'warn').mockImplementation(() => { });
|
|
1125
|
+
const mockTokenManager = {
|
|
1126
|
+
getValidCredentials: vi
|
|
1127
|
+
.fn()
|
|
1128
|
+
.mockRejectedValue(new Error('Internal token manager error')),
|
|
1129
|
+
};
|
|
1130
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
1131
|
+
SharedTokenManager.getInstance = vi
|
|
1132
|
+
.fn()
|
|
1133
|
+
.mockReturnValue(mockTokenManager);
|
|
1134
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
1135
|
+
const request = {
|
|
1136
|
+
model: 'OSA-turbo',
|
|
1137
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
1138
|
+
};
|
|
1139
|
+
await expect(newGenerator.generateContent(request, 'test-prompt-id')).rejects.toThrow('Failed to obtain valid OSA access token');
|
|
1140
|
+
expect(consoleSpy).toHaveBeenCalledWith('Failed to get token from shared manager:', expect.any(Error));
|
|
1141
|
+
consoleSpy.mockRestore();
|
|
1142
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
1143
|
+
});
|
|
1144
|
+
it('should handle method types with token failure (except countTokens)', async () => {
|
|
1145
|
+
const mockTokenManager = {
|
|
1146
|
+
getValidCredentials: vi
|
|
1147
|
+
.fn()
|
|
1148
|
+
.mockRejectedValue(new Error('Token error')),
|
|
1149
|
+
};
|
|
1150
|
+
const originalGetInstance = SharedTokenManager.getInstance;
|
|
1151
|
+
SharedTokenManager.getInstance = vi
|
|
1152
|
+
.fn()
|
|
1153
|
+
.mockReturnValue(mockTokenManager);
|
|
1154
|
+
const newGenerator = new OSAContentGenerator(mockOSAClient, { model: 'OSA-turbo', authType: AuthType.OSA_OAUTH }, mockConfig);
|
|
1155
|
+
const generateRequest = {
|
|
1156
|
+
model: 'OSA-turbo',
|
|
1157
|
+
contents: [{ role: 'user', parts: [{ text: 'Hello' }] }],
|
|
1158
|
+
};
|
|
1159
|
+
const countRequest = {
|
|
1160
|
+
model: 'OSA-turbo',
|
|
1161
|
+
contents: [{ role: 'user', parts: [{ text: 'Count' }] }],
|
|
1162
|
+
};
|
|
1163
|
+
const embedRequest = {
|
|
1164
|
+
model: 'OSA-turbo',
|
|
1165
|
+
contents: [{ parts: [{ text: 'Embed' }] }],
|
|
1166
|
+
};
|
|
1167
|
+
// Methods requiring authentication should fail
|
|
1168
|
+
await expect(newGenerator.generateContent(generateRequest, 'test-id')).rejects.toThrow('Failed to obtain valid OSA access token');
|
|
1169
|
+
await expect(newGenerator.generateContentStream(generateRequest, 'test-id')).rejects.toThrow('Failed to obtain valid OSA access token');
|
|
1170
|
+
await expect(newGenerator.embedContent(embedRequest)).rejects.toThrow('Failed to obtain valid OSA access token');
|
|
1171
|
+
// countTokens should succeed as it's a local operation
|
|
1172
|
+
const countResult = await newGenerator.countTokens(countRequest);
|
|
1173
|
+
expect(countResult.totalTokens).toBe(15);
|
|
1174
|
+
SharedTokenManager.getInstance = originalGetInstance;
|
|
1175
|
+
});
|
|
1176
|
+
});
|
|
1177
|
+
});
|
|
1178
|
+
//# sourceMappingURL=qwenContentGenerator.test.js.map
|