## Summary - add the Spec 181 restore-safety layer with scope fingerprinting, preview/check integrity states, execution safety snapshots, result attention, and operator-facing copy across the wizard, restore detail, and canonical operation detail - add focused unit and feature coverage for restore-safety assessment, result attention, and restore-linked operation detail - switch the finding exceptions queue `Inspect exception` action to a native Filament slide-over while preserving query-param-backed inline summary behavior ## Testing - `vendor/bin/sail artisan test --compact tests/Feature/Monitoring/FindingExceptionsQueueTest.php tests/Feature/Filament/RestoreSafetyIntegrityWizardTest.php tests/Feature/Filament/RestoreResultAttentionSurfaceTest.php tests/Feature/Operations/RestoreLinkedOperationDetailTest.php tests/Unit/Support/RestoreSafety` ## Notes - Spec 181 checklist is complete (`specs/181-restore-safety-integrity/checklists/requirements.md`) - the branch still has unchecked follow-up tasks in `specs/181-restore-safety-integrity/tasks.md`: `T012`, `T018`, `T019`, `T023`, `T025`, `T029`, `T032`, `T033`, `T041`, `T042`, `T043`, `T044` - Filament v5 / Livewire v4 compliance is preserved, no panel provider registration changes were made, no global-search behavior was added, destructive actions remain confirmation-gated, and no new Filament assets were introduced Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #210
57 lines
1.6 KiB
PHP
57 lines
1.6 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
use App\Support\RestoreSafety\RestoreScopeFingerprint;
|
|
|
|
it('normalizes selected item and group mapping order into a stable fingerprint', function (): void {
|
|
$first = RestoreScopeFingerprint::fromInputs(
|
|
backupSetId: 10,
|
|
scopeMode: 'selected',
|
|
selectedItemIds: [9, 3, '3', 1],
|
|
groupMapping: [
|
|
'group-b' => 'target-b',
|
|
'group-a' => 'target-a',
|
|
],
|
|
);
|
|
|
|
$second = RestoreScopeFingerprint::fromInputs(
|
|
backupSetId: 10,
|
|
scopeMode: 'selected',
|
|
selectedItemIds: ['1', 3, 9],
|
|
groupMapping: [
|
|
'group-a' => 'target-a',
|
|
'group-b' => 'target-b',
|
|
],
|
|
);
|
|
|
|
expect($first->selectedItemIds)->toBe([1, 3, 9])
|
|
->and($first->fingerprint)->toBe($second->fingerprint);
|
|
});
|
|
|
|
it('changes fingerprint when scope-affecting values change', function (): void {
|
|
$base = RestoreScopeFingerprint::fromInputs(
|
|
backupSetId: 10,
|
|
scopeMode: 'selected',
|
|
selectedItemIds: [1, 2],
|
|
groupMapping: ['group-a' => 'target-a'],
|
|
);
|
|
|
|
$changedSelection = RestoreScopeFingerprint::fromInputs(
|
|
backupSetId: 10,
|
|
scopeMode: 'selected',
|
|
selectedItemIds: [1, 3],
|
|
groupMapping: ['group-a' => 'target-a'],
|
|
);
|
|
|
|
$changedMapping = RestoreScopeFingerprint::fromInputs(
|
|
backupSetId: 10,
|
|
scopeMode: 'selected',
|
|
selectedItemIds: [1, 2],
|
|
groupMapping: ['group-a' => 'SKIP'],
|
|
);
|
|
|
|
expect($base->fingerprint)->not->toBe($changedSelection->fingerprint)
|
|
->and($base->fingerprint)->not->toBe($changedMapping->fingerprint);
|
|
});
|