Resolved multiple critical discovery system issues: ## Discovery System Fixes - Fixed console commands not being discovered on first run - Implemented fallback discovery for empty caches - Added context-aware caching with separate cache keys - Fixed object serialization preventing __PHP_Incomplete_Class ## Cache System Improvements - Smart caching that only caches meaningful results - Separate caches for different execution contexts (console, web, test) - Proper array serialization/deserialization for cache compatibility - Cache hit logging for debugging and monitoring ## Object Serialization Fixes - Fixed DiscoveredAttribute serialization with proper string conversion - Sanitized additional data to prevent object reference issues - Added fallback for corrupted cache entries ## Performance & Reliability - All 69 console commands properly discovered and cached - 534 total discovery items successfully cached and restored - No more __PHP_Incomplete_Class cache corruption - Improved error handling and graceful fallbacks ## Testing & Quality - Fixed code style issues across discovery components - Enhanced logging for better debugging capabilities - Improved cache validation and error recovery Ready for production deployment with stable discovery system. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
49 lines
1.6 KiB
PHP
49 lines
1.6 KiB
PHP
#!/usr/bin/env php
|
|
<?php
|
|
declare(strict_types=1);
|
|
|
|
require_once __DIR__ . '/vendor/autoload.php';
|
|
|
|
use App\Framework\Console\ConsoleCommand;
|
|
use App\Framework\Console\DemoCommand;
|
|
|
|
echo "Testing manual attribute discovery..." . PHP_EOL;
|
|
|
|
try {
|
|
// Manually test attribute discovery
|
|
$reflector = new ReflectionClass(DemoCommand::class);
|
|
|
|
echo "DemoCommand exists: " . (class_exists(DemoCommand::class) ? 'YES' : 'NO') . PHP_EOL;
|
|
echo "ConsoleCommand exists: " . (class_exists(ConsoleCommand::class) ? 'YES' : 'NO') . PHP_EOL;
|
|
|
|
$methods = $reflector->getMethods();
|
|
echo "Methods found: " . count($methods) . PHP_EOL;
|
|
|
|
foreach ($methods as $method) {
|
|
echo "Method: " . $method->getName() . PHP_EOL;
|
|
|
|
// Get all attributes
|
|
$allAttributes = $method->getAttributes();
|
|
echo " All attributes: " . count($allAttributes) . PHP_EOL;
|
|
|
|
foreach ($allAttributes as $attr) {
|
|
echo " Attribute: " . $attr->getName() . PHP_EOL;
|
|
}
|
|
|
|
// Get specific ConsoleCommand attributes
|
|
$consoleAttributes = $method->getAttributes(ConsoleCommand::class);
|
|
echo " ConsoleCommand attributes: " . count($consoleAttributes) . PHP_EOL;
|
|
|
|
if (!empty($consoleAttributes)) {
|
|
$instance = $consoleAttributes[0]->newInstance();
|
|
echo " Name: " . $instance->name . PHP_EOL;
|
|
echo " Description: " . $instance->description . PHP_EOL;
|
|
}
|
|
|
|
echo PHP_EOL;
|
|
}
|
|
|
|
} catch (Exception $e) {
|
|
echo "Error: " . $e->getMessage() . PHP_EOL;
|
|
echo "Trace: " . $e->getTraceAsString() . PHP_EOL;
|
|
} |