feat(Deployment): Integrate Ansible deployment via PHP deployment pipeline

- Create AnsibleDeployStage using framework's Process module for secure command execution
- Integrate AnsibleDeployStage into DeploymentPipelineCommands for production deployments
- Add force_deploy flag support in Ansible playbook to override stale locks
- Use PHP deployment module as orchestrator (php console.php deploy:production)
- Fix ErrorAggregationInitializer to use Environment class instead of $_ENV superglobal

Architecture:
- BuildStage → AnsibleDeployStage → HealthCheckStage for production
- Process module provides timeout, error handling, and output capture
- Ansible playbook supports rollback via rollback-git-based.yml
- Zero-downtime deployments with health checks
This commit is contained in:
2025-10-26 14:08:07 +01:00
parent a90263d3be
commit 3b623e7afb
170 changed files with 19888 additions and 575 deletions

View File

@@ -0,0 +1,75 @@
<?php
declare(strict_types=1);
require_once __DIR__ . '/../../vendor/autoload.php';
use App\Framework\Logging\DefaultLogger;
use App\Framework\Logging\Handlers\ConsoleHandler;
use App\Framework\Scheduler\Services\SchedulerService;
use App\Framework\Worker\Every;
use App\Framework\Worker\Schedule;
use App\Framework\Worker\ScheduleDiscoveryService;
use App\Framework\Discovery\Results\DiscoveryRegistry;
use App\Framework\Discovery\Results\AttributeRegistry;
// Test job class
#[Schedule(at: new Every(minutes: 5))]
final class DebugScheduledJob
{
public function handle(): array
{
return ['status' => 'success', 'executed_at' => time()];
}
}
// Setup logger
$logger = new DefaultLogger(handlers: [new ConsoleHandler()]);
// Setup scheduler
$schedulerService = new SchedulerService($logger);
// Setup discovery registry with attribute registry
$attributeRegistry = new AttributeRegistry();
$attributeRegistry->register(Schedule::class, DebugScheduledJob::class);
$discoveryRegistry = new DiscoveryRegistry($attributeRegistry);
// Create discovery service
$scheduleDiscovery = new ScheduleDiscoveryService(
$discoveryRegistry,
$schedulerService
);
echo "=== Testing ScheduleDiscoveryService ===\n\n";
// Discover and register
$registered = $scheduleDiscovery->discoverAndRegister();
echo "Registered: {$registered} tasks\n\n";
// Get scheduled tasks
$scheduledTasks = $scheduleDiscovery->getScheduledTasks();
echo "Scheduled tasks count: " . count($scheduledTasks) . "\n\n";
foreach ($scheduledTasks as $task) {
echo "Task ID: {$task->taskId}\n";
echo "Next execution: {$task->nextExecution->format('Y-m-d H:i:s')}\n";
echo "---\n";
}
// Execute a task
if (count($scheduledTasks) > 0) {
$task = $scheduledTasks[0];
echo "\nExecuting task: {$task->taskId}\n";
$result = $schedulerService->executeTask($task);
echo "Success: " . ($result->success ? 'Yes' : 'No') . "\n";
echo "Result: " . json_encode($result->result, JSON_PRETTY_PRINT) . "\n";
if ($result->error) {
echo "Error: {$result->error}\n";
}
}
echo "\n=== Test completed ===\n";