TenantAtlas/tests/Unit/Evidence/EvidenceSnapshotBadgeTest.php
ahmido 1f0cc5de56 feat: implement operator explanation layer (#191)
## Summary
- add the shared operator explanation layer with explanation families, trustworthiness semantics, count descriptors, and centralized badge mappings
- adopt explanation-first rendering across baseline compare, governance operation run detail, baseline snapshot presentation, tenant review detail, and review register rows
- extend reason translation, artifact-truth presentation, fallback ops UX messaging, and focused regression coverage for operator explanation semantics

## Testing
- vendor/bin/sail bin pint --dirty --format agent
- vendor/bin/sail artisan test --compact tests/Feature/Monitoring/OperationsTenantScopeTest.php tests/Feature/Operations/OperationRunBlockedExecutionPresentationTest.php
- vendor/bin/sail artisan test --compact

## Notes
- Livewire v4 compatible
- panel provider registration remains in bootstrap/providers.php
- no destructive Filament actions were added or changed in this PR
- no new global-search behavior was introduced in this slice

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #191
2026-03-24 11:24:33 +00:00

39 lines
2.2 KiB
PHP

<?php
declare(strict_types=1);
use App\Support\Badges\BadgeCatalog;
use App\Support\Badges\BadgeDomain;
it('maps all evidence snapshot statuses and completeness states to known badge specs', function (BadgeDomain $domain, string $value): void {
$spec = BadgeCatalog::spec($domain, $value);
expect($spec->label)->not->toBe('Unknown')
->and($spec->icon)->not->toBeNull();
})->with([
'queued status' => [BadgeDomain::EvidenceSnapshotStatus, 'queued'],
'generating status' => [BadgeDomain::EvidenceSnapshotStatus, 'generating'],
'active status' => [BadgeDomain::EvidenceSnapshotStatus, 'active'],
'superseded status' => [BadgeDomain::EvidenceSnapshotStatus, 'superseded'],
'expired status' => [BadgeDomain::EvidenceSnapshotStatus, 'expired'],
'failed status' => [BadgeDomain::EvidenceSnapshotStatus, 'failed'],
'complete completeness' => [BadgeDomain::EvidenceCompleteness, 'complete'],
'partial completeness' => [BadgeDomain::EvidenceCompleteness, 'partial'],
'missing completeness' => [BadgeDomain::EvidenceCompleteness, 'missing'],
'stale completeness' => [BadgeDomain::EvidenceCompleteness, 'stale'],
]);
it('reclassifies valid-empty and freshness evidence states with explicit labels', function (): void {
expect(BadgeCatalog::spec(BadgeDomain::EvidenceCompleteness, 'complete')->label)->toBe('Coverage ready')
->and(BadgeCatalog::spec(BadgeDomain::EvidenceCompleteness, 'missing')->label)->toBe('Not collected yet')
->and(BadgeCatalog::spec(BadgeDomain::EvidenceCompleteness, 'missing')->color)->toBe('info')
->and(BadgeCatalog::spec(BadgeDomain::EvidenceCompleteness, 'stale')->label)->toBe('Refresh recommended')
->and(BadgeCatalog::spec(BadgeDomain::EvidenceCompleteness, 'stale')->color)->toBe('warning');
});
it('exposes shared governance-artifact truth badges for evidence semantics', function (): void {
expect(BadgeCatalog::spec(BadgeDomain::GovernanceArtifactContent, 'partial')->label)->toBe('Partially complete')
->and(BadgeCatalog::spec(BadgeDomain::GovernanceArtifactFreshness, 'stale')->label)->toBe('Refresh recommended')
->and(BadgeCatalog::spec(BadgeDomain::GovernanceArtifactActionability, 'required')->label)->toBe('Action required');
});