Files
hive/scripts/test-mcp-integration.js
anthonyrawlins 6933a6ccb1 Add CCLI (CLI agent integration) complete implementation
- Complete Gemini CLI agent adapter with SSH execution
- CLI agent factory with connection pooling
- SSH executor with AsyncSSH for remote CLI execution
- Backend integration with CLI agent manager
- MCP server updates with CLI agent tools
- Frontend UI updates for mixed agent types
- Database migrations for CLI agent support
- Docker deployment with CLI source integration
- Comprehensive documentation and testing

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-10 12:45:43 +10:00

110 lines
4.0 KiB
JavaScript

#!/usr/bin/env node
/**
* Test MCP Server CLI Agent Integration
*/
const { HiveClient } = require('../../mcp-server/dist/hive-client.js');
const { HiveTools } = require('../../mcp-server/dist/hive-tools.js');
async function testMCPIntegration() {
console.log('🧪 Testing MCP Server CLI Agent Integration...\n');
try {
// Initialize Hive client
const hiveClient = new HiveClient({
baseUrl: 'https://hive.home.deepblack.cloud/api',
wsUrl: 'wss://hive.home.deepblack.cloud/socket.io',
timeout: 15000
});
console.log('✅ HiveClient initialized');
// Test connection
try {
await hiveClient.testConnection();
console.log('✅ Connection to Hive backend successful');
} catch (error) {
console.log('⚠️ Connection test failed (backend may be offline):', error.message);
console.log(' Continuing with tool definition tests...\n');
}
// Initialize tools
const hiveTools = new HiveTools(hiveClient);
console.log('✅ HiveTools initialized');
// Test tool definitions
const tools = hiveTools.getAllTools();
console.log(`✅ Loaded ${tools.length} MCP tools\n`);
// Check for CLI agent tools
const cliTools = tools.filter(tool =>
tool.name.includes('cli') ||
tool.name.includes('predefined')
);
console.log('🔍 CLI Agent Tools Available:');
cliTools.forEach(tool => {
console.log(`${tool.name}: ${tool.description}`);
});
// Test tool schema validation
const registerCliTool = tools.find(t => t.name === 'hive_register_cli_agent');
if (registerCliTool) {
console.log('\n✅ hive_register_cli_agent tool found');
console.log(' Required fields:', registerCliTool.inputSchema.required);
const properties = registerCliTool.inputSchema.properties;
if (properties.host && properties.node_version && properties.specialization) {
console.log('✅ CLI agent tool schema validated');
} else {
console.log('❌ CLI agent tool schema missing required properties');
}
} else {
console.log('❌ hive_register_cli_agent tool not found');
}
// Test agent enumeration
const agentEnums = tools
.filter(t => t.inputSchema.properties &&
(t.inputSchema.properties.specialization ||
t.inputSchema.properties.type))
.map(t => {
const spec = t.inputSchema.properties.specialization;
const type = t.inputSchema.properties.type;
return { tool: t.name, enum: spec?.enum || type?.enum };
})
.filter(t => t.enum);
console.log('\n🔍 Agent Type Enumerations:');
agentEnums.forEach(({ tool, enum: enumValues }) => {
const cliTypes = enumValues.filter(e =>
e.includes('cli') || e.includes('general') || e.includes('reasoning')
);
if (cliTypes.length > 0) {
console.log(`${tool}: includes CLI types [${cliTypes.join(', ')}]`);
}
});
console.log('\n🎉 MCP Integration Test Complete!');
console.log('✅ CLI agent tools are properly integrated');
console.log('✅ Schema validation passed');
console.log('✅ Mixed agent type support confirmed');
return true;
} catch (error) {
console.error('❌ MCP Integration test failed:', error.message);
return false;
}
}
// Run the test
testMCPIntegration()
.then(success => {
process.exit(success ? 0 : 1);
})
.catch(error => {
console.error('❌ Test execution failed:', error);
process.exit(1);
});