94 lines
2.9 KiB
PHP
94 lines
2.9 KiB
PHP
<?php
|
|
|
|
use App\Jobs\ApplyBackupScheduleRetentionJob;
|
|
use App\Models\BackupSchedule;
|
|
use App\Models\BackupSet;
|
|
use App\Models\OperationRun;
|
|
use Filament\Facades\Filament;
|
|
|
|
test('retention keeps last N backup sets per schedule', function () {
|
|
[$user, $tenant] = createUserWithTenant(role: 'manager');
|
|
|
|
$schedule = BackupSchedule::query()->create([
|
|
'tenant_id' => $tenant->id,
|
|
'name' => 'Nightly',
|
|
'is_enabled' => true,
|
|
'timezone' => 'UTC',
|
|
'frequency' => 'daily',
|
|
'time_of_day' => '01:00:00',
|
|
'days_of_week' => null,
|
|
'policy_types' => ['deviceConfiguration'],
|
|
'include_foundations' => true,
|
|
'retention_keep_last' => 2,
|
|
]);
|
|
|
|
$this->actingAs($user);
|
|
Filament::setTenant($tenant, true);
|
|
|
|
$sets = collect(range(1, 5))->map(function (int $i) use ($tenant): BackupSet {
|
|
return BackupSet::query()->create([
|
|
'tenant_id' => $tenant->id,
|
|
'name' => 'Set '.$i,
|
|
'status' => 'completed',
|
|
'item_count' => 0,
|
|
'completed_at' => now()->subMinutes(10 - $i),
|
|
]);
|
|
});
|
|
|
|
$completedAt = now('UTC')->startOfMinute()->subMinutes(10);
|
|
|
|
foreach ($sets as $set) {
|
|
OperationRun::query()->create([
|
|
'workspace_id' => (int) $tenant->workspace_id,
|
|
'tenant_id' => (int) $tenant->id,
|
|
'user_id' => null,
|
|
'initiator_name' => 'System',
|
|
'type' => 'backup_schedule_run',
|
|
'status' => 'completed',
|
|
'outcome' => 'succeeded',
|
|
'run_identity_hash' => hash('sha256', 'retention-test:'.$schedule->id.':'.$set->id),
|
|
'summary_counts' => [
|
|
'total' => 0,
|
|
'processed' => 0,
|
|
'succeeded' => 0,
|
|
],
|
|
'failure_summary' => [],
|
|
'context' => [
|
|
'backup_schedule_id' => (int) $schedule->id,
|
|
'backup_set_id' => (int) $set->id,
|
|
],
|
|
'started_at' => $completedAt,
|
|
'completed_at' => $completedAt,
|
|
]);
|
|
|
|
$completedAt = $completedAt->addMinute();
|
|
}
|
|
|
|
ApplyBackupScheduleRetentionJob::dispatchSync($schedule->id);
|
|
|
|
$kept = $sets->take(-2);
|
|
$deleted = $sets->take(3);
|
|
|
|
foreach ($kept as $set) {
|
|
$this->assertDatabaseHas('backup_sets', [
|
|
'id' => $set->id,
|
|
'deleted_at' => null,
|
|
]);
|
|
}
|
|
|
|
foreach ($deleted as $set) {
|
|
$this->assertSoftDeleted('backup_sets', ['id' => $set->id]);
|
|
}
|
|
|
|
$retentionRun = OperationRun::query()
|
|
->where('tenant_id', (int) $tenant->id)
|
|
->where('type', 'backup_schedule_retention')
|
|
->latest('id')
|
|
->first();
|
|
|
|
expect($retentionRun)->not->toBeNull();
|
|
expect($retentionRun?->status)->toBe('completed');
|
|
expect($retentionRun?->outcome)->toBe('succeeded');
|
|
expect($retentionRun?->summary_counts['succeeded'] ?? null)->toBe(3);
|
|
});
|