mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-21 21:50:49 +02:00

* feat: MCP Connection management overhaul - Making MCPManager manageable Refactor the monolithic MCPManager into focused, single-responsibility classes: • MCPServersRegistry: Server configuration discovery and metadata management • UserConnectionManager: Manages user-level connections • ConnectionsRepository: Low-level connection pool with lazy loading • MCPConnectionFactory: Handles MCP connection creation with OAuth support New Features: • Lazy loading of app-level connections for horizontal scaling • Automatic reconnection for app-level connections • Enhanced OAuth detection with explicit requiresOAuth flag • Centralized MCP configuration management Bug Fixes: • App-level connection detection in MCPManager.callTool • MCP Connection Reinitialization route behavior Optimizations: • MCPConnection.isConnected() caching to reduce overhead • Concurrent server metadata retrieval instead of sequential This refactoring addresses scalability bottlenecks and improves reliability while maintaining backward compatibility with existing configurations. * feat: Enabled import order in eslint. * # Moved tests to __tests__ folder # added tests for MCPServersRegistry.ts * # Add unit tests for ConnectionsRepository functionality * # Add unit tests for MCPConnectionFactory functionality * # Reorganize MCP connection tests and improve error handling * # reordering imports * # Update testPathIgnorePatterns in jest.config.mjs to exclude development TypeScript files * # removed mcp/manager.ts
76 lines
2.2 KiB
TypeScript
76 lines
2.2 KiB
TypeScript
// Integration tests for OAuth detection against real public MCP servers
|
|
// These tests verify the actual behavior against live endpoints
|
|
//
|
|
// DEVELOPMENT ONLY: This file is excluded from the test suite (.dev.ts extension)
|
|
// Use this for development and debugging OAuth detection behavior
|
|
//
|
|
// To run manually from packages/api directory:
|
|
// npx jest --testMatch="**/detectOAuth.integration.dev.ts"
|
|
|
|
import { detectOAuthRequirement } from '~/mcp/oauth';
|
|
|
|
describe('OAuth Detection Integration Tests', () => {
|
|
const NETWORK_TIMEOUT = 10000;
|
|
|
|
interface TestServer {
|
|
name: string;
|
|
url: string;
|
|
expectedOAuth: boolean;
|
|
expectedMethod: string;
|
|
withMeta: boolean;
|
|
}
|
|
|
|
const testServers: TestServer[] = [
|
|
{
|
|
name: 'GitHub Copilot MCP Server',
|
|
url: 'https://api.githubcopilot.com/mcp',
|
|
expectedOAuth: true,
|
|
expectedMethod: '401-challenge-metadata',
|
|
withMeta: true,
|
|
},
|
|
{
|
|
name: 'GitHub API (401 without metadata)',
|
|
url: 'https://api.github.com/user',
|
|
expectedOAuth: true,
|
|
expectedMethod: 'no-metadata-found',
|
|
withMeta: false,
|
|
},
|
|
{
|
|
name: 'Stytch Todo MCP Server',
|
|
url: 'https://mcp-stytch-consumer-todo-list.maxwell-gerber42.workers.dev',
|
|
expectedOAuth: true,
|
|
expectedMethod: 'protected-resource-metadata',
|
|
withMeta: true,
|
|
},
|
|
{
|
|
name: 'HTTPBin (Non-OAuth)',
|
|
url: 'https://httpbin.org',
|
|
expectedOAuth: false,
|
|
expectedMethod: 'no-metadata-found',
|
|
withMeta: false,
|
|
},
|
|
{
|
|
name: 'Unreachable Server',
|
|
url: 'https://definitely-not-a-real-server-12345.com',
|
|
expectedOAuth: false,
|
|
expectedMethod: 'no-metadata-found',
|
|
withMeta: false,
|
|
},
|
|
];
|
|
|
|
describe('detectOAuthRequirement integration', () => {
|
|
testServers.forEach((server) => {
|
|
it(
|
|
`should handle ${server.name}`,
|
|
async () => {
|
|
const result = await detectOAuthRequirement(server.url);
|
|
|
|
expect(result.requiresOAuth).toBe(server.expectedOAuth);
|
|
expect(result.method).toBe(server.expectedMethod);
|
|
expect(result.metadata == null).toBe(!server.withMeta);
|
|
},
|
|
NETWORK_TIMEOUT,
|
|
);
|
|
});
|
|
});
|
|
});
|