TenantAtlas/tests/Unit/Badges/OperationRunBadgesTest.php
ahmido 3c3daae405 feat: normalize operator outcome taxonomy (#186)
## 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
2026-03-22 12:13:34 +00:00

53 lines
2.1 KiB
PHP

<?php
declare(strict_types=1);
use App\Support\Badges\BadgeCatalog;
use App\Support\Badges\BadgeDomain;
it('maps operation run status values to canonical badge semantics', function (): void {
$queued = BadgeCatalog::spec(BadgeDomain::OperationRunStatus, 'queued');
expect($queued->label)->toBe('Queued for execution');
expect($queued->color)->toBe('info');
$running = BadgeCatalog::spec(BadgeDomain::OperationRunStatus, 'running');
expect($running->label)->toBe('In progress');
expect($running->color)->toBe('info');
$completed = BadgeCatalog::spec(BadgeDomain::OperationRunStatus, 'completed');
expect($completed->label)->toBe('Run finished');
expect($completed->color)->toBe('gray');
});
it('maps operation run outcome values to canonical badge semantics', function (): void {
$pending = BadgeCatalog::spec(BadgeDomain::OperationRunOutcome, 'pending');
expect($pending->label)->toBe('Awaiting result');
expect($pending->color)->toBe('gray');
$succeeded = BadgeCatalog::spec(BadgeDomain::OperationRunOutcome, 'succeeded');
expect($succeeded->label)->toBe('Completed successfully');
expect($succeeded->color)->toBe('success');
$partial = BadgeCatalog::spec(BadgeDomain::OperationRunOutcome, 'partially_succeeded');
expect($partial->label)->toBe('Completed with follow-up');
expect($partial->color)->toBe('warning');
$blocked = BadgeCatalog::spec(BadgeDomain::OperationRunOutcome, 'blocked');
expect($blocked->label)->toBe('Blocked by prerequisite');
expect($blocked->color)->toBe('warning');
$failed = BadgeCatalog::spec(BadgeDomain::OperationRunOutcome, 'failed');
expect($failed->label)->toBe('Execution failed');
expect($failed->color)->toBe('danger');
$cancelled = BadgeCatalog::spec(BadgeDomain::OperationRunOutcome, 'cancelled');
expect($cancelled->label)->toBe('Cancelled');
expect($cancelled->color)->toBe('gray');
});
it('never represents a success outcome with warning/attention meaning', function (): void {
$succeeded = BadgeCatalog::spec(BadgeDomain::OperationRunOutcome, 'succeeded');
expect($succeeded->color)->not->toBe('warning');
});