## 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
44 lines
1.5 KiB
PHP
44 lines
1.5 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
use App\Support\Badges\OperatorOutcomeTaxonomy;
|
|
use App\Support\Badges\OperatorStateClassification;
|
|
|
|
it('never allows diagnostic taxonomy entries to use warning or danger colors', function (): void {
|
|
$violations = [];
|
|
|
|
foreach (OperatorOutcomeTaxonomy::all() as $domain => $entries) {
|
|
foreach ($entries as $state => $entry) {
|
|
if ($entry['classification'] !== OperatorStateClassification::Diagnostic) {
|
|
continue;
|
|
}
|
|
|
|
if (! in_array($entry['color'], ['warning', 'danger'], true)) {
|
|
continue;
|
|
}
|
|
|
|
$violations[] = sprintf('%s:%s => %s', $domain, $state, $entry['color']);
|
|
}
|
|
}
|
|
|
|
expect($violations)->toBeEmpty("Diagnostic taxonomy entries must not use warning or danger colors:\n".implode("\n", $violations));
|
|
});
|
|
|
|
it('does not keep overloaded bare labels in the adopted taxonomy slice', function (): void {
|
|
$forbiddenLabels = ['Blocked', 'Missing', 'Partial', 'Stale', 'Unsupported', 'Warning', 'Safe'];
|
|
$violations = [];
|
|
|
|
foreach (OperatorOutcomeTaxonomy::all() as $domain => $entries) {
|
|
foreach ($entries as $state => $entry) {
|
|
if (! in_array($entry['label'], $forbiddenLabels, true)) {
|
|
continue;
|
|
}
|
|
|
|
$violations[] = sprintf('%s:%s => %s', $domain, $state, $entry['label']);
|
|
}
|
|
}
|
|
|
|
expect($violations)->toBeEmpty("Overloaded bare operator labels remain in the first-slice taxonomy:\n".implode("\n", $violations));
|
|
});
|