## Summary - replace the baseline snapshot detail page with a structured summary-first rendering flow - add a presenter plus renderer registry with RBAC, compliance, and fallback renderers - add grouped policy-type browsing, fidelity and gap badges, and workspace authorization coverage - add Feature 130 spec, plan, contract, research, quickstart, and completed task artifacts ## Testing - focused Pest coverage was added for structured rendering, fallback behavior, degraded states, authorization, presenter logic, renderer resolution, and badge mapping - I did not rerun the full validation suite in this final PR step ## Notes - base branch: `dev` - feature branch: `130-structured-snapshot-rendering` Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #158
30 lines
1.2 KiB
PHP
30 lines
1.2 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
use App\Support\Badges\BadgeCatalog;
|
|
use App\Support\Badges\BadgeDomain;
|
|
|
|
it('maps baseline snapshot fidelity states through the shared badge catalog', function (): void {
|
|
$full = BadgeCatalog::spec(BadgeDomain::BaselineSnapshotFidelity, 'full');
|
|
$referenceOnly = BadgeCatalog::spec(BadgeDomain::BaselineSnapshotFidelity, 'reference_only');
|
|
$unsupported = BadgeCatalog::spec(BadgeDomain::BaselineSnapshotFidelity, 'unsupported');
|
|
|
|
expect($full->label)->toBe('Full')
|
|
->and($full->color)->toBe('success')
|
|
->and($referenceOnly->label)->toBe('Reference only')
|
|
->and($referenceOnly->color)->toBe('info')
|
|
->and($unsupported->label)->toBe('Unsupported')
|
|
->and($unsupported->color)->toBe('gray');
|
|
});
|
|
|
|
it('maps baseline snapshot gap states through the shared badge catalog', function (): void {
|
|
$clear = BadgeCatalog::spec(BadgeDomain::BaselineSnapshotGapStatus, 'clear');
|
|
$present = BadgeCatalog::spec(BadgeDomain::BaselineSnapshotGapStatus, 'gaps_present');
|
|
|
|
expect($clear->label)->toBe('No gaps')
|
|
->and($clear->color)->toBe('success')
|
|
->and($present->label)->toBe('Gaps present')
|
|
->and($present->color)->toBe('warning');
|
|
});
|