Skip to main content
Glama
test-rapid-debug.js•3.9 kB
#!/usr/bin/env node // Test the rapid debugging feature import { RapidDebugger } from './dist/src/tools/rapidDebugger.js'; import dotenv from 'dotenv'; dotenv.config(); console.log('šŸš€ Testing Rapid Debug - Target: Under 30 Seconds\n'); // Sample server log with multiple issues const serverLog = ` 2024-01-23 14:32:15 [INFO] Server starting up... 2024-01-23 14:32:16 [ERROR] Database connection failed: Connection timed out after 30000ms java.sql.SQLException: Connection is not available, request timed out after 30000ms. at org.apache.commons.dbcp2.PoolingDataSource.getConnection(PoolingDataSource.java:154) at com.app.service.DatabaseService.connect(DatabaseService.java:45) 2024-01-23 14:32:17 [ERROR] Authentication failed for user 'admin' from IP 192.168.1.100 2024-01-23 14:32:18 [FATAL] OutOfMemoryError: Java heap space java.lang.OutOfMemoryError: Java heap space at java.util.ArrayList.grow(ArrayList.java:275) at com.app.processor.DataProcessor.loadData(DataProcessor.java:123) 2024-01-23 14:32:19 [ERROR] Network timeout: Connection refused to api.external.com:443 2024-01-23 14:32:20 [ERROR] Configuration error: Unable to load /etc/app/config.yaml 2024-01-23 14:32:21 [CRITICAL] Application shutdown initiated due to critical errors `; async function testRapidDebug() { console.log('šŸ“Š Starting rapid debug analysis...'); console.log('====================================='); try { const rapidDebugger = new RapidDebugger(); const startTime = Date.now(); // Test rapid debugging const result = await rapidDebugger.debugInUnder30Seconds(serverLog); const totalTime = Date.now() - startTime; console.log(`ā±ļø Total Analysis Time: ${result.timeToAnalysis}ms`); console.log(`šŸŽÆ Target Met: ${result.timeToAnalysis < 30000 ? 'āœ… YES' : 'āŒ NO'} (under 30 seconds)`); console.log('\n🚨 CRITICAL ERRORS DETECTED:'); result.criticalErrors.forEach((error, i) => { console.log(` ${i + 1}. ${error}`); }); console.log(`\nšŸŽÆ ROOT CAUSE: ${result.rootCause}`); console.log(`šŸ“Š AI Confidence: ${result.confidence}%`); console.log('\nšŸ”§ QUICK FIXES (Priority Order):'); result.quickFixes .sort((a, b) => a.priority === 'high' ? -1 : 1) .forEach((fix, i) => { console.log(` ${i + 1}. [${fix.priority.toUpperCase()}] ${fix.issue}`); console.log(` Fix: ${fix.fix}`); if (fix.command) { console.log(` Command: ${fix.command}`); } console.log(` Time: ${fix.estimatedTime}\n`); }); console.log('⚔ READY-TO-RUN DEBUG COMMANDS:'); console.log('================================'); result.debugCommands.forEach(cmd => { console.log(cmd); }); console.log('\nšŸ“‹ NEXT STEPS:'); result.nextSteps.forEach((step, i) => { console.log(` ${i + 1}. ${step}`); }); console.log('\nšŸŽ‰ RAPID DEBUG SUMMARY:'); console.log('======================='); console.log(`āœ… Analysis completed in ${result.timeToAnalysis}ms`); console.log(`āœ… Found ${result.criticalErrors.length} critical issues`); console.log(`āœ… Generated ${result.quickFixes.length} actionable fixes`); console.log(`āœ… Provided ${result.debugCommands.length} debug commands`); console.log(`āœ… AI confidence: ${result.confidence}%`); // Test quick scan console.log('\n⚔ Testing Quick Scan...'); const quickStart = Date.now(); const scanResult = await rapidDebugger.quickScan(serverLog); const scanTime = Date.now() - quickStart; console.log(`⚔ Quick scan: ${scanResult.errors} errors found in ${scanResult.time}ms`); console.log(`🚨 Critical status: ${scanResult.critical ? 'YES' : 'NO'}`); } catch (error) { console.error('āŒ Rapid debug test failed:', error.message); } } testRapidDebug();

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/ChiragPatankar/loganalyzer-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server