Files
michaelschiemer/tests/debug/test-dataprovider-working.php
Michael Schiemer fc3d7e6357 feat(Production): Complete production deployment infrastructure
- Add comprehensive health check system with multiple endpoints
- Add Prometheus metrics endpoint
- Add production logging configurations (5 strategies)
- Add complete deployment documentation suite:
  * QUICKSTART.md - 30-minute deployment guide
  * DEPLOYMENT_CHECKLIST.md - Printable verification checklist
  * DEPLOYMENT_WORKFLOW.md - Complete deployment lifecycle
  * PRODUCTION_DEPLOYMENT.md - Comprehensive technical reference
  * production-logging.md - Logging configuration guide
  * ANSIBLE_DEPLOYMENT.md - Infrastructure as Code automation
  * README.md - Navigation hub
  * DEPLOYMENT_SUMMARY.md - Executive summary
- Add deployment scripts and automation
- Add DEPLOYMENT_PLAN.md - Concrete plan for immediate deployment
- Update README with production-ready features

All production infrastructure is now complete and ready for deployment.
2025-10-25 19:18:37 +02:00

198 lines
7.1 KiB
PHP

<?php
declare(strict_types=1);
require_once __DIR__ . '/../bootstrap.php';
use App\Application\LiveComponents\InfiniteScroll\InfiniteScrollComponent;
use App\Framework\Cache\Cache;
use App\Framework\Cache\Driver\InMemoryCache;
use App\Framework\Cache\GeneralCache;
use App\Framework\Core\PathProvider;
use App\Framework\DateTime\Clock;
use App\Framework\DateTime\SystemClock;
use App\Framework\DI\DefaultContainer;
use App\Framework\Discovery\DiscoveryServiceBootstrapper;
use App\Framework\LiveComponents\DataProviderResolver;
use App\Framework\LiveComponents\ValueObjects\ComponentId;
use App\Framework\Serializer\Php\PhpSerializer;
use App\Framework\Serializer\Php\PhpSerializerConfig;
echo "\nDataProvider Resolution Integration Test\n";
echo str_repeat('=', 70) . "\n\n";
// 1. Setup minimal dependencies like the integration test does
echo "1. Setting up Discovery System...\n";
$container = new DefaultContainer();
$cacheDriver = new InMemoryCache();
$serializer = new PhpSerializer(PhpSerializerConfig::safe());
$cache = new GeneralCache($cacheDriver, $serializer);
$clock = new SystemClock();
$basePath = file_exists('/var/www/html/src') ? '/var/www/html' : '/home/michael/dev/michaelschiemer';
$pathProvider = new PathProvider($basePath);
// Register dependencies in container
$container->singleton(Cache::class, $cache);
$container->singleton(Clock::class, $clock);
$container->singleton(PathProvider::class, $pathProvider);
// Bootstrap discovery
$bootstrapper = new DiscoveryServiceBootstrapper($container, $clock);
$registry = $bootstrapper->performBootstrap($pathProvider, $cache, null);
echo "✓ Discovery System bootstrapped\n";
echo " - Total discovered items: " . $registry->count() . "\n\n";
// 2. Create DataProviderResolver with discovery
echo "2. Creating DataProviderResolver...\n";
// Create mock discovery service that wraps the registry
$mockDiscovery = new class ($registry) {
public function __construct(
private \App\Framework\Discovery\Results\DiscoveryRegistry $registry
) {
}
public function getAttributeRegistry(): \App\Framework\Discovery\Results\AttributeRegistry
{
return $this->registry->attributes;
}
public function getDiscoveryRegistry(): \App\Framework\Discovery\Results\DiscoveryRegistry
{
return $this->registry;
}
};
$resolver = new DataProviderResolver($mockDiscovery);
echo "✓ DataProviderResolver created\n\n";
// 3. Test: Initial Component Creation
echo "3. Test: Initial Component Creation with dataSource='demo'...\n";
$component = new InfiniteScrollComponent(
id: ComponentId::fromString('scroll:test'),
dataProviderResolver: $resolver,
items: [],
currentPage: 0,
pageSize: 5,
dataSource: 'demo'
);
echo "✓ Component created successfully\n";
$initialData = $component->getData();
echo " - Data has 'data_source': " . ($initialData->has('data_source') ? 'YES' : 'NO') . "\n";
echo " - dataSource value: '" . $initialData->get('data_source') . "'\n";
echo " - Items count: " . count($initialData->get('items')) . "\n\n";
// 4. Test: Execute Action
echo "4. Test: Execute Action - loadMore()...\n";
try {
$actionResult = $component->loadMore();
echo "✓ Action executed successfully\n";
echo " - Items loaded: " . count($actionResult->get('items')) . "\n";
echo " - Current page: " . $actionResult->get('current_page') . "\n";
echo " - Has 'data_source': " . ($actionResult->has('data_source') ? 'YES' : 'NO') . "\n";
echo " - dataSource value: '" . $actionResult->get('data_source') . "'\n\n";
} catch (\Exception $e) {
echo "✗ FAILED: " . $e->getMessage() . "\n";
echo " File: " . $e->getFile() . ":" . $e->getLine() . "\n";
echo " Stack trace:\n" . $e->getTraceAsString() . "\n\n";
exit(1);
}
// 5. Test: State Restoration
echo "5. Test: State Restoration from ComponentData...\n";
echo " - Attempting to reconstruct component from action result...\n";
try {
$restoredComponent = new InfiniteScrollComponent(
id: ComponentId::fromString('scroll:test-restored'),
dataProviderResolver: $resolver,
initialData: $actionResult // This triggers state restoration path
);
echo "✓ Component restored from ComponentData\n";
$restoredData = $restoredComponent->getData();
echo " - Restored items count: " . count($restoredData->get('items')) . "\n";
echo " - Restored page: " . $restoredData->get('current_page') . "\n";
echo " - Restored dataSource: '" . $restoredData->get('data_source') . "'\n\n";
} catch (\Exception $e) {
echo "✗ FAILED: " . $e->getMessage() . "\n";
echo " File: " . $e->getFile() . ":" . $e->getLine() . "\n";
echo " Stack trace:\n" . $e->getTraceAsString() . "\n\n";
exit(1);
}
// 6. Test: Action on Restored Component
echo "6. Test: Action on Restored Component...\n";
try {
$secondActionResult = $restoredComponent->loadMore();
echo "✓ Second action executed successfully\n";
echo " - Total items: " . count($secondActionResult->get('items')) . "\n";
echo " - Current page: " . $secondActionResult->get('current_page') . "\n";
echo " - dataSource: '" . $secondActionResult->get('data_source') . "'\n\n";
} catch (\Exception $e) {
echo "✗ FAILED: " . $e->getMessage() . "\n";
echo " File: " . $e->getFile() . ":" . $e->getLine() . "\n";
exit(1);
}
// 7. Verify All Requirements
echo "7. Verification of Requirements...\n";
$allPassed = true;
// Requirement 1: dataSource preserved through state transformations
if ($secondActionResult->get('data_source') !== 'demo') {
echo "✗ FAIL: dataSource not preserved\n";
echo " Expected: 'demo'\n";
echo " Got: '" . $secondActionResult->get('data_source') . "'\n";
$allPassed = false;
} else {
echo "✓ PASS: dataSource preserved correctly ('demo')\n";
}
// Requirement 2: Component state preserved correctly
if ($secondActionResult->get('current_page') !== 2) {
echo "✗ FAIL: Page progression incorrect\n";
echo " Expected page: 2\n";
echo " Got page: " . $secondActionResult->get('current_page') . "\n";
$allPassed = false;
} else {
echo "✓ PASS: Page progression correct (2)\n";
}
// Requirement 3: Data accumulated correctly
$expectedItems = 10; // 5 items per page * 2 pages
$actualItems = count($secondActionResult->get('items'));
if ($actualItems !== $expectedItems) {
echo "✗ FAIL: Item accumulation incorrect\n";
echo " Expected items: $expectedItems\n";
echo " Got items: $actualItems\n";
$allPassed = false;
} else {
echo "✓ PASS: Item accumulation correct ($expectedItems items)\n";
}
echo "\n" . str_repeat('=', 70) . "\n";
if ($allPassed) {
echo "✅ ALL TESTS PASSED\n";
echo "DataProvider resolution flow is working correctly!\n";
echo "\n";
echo "Summary:\n";
echo "- Initial render with dataSource ✓\n";
echo "- Action execution with state update ✓\n";
echo "- State restoration from ComponentData ✓\n";
echo "- Provider resolution in restored component ✓\n";
echo "- Subsequent actions on restored component ✓\n";
exit(0);
} else {
echo "❌ SOME TESTS FAILED\n";
echo "Review failures above for details.\n";
exit(1);
}