TenantAtlas/tests/Unit/Support/RestoreSafety/RestoreScopeFingerprintTest.php
ahmido a107e7e41b feat: restore safety integrity and queue slide-over (#210)
## 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
2026-04-06 23:37:14 +00:00

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);
});