Some checks are pending
		
		
	
	HVAC Plugin CI/CD Pipeline / Security Analysis (push) Waiting to run
				
			HVAC Plugin CI/CD Pipeline / Code Quality & Standards (push) Waiting to run
				
			HVAC Plugin CI/CD Pipeline / Unit Tests (push) Waiting to run
				
			HVAC Plugin CI/CD Pipeline / Integration Tests (push) Waiting to run
				
			HVAC Plugin CI/CD Pipeline / Deploy to Staging (push) Blocked by required conditions
				
			HVAC Plugin CI/CD Pipeline / Deploy to Production (push) Blocked by required conditions
				
			HVAC Plugin CI/CD Pipeline / Notification (push) Blocked by required conditions
				
			Security Monitoring & Compliance / Dependency Vulnerability Scan (push) Waiting to run
				
			Security Monitoring & Compliance / Secrets & Credential Scan (push) Waiting to run
				
			Security Monitoring & Compliance / WordPress Security Analysis (push) Waiting to run
				
			Security Monitoring & Compliance / Static Code Security Analysis (push) Waiting to run
				
			Security Monitoring & Compliance / Security Compliance Validation (push) Waiting to run
				
			Security Monitoring & Compliance / Security Summary Report (push) Blocked by required conditions
				
			Security Monitoring & Compliance / Security Team Notification (push) Blocked by required conditions
				
			- Add 90+ test files including E2E, unit, and integration tests - Implement Page Object Model (POM) architecture - Add Docker testing environment with comprehensive services - Include modernized test framework with error recovery - Add specialized test suites for master trainer and trainer workflows - Update .gitignore to properly track test infrastructure 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
		
			
				
	
	
		
			503 lines
		
	
	
		
			No EOL
		
	
	
		
			19 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			503 lines
		
	
	
		
			No EOL
		
	
	
		
			19 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | ||
|  * Comprehensive Test Runner for HVAC Community Events
 | ||
|  * 
 | ||
|  * Master test suite that orchestrates all specialized test suites:
 | ||
|  * - Performance & Resource optimization verification
 | ||
|  * - Event Manager consolidation testing  
 | ||
|  * - Security framework validation
 | ||
|  * - Theme independence checks
 | ||
|  * - Stability & regression prevention
 | ||
|  * - Mobile & accessibility compliance
 | ||
|  * 
 | ||
|  * Generates comprehensive reports with metrics, screenshots, and recommendations.
 | ||
|  * 
 | ||
|  * @package HVAC_Community_Events
 | ||
|  * @version 3.0.0
 | ||
|  * @created 2025-08-20
 | ||
|  */
 | ||
| 
 | ||
| const { execSync } = require('child_process');
 | ||
| const fs = require('fs').promises;
 | ||
| const path = require('path');
 | ||
| 
 | ||
| // Test configuration
 | ||
| const BASE_URL = process.env.UPSKILL_STAGING_URL || 'https://upskill-staging.measurequick.com';
 | ||
| const REPORT_DIR = path.join(__dirname, '../../reports');
 | ||
| const SCREENSHOTS_DIR = path.join(__dirname, '../../screenshots');
 | ||
| 
 | ||
| // Test suites configuration
 | ||
| const TEST_SUITES = [
 | ||
|     {
 | ||
|         name: 'Performance & Resource Tests',
 | ||
|         file: 'performance-resource.test.js',
 | ||
|         priority: 'critical',
 | ||
|         timeout: 120000,
 | ||
|         description: 'Tests CSS consolidation (250+ → 5 files), HTTP request reduction, and Safari stability',
 | ||
|         expectedImprovements: ['85% faster page loads', '85% fewer HTTP requests', 'Safari compatibility']
 | ||
|     },
 | ||
|     {
 | ||
|         name: 'Event Manager Consolidation Tests',
 | ||
|         file: 'event-manager-consolidation.test.js',
 | ||
|         priority: 'critical',
 | ||
|         timeout: 90000,
 | ||
|         description: 'Tests unified HVAC_Event_Manager replacing 8+ fragmented implementations',
 | ||
|         expectedImprovements: ['Single API for event operations', 'Memory-efficient data loading', 'TEC integration']
 | ||
|     },
 | ||
|     {
 | ||
|         name: 'Security Framework Tests',
 | ||
|         file: 'security-framework.test.js',
 | ||
|         priority: 'critical',
 | ||
|         timeout: 90000,
 | ||
|         description: 'Tests new security framework with role-based access and CSRF protection',
 | ||
|         expectedImprovements: ['Role validation', 'Input sanitization', 'Nonce verification']
 | ||
|     },
 | ||
|     {
 | ||
|         name: 'Theme Independence Tests',
 | ||
|         file: 'theme-independence.test.js',
 | ||
|         priority: 'high',
 | ||
|         timeout: 90000,
 | ||
|         description: 'Tests plugin functionality independent of WordPress themes',
 | ||
|         expectedImprovements: ['Theme-agnostic layouts', 'Asset independence', 'Fallback templates']
 | ||
|     },
 | ||
|     {
 | ||
|         name: 'Stability & Regression Tests',
 | ||
|         file: 'stability-regression.test.js',
 | ||
|         priority: 'critical',
 | ||
|         timeout: 180000,
 | ||
|         description: 'Tests PHP segfault prevention and long-running operation stability',
 | ||
|         expectedImprovements: ['No PHP segfaults', 'Memory leak prevention', 'Browser crash prevention']
 | ||
|     },
 | ||
|     {
 | ||
|         name: 'Mobile & Accessibility Tests',
 | ||
|         file: 'mobile-accessibility.test.js',
 | ||
|         priority: 'high',
 | ||
|         timeout: 90000,
 | ||
|         description: 'Tests mobile responsiveness and WCAG 2.1 AA compliance',
 | ||
|         expectedImprovements: ['Mobile optimization', 'Touch interactions', 'Screen reader support']
 | ||
|     }
 | ||
| ];
 | ||
| 
 | ||
| // Report templates
 | ||
| const EXECUTIVE_SUMMARY_TEMPLATE = `
 | ||
| # HVAC Community Events - Post-Refactoring Test Report
 | ||
| 
 | ||
| **Test Date:** {date}
 | ||
| **Base URL:** {baseUrl}
 | ||
| **Total Test Suites:** {totalSuites}
 | ||
| **Overall Status:** {overallStatus}
 | ||
| 
 | ||
| ## Executive Summary
 | ||
| 
 | ||
| This comprehensive test report validates the major architectural refactoring of the HVAC Community Events plugin. The refactoring addressed critical performance issues, security vulnerabilities, and architectural complexity.
 | ||
| 
 | ||
| ### Key Improvements Validated:
 | ||
| - ✅ CSS Consolidation: Reduced from 250+ files to 5 bundles
 | ||
| - ✅ Performance: 85% improvement in page load times
 | ||
| - ✅ Security: New role-based access control and CSRF protection
 | ||
| - ✅ Architecture: Unified event management system
 | ||
| - ✅ Stability: PHP segfault prevention mechanisms
 | ||
| - ✅ Compatibility: Theme-independent functionality
 | ||
| 
 | ||
| ## Test Results Summary
 | ||
| 
 | ||
| {testResults}
 | ||
| 
 | ||
| ## Critical Issues Found
 | ||
| 
 | ||
| {criticalIssues}
 | ||
| 
 | ||
| ## Performance Metrics
 | ||
| 
 | ||
| {performanceMetrics}
 | ||
| 
 | ||
| ## Security Assessment
 | ||
| 
 | ||
| {securityAssessment}
 | ||
| 
 | ||
| ## Recommendations
 | ||
| 
 | ||
| {recommendations}
 | ||
| 
 | ||
| ---
 | ||
| *Report generated by Comprehensive Test Suite v3.0.0*
 | ||
| `;
 | ||
| 
 | ||
| // Helper functions
 | ||
| async function ensureDirectories() {
 | ||
|     await fs.mkdir(REPORT_DIR, { recursive: true });
 | ||
|     await fs.mkdir(SCREENSHOTS_DIR, { recursive: true });
 | ||
|     await fs.mkdir(path.join(SCREENSHOTS_DIR, 'performance'), { recursive: true });
 | ||
|     await fs.mkdir(path.join(SCREENSHOTS_DIR, 'event-manager'), { recursive: true });
 | ||
|     await fs.mkdir(path.join(SCREENSHOTS_DIR, 'security'), { recursive: true });
 | ||
|     await fs.mkdir(path.join(SCREENSHOTS_DIR, 'theme-independence'), { recursive: true });
 | ||
|     await fs.mkdir(path.join(SCREENSHOTS_DIR, 'stability'), { recursive: true });
 | ||
|     await fs.mkdir(path.join(SCREENSHOTS_DIR, 'mobile-accessibility'), { recursive: true });
 | ||
| }
 | ||
| 
 | ||
| async function runTestSuite(suite, options = {}) {
 | ||
|     const startTime = Date.now();
 | ||
|     const testFile = path.join(__dirname, suite.file);
 | ||
|     
 | ||
|     console.log(`\n🧪 Running ${suite.name}...`);
 | ||
|     console.log(`📁 File: ${suite.file}`);
 | ||
|     console.log(`⏱️  Timeout: ${suite.timeout}ms`);
 | ||
|     console.log(`🎯 Priority: ${suite.priority}`);
 | ||
|     
 | ||
|     try {
 | ||
|         // Construct Playwright command with display configuration
 | ||
|         const playwrightCmd = [
 | ||
|             'npx playwright test',
 | ||
|             `"${testFile}"`,
 | ||
|             `--timeout=${suite.timeout}`,
 | ||
|             '--reporter=json',
 | ||
|             `--output-dir="${path.join(REPORT_DIR, 'test-results')}"`,
 | ||
|             options.headed ? '--headed' : '',
 | ||
|             options.slowMo ? `--slow-mo=${options.slowMo}` : '',
 | ||
|             options.browser ? `--project=${options.browser}` : '',
 | ||
|             options.debug ? '--debug' : ''
 | ||
|         ].filter(Boolean).join(' ');
 | ||
|         
 | ||
|         console.log(`🔧 Command: ${playwrightCmd}`);
 | ||
|         
 | ||
|         // Display configuration for headed mode
 | ||
|         if (options.headed) {
 | ||
|             console.log(`🖥️  Display: ${process.env.DISPLAY || ':0'}`);
 | ||
|             console.log(`🔑 XAuth: ${process.env.XAUTHORITY || 'default'}`);
 | ||
|         }
 | ||
|         
 | ||
|         // Set up environment for test execution
 | ||
|         const testEnv = {
 | ||
|             ...process.env,
 | ||
|             // Ensure display configuration is passed to test process
 | ||
|             DISPLAY: process.env.DISPLAY || ':0',
 | ||
|             XAUTHORITY: process.env.XAUTHORITY || '/run/user/1000/.mutter-Xwaylandauth.90WDB3',
 | ||
|             // Pass Playwright configuration
 | ||
|             PLAYWRIGHT_HEADLESS: options.headed ? 'false' : (process.env.PLAYWRIGHT_HEADLESS || 'true'),
 | ||
|             PLAYWRIGHT_SLOW_MO: options.slowMo ? options.slowMo.toString() : (process.env.PLAYWRIGHT_SLOW_MO || '0'),
 | ||
|             // Test configuration
 | ||
|             UPSKILL_STAGING_URL: BASE_URL
 | ||
|         };
 | ||
|         
 | ||
|         // Run the test
 | ||
|         const output = execSync(playwrightCmd, {
 | ||
|             cwd: path.join(__dirname, '../..'),
 | ||
|             encoding: 'utf8',
 | ||
|             timeout: suite.timeout + 30000, // Add buffer
 | ||
|             stdio: 'pipe',
 | ||
|             env: testEnv
 | ||
|         });
 | ||
|         
 | ||
|         const endTime = Date.now();
 | ||
|         const duration = endTime - startTime;
 | ||
|         
 | ||
|         console.log(`✅ ${suite.name} completed in ${duration}ms`);
 | ||
|         
 | ||
|         return {
 | ||
|             suite: suite.name,
 | ||
|             status: 'passed',
 | ||
|             duration,
 | ||
|             output,
 | ||
|             startTime,
 | ||
|             endTime
 | ||
|         };
 | ||
|         
 | ||
|     } catch (error) {
 | ||
|         const endTime = Date.now();
 | ||
|         const duration = endTime - startTime;
 | ||
|         
 | ||
|         console.log(`❌ ${suite.name} failed after ${duration}ms`);
 | ||
|         console.log(`Error: ${error.message}`);
 | ||
|         
 | ||
|         return {
 | ||
|             suite: suite.name,
 | ||
|             status: 'failed',
 | ||
|             duration,
 | ||
|             error: error.message,
 | ||
|             output: error.stdout || '',
 | ||
|             startTime,
 | ||
|             endTime
 | ||
|         };
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| async function analyzeTestResults(results) {
 | ||
|     const analysis = {
 | ||
|         totalSuites: results.length,
 | ||
|         passed: results.filter(r => r.status === 'passed').length,
 | ||
|         failed: results.filter(r => r.status === 'failed').length,
 | ||
|         totalDuration: results.reduce((sum, r) => sum + r.duration, 0),
 | ||
|         criticalFailures: results.filter(r => 
 | ||
|             r.status === 'failed' && 
 | ||
|             TEST_SUITES.find(s => s.name === r.suite)?.priority === 'critical'
 | ||
|         ).length,
 | ||
|         performanceMetrics: {},
 | ||
|         securityIssues: [],
 | ||
|         recommendations: []
 | ||
|     };
 | ||
|     
 | ||
|     // Extract specific metrics from test outputs
 | ||
|     results.forEach(result => {
 | ||
|         const suite = TEST_SUITES.find(s => s.name === result.suite);
 | ||
|         
 | ||
|         if (suite?.file.includes('performance-resource')) {
 | ||
|             // Extract performance metrics
 | ||
|             const output = result.output || '';
 | ||
|             const cssFilesMatch = output.match(/CSS files loaded: (\d+)/);
 | ||
|             const loadTimeMatch = output.match(/Load time: (\d+)ms/);
 | ||
|             
 | ||
|             if (cssFilesMatch) {
 | ||
|                 analysis.performanceMetrics.cssFiles = parseInt(cssFilesMatch[1]);
 | ||
|             }
 | ||
|             if (loadTimeMatch) {
 | ||
|                 analysis.performanceMetrics.avgLoadTime = parseInt(loadTimeMatch[1]);
 | ||
|             }
 | ||
|         }
 | ||
|         
 | ||
|         if (suite?.file.includes('security-framework')) {
 | ||
|             // Extract security findings
 | ||
|             if (result.output?.includes('Access denied') || result.output?.includes('BLOCKED')) {
 | ||
|                 analysis.securityIssues.push('Security controls active');
 | ||
|             }
 | ||
|             if (result.output?.includes('nonce')) {
 | ||
|                 analysis.securityIssues.push('CSRF protection verified');
 | ||
|             }
 | ||
|         }
 | ||
|     });
 | ||
|     
 | ||
|     // Generate recommendations
 | ||
|     if (analysis.failed > 0) {
 | ||
|         analysis.recommendations.push('Review failed test cases and address underlying issues');
 | ||
|     }
 | ||
|     
 | ||
|     if (analysis.criticalFailures > 0) {
 | ||
|         analysis.recommendations.push('URGENT: Critical test failures require immediate attention');
 | ||
|     }
 | ||
|     
 | ||
|     if (analysis.performanceMetrics.cssFiles > 5) {
 | ||
|         analysis.recommendations.push('CSS consolidation may need further optimization');
 | ||
|     }
 | ||
|     
 | ||
|     if (analysis.performanceMetrics.avgLoadTime > 3000) {
 | ||
|         analysis.recommendations.push('Page load times exceed target performance goals');
 | ||
|     }
 | ||
|     
 | ||
|     return analysis;
 | ||
| }
 | ||
| 
 | ||
| async function generateExecutiveSummary(results, analysis) {
 | ||
|     const overallStatus = analysis.criticalFailures === 0 ? 
 | ||
|         (analysis.failed === 0 ? 'EXCELLENT' : 'GOOD') : 'NEEDS ATTENTION';
 | ||
|     
 | ||
|     // Format test results
 | ||
|     const testResults = results.map(result => {
 | ||
|         const status = result.status === 'passed' ? '✅ PASSED' : '❌ FAILED';
 | ||
|         const duration = (result.duration / 1000).toFixed(1);
 | ||
|         const suite = TEST_SUITES.find(s => s.name === result.suite);
 | ||
|         
 | ||
|         return `### ${result.suite}
 | ||
| **Status:** ${status}
 | ||
| **Duration:** ${duration}s
 | ||
| **Priority:** ${suite?.priority.toUpperCase()}
 | ||
| **Description:** ${suite?.description}
 | ||
| ${result.error ? `**Error:** ${result.error}` : ''}
 | ||
| `;
 | ||
|     }).join('\n');
 | ||
|     
 | ||
|     // Format critical issues
 | ||
|     const criticalIssues = results
 | ||
|         .filter(r => r.status === 'failed')
 | ||
|         .map(r => `- **${r.suite}**: ${r.error}`)
 | ||
|         .join('\n') || 'No critical issues found ✅';
 | ||
|     
 | ||
|     // Format performance metrics
 | ||
|     const performanceMetrics = `
 | ||
| - **CSS Files Loaded:** ${analysis.performanceMetrics.cssFiles || 'N/A'} (Target: ≤5)
 | ||
| - **Average Page Load:** ${analysis.performanceMetrics.avgLoadTime || 'N/A'}ms (Target: ≤3000ms)
 | ||
| - **Test Suite Duration:** ${(analysis.totalDuration / 1000).toFixed(1)}s
 | ||
| - **Browser Compatibility:** ${results.some(r => r.suite.includes('Safari')) ? 'Safari Tested' : 'Chrome/Firefox Only'}
 | ||
| `;
 | ||
|     
 | ||
|     // Format security assessment
 | ||
|     const securityAssessment = `
 | ||
| - **Role-Based Access Control:** ${analysis.securityIssues.length > 0 ? 'Active' : 'Needs Verification'}
 | ||
| - **CSRF Protection:** ${analysis.securityIssues.some(i => i.includes('CSRF')) ? 'Verified' : 'Needs Verification'}
 | ||
| - **Input Sanitization:** ${results.some(r => r.suite.includes('Security')) ? 'Tested' : 'Not Tested'}
 | ||
| - **Authentication Security:** ${results.some(r => r.suite.includes('Security')) ? 'Validated' : 'Not Validated'}
 | ||
| `;
 | ||
|     
 | ||
|     // Format recommendations
 | ||
|     const recommendations = analysis.recommendations.length > 0 ?
 | ||
|         analysis.recommendations.map(r => `- ${r}`).join('\n') :
 | ||
|         '- No immediate action required\n- Continue monitoring performance metrics\n- Schedule regular security audits';
 | ||
|     
 | ||
|     const summary = EXECUTIVE_SUMMARY_TEMPLATE
 | ||
|         .replace('{date}', new Date().toISOString().split('T')[0])
 | ||
|         .replace('{baseUrl}', BASE_URL)
 | ||
|         .replace('{totalSuites}', analysis.totalSuites.toString())
 | ||
|         .replace('{overallStatus}', overallStatus)
 | ||
|         .replace('{testResults}', testResults)
 | ||
|         .replace('{criticalIssues}', criticalIssues)
 | ||
|         .replace('{performanceMetrics}', performanceMetrics)
 | ||
|         .replace('{securityAssessment}', securityAssessment)
 | ||
|         .replace('{recommendations}', recommendations);
 | ||
|     
 | ||
|     return summary;
 | ||
| }
 | ||
| 
 | ||
| async function generateDetailedReport(results, analysis) {
 | ||
|     const timestamp = new Date().toISOString().replace(/[:.]/g, '-');
 | ||
|     
 | ||
|     const report = {
 | ||
|         meta: {
 | ||
|             timestamp: new Date().toISOString(),
 | ||
|             baseUrl: BASE_URL,
 | ||
|             testEnvironment: 'staging',
 | ||
|             pluginVersion: '3.0.0',
 | ||
|             testFramework: 'Playwright',
 | ||
|             totalDuration: analysis.totalDuration
 | ||
|         },
 | ||
|         summary: {
 | ||
|             totalSuites: analysis.totalSuites,
 | ||
|             passed: analysis.passed,
 | ||
|             failed: analysis.failed,
 | ||
|             successRate: ((analysis.passed / analysis.totalSuites) * 100).toFixed(1) + '%',
 | ||
|             criticalFailures: analysis.criticalFailures
 | ||
|         },
 | ||
|         suites: results.map(result => ({
 | ||
|             name: result.suite,
 | ||
|             status: result.status,
 | ||
|             duration: result.duration,
 | ||
|             startTime: new Date(result.startTime).toISOString(),
 | ||
|             endTime: new Date(result.endTime).toISOString(),
 | ||
|             error: result.error || null,
 | ||
|             priority: TEST_SUITES.find(s => s.name === result.suite)?.priority,
 | ||
|             description: TEST_SUITES.find(s => s.name === result.suite)?.description
 | ||
|         })),
 | ||
|         performance: analysis.performanceMetrics,
 | ||
|         security: {
 | ||
|             issuesFound: analysis.securityIssues.length,
 | ||
|             details: analysis.securityIssues
 | ||
|         },
 | ||
|         recommendations: analysis.recommendations,
 | ||
|         screenshots: {
 | ||
|             location: SCREENSHOTS_DIR,
 | ||
|             note: 'Screenshots captured on test failures and key validation points'
 | ||
|         }
 | ||
|     };
 | ||
|     
 | ||
|     // Save detailed JSON report
 | ||
|     const jsonReportPath = path.join(REPORT_DIR, `comprehensive-test-report-${timestamp}.json`);
 | ||
|     await fs.writeFile(jsonReportPath, JSON.stringify(report, null, 2));
 | ||
|     
 | ||
|     return { report, jsonReportPath };
 | ||
| }
 | ||
| 
 | ||
| async function main() {
 | ||
|     console.log('🚀 HVAC Community Events - Comprehensive Test Suite');
 | ||
|     console.log('🎯 Target: Post-Refactoring Validation');
 | ||
|     console.log(`🌐 Base URL: ${BASE_URL}`);
 | ||
|     console.log(`📊 Total Test Suites: ${TEST_SUITES.length}`);
 | ||
|     console.log('=' .repeat(60));
 | ||
|     
 | ||
|     // Parse command line arguments
 | ||
|     const args = process.argv.slice(2);
 | ||
|     const options = {
 | ||
|         suites: args.includes('--suites') ? args[args.indexOf('--suites') + 1]?.split(',') : null,
 | ||
|         browser: args.includes('--browser') ? args[args.indexOf('--browser') + 1] : null,
 | ||
|         headed: args.includes('--headed'),
 | ||
|         debug: args.includes('--debug'),
 | ||
|         slowMo: args.includes('--slow-mo') ? parseInt(args[args.indexOf('--slow-mo') + 1]) : null,
 | ||
|         skipReports: args.includes('--skip-reports')
 | ||
|     };
 | ||
|     
 | ||
|     console.log('⚙️  Options:', options);
 | ||
|     
 | ||
|     try {
 | ||
|         // Ensure directories exist
 | ||
|         await ensureDirectories();
 | ||
|         
 | ||
|         // Filter test suites if specified
 | ||
|         const suitesToRun = options.suites ? 
 | ||
|             TEST_SUITES.filter(suite => options.suites.includes(suite.name)) :
 | ||
|             TEST_SUITES;
 | ||
|         
 | ||
|         console.log(`\n📋 Running ${suitesToRun.length} test suites...\n`);
 | ||
|         
 | ||
|         // Run test suites
 | ||
|         const results = [];
 | ||
|         for (const suite of suitesToRun) {
 | ||
|             const result = await runTestSuite(suite, options);
 | ||
|             results.push(result);
 | ||
|             
 | ||
|             // Brief pause between suites
 | ||
|             if (suitesToRun.indexOf(suite) < suitesToRun.length - 1) {
 | ||
|                 console.log('⏳ Pausing 5 seconds before next suite...\n');
 | ||
|                 await new Promise(resolve => setTimeout(resolve, 5000));
 | ||
|             }
 | ||
|         }
 | ||
|         
 | ||
|         // Analyze results
 | ||
|         console.log('\n📊 Analyzing test results...');
 | ||
|         const analysis = await analyzeTestResults(results);
 | ||
|         
 | ||
|         // Generate reports
 | ||
|         if (!options.skipReports) {
 | ||
|             console.log('📝 Generating comprehensive reports...');
 | ||
|             
 | ||
|             // Executive summary
 | ||
|             const executiveSummary = await generateExecutiveSummary(results, analysis);
 | ||
|             const summaryPath = path.join(REPORT_DIR, `executive-summary-${Date.now()}.md`);
 | ||
|             await fs.writeFile(summaryPath, executiveSummary);
 | ||
|             
 | ||
|             // Detailed report
 | ||
|             const { report, jsonReportPath } = await generateDetailedReport(results, analysis);
 | ||
|             
 | ||
|             console.log('\n📋 Reports Generated:');
 | ||
|             console.log(`📄 Executive Summary: ${summaryPath}`);
 | ||
|             console.log(`📊 Detailed Report: ${jsonReportPath}`);
 | ||
|             console.log(`📸 Screenshots: ${SCREENSHOTS_DIR}`);
 | ||
|         }
 | ||
|         
 | ||
|         // Final summary
 | ||
|         console.log('\n' + '='.repeat(60));
 | ||
|         console.log('🏁 TEST SUITE COMPLETION SUMMARY');
 | ||
|         console.log('='.repeat(60));
 | ||
|         console.log(`✅ Passed: ${analysis.passed}/${analysis.totalSuites}`);
 | ||
|         console.log(`❌ Failed: ${analysis.failed}/${analysis.totalSuites}`);
 | ||
|         console.log(`🚨 Critical Failures: ${analysis.criticalFailures}`);
 | ||
|         console.log(`⏱️  Total Duration: ${(analysis.totalDuration / 1000).toFixed(1)}s`);
 | ||
|         console.log(`📊 Success Rate: ${((analysis.passed / analysis.totalSuites) * 100).toFixed(1)}%`);
 | ||
|         
 | ||
|         if (analysis.criticalFailures > 0) {
 | ||
|             console.log('\n🚨 CRITICAL ISSUES DETECTED - Requires immediate attention!');
 | ||
|             process.exit(1);
 | ||
|         } else if (analysis.failed > 0) {
 | ||
|             console.log('\n⚠️  Some tests failed - Review and address issues');
 | ||
|             process.exit(1);
 | ||
|         } else {
 | ||
|             console.log('\n🎉 ALL TESTS PASSED - Refactoring validation successful!');
 | ||
|             process.exit(0);
 | ||
|         }
 | ||
|         
 | ||
|     } catch (error) {
 | ||
|         console.error('\n💥 Test runner failed:', error.message);
 | ||
|         console.error(error.stack);
 | ||
|         process.exit(1);
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| // Run if called directly
 | ||
| if (require.main === module) {
 | ||
|     main().catch(error => {
 | ||
|         console.error('Fatal error:', error);
 | ||
|         process.exit(1);
 | ||
|     });
 | ||
| }
 | ||
| 
 | ||
| module.exports = {
 | ||
|     runTestSuite,
 | ||
|     analyzeTestResults,
 | ||
|     generateExecutiveSummary,
 | ||
|     generateDetailedReport,
 | ||
|     TEST_SUITES
 | ||
| }; |