## Summary - introduce a shared operator outcome taxonomy with semantic axes, severity bands, and next-action policy - apply the taxonomy to operations, evidence/review completeness, baseline semantics, and restore semantics - harden badge rendering, tenant-safe filtering/search behavior, and operator-facing summary/notification wording - add the spec kit artifacts, reference documentation, and regression coverage for diagnostic-vs-primary state handling ## Testing - focused Pest coverage for taxonomy registry and badge guardrails - operations presentation and notification tests - evidence, baseline, restore, and tenant-scope regression tests ## Notes - Livewire v4.0+ compliance is preserved in the existing Filament v5 stack - panel provider registration remains unchanged in bootstrap/providers.php - no new globally searchable resource was added; adopted resources remain tenant-safe and out of global search where required - no new destructive action family was introduced; existing actions keep their current authorization and confirmation behavior - no new frontend asset strategy was introduced; existing deploy flow with filament:assets remains unchanged Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #186
65 lines
2.7 KiB
PHP
65 lines
2.7 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
use App\Support\Badges\BadgeCatalog;
|
|
use App\Support\Badges\BadgeDomain;
|
|
|
|
it('maps restore run status values to canonical badge semantics', function (): void {
|
|
$draft = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'draft');
|
|
expect($draft->label)->toBe('Draft');
|
|
expect($draft->color)->toBe('gray');
|
|
|
|
$previewed = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'previewed');
|
|
expect($previewed->label)->toBe('Preview ready');
|
|
expect($previewed->color)->toBe('gray');
|
|
|
|
$queued = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'queued');
|
|
expect($queued->label)->toBe('Queued for execution');
|
|
expect($queued->color)->toBe('info');
|
|
|
|
$running = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'running');
|
|
expect($running->label)->toBe('Applying restore');
|
|
expect($running->color)->toBe('info');
|
|
|
|
$completed = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'completed');
|
|
expect($completed->label)->toBe('Applied successfully');
|
|
expect($completed->color)->toBe('success');
|
|
|
|
$partial = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'partial');
|
|
expect($partial->label)->toBe('Applied with follow-up');
|
|
expect($partial->color)->toBe('warning');
|
|
|
|
$completedWithErrors = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'completed_with_errors');
|
|
expect($completedWithErrors->label)->toBe('Applied with follow-up');
|
|
expect($completedWithErrors->color)->toBe('warning');
|
|
|
|
$failed = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'failed');
|
|
expect($failed->label)->toBe('Restore failed');
|
|
expect($failed->color)->toBe('danger');
|
|
|
|
$aborted = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'aborted');
|
|
expect($aborted->label)->toBe('Stopped early');
|
|
expect($aborted->color)->toBe('gray');
|
|
});
|
|
|
|
it('never represents a completed outcome with warning/attention meaning', function (): void {
|
|
$completed = BadgeCatalog::spec(BadgeDomain::RestoreRunStatus, 'completed');
|
|
|
|
expect($completed->color)->not->toBe('warning');
|
|
});
|
|
|
|
it('maps restore safety check severity values to canonical badge semantics', function (): void {
|
|
$blocking = BadgeCatalog::spec(BadgeDomain::RestoreCheckSeverity, 'blocking');
|
|
expect($blocking->label)->toBe('Fix before running');
|
|
expect($blocking->color)->toBe('danger');
|
|
|
|
$warning = BadgeCatalog::spec(BadgeDomain::RestoreCheckSeverity, 'warning');
|
|
expect($warning->label)->toBe('Review before running');
|
|
expect($warning->color)->toBe('warning');
|
|
|
|
$safe = BadgeCatalog::spec(BadgeDomain::RestoreCheckSeverity, 'safe');
|
|
expect($safe->label)->toBe('Ready to continue');
|
|
expect($safe->color)->toBe('success');
|
|
});
|