TenantAtlas/apps/platform/tests/Unit/Badges/ProviderConnectionBadgesTest.php
ahmido 110245a9ec
Some checks are pending
Main Confidence / confidence (push) Waiting to run
feat: neutralize provider connection target-scope surfaces (#274)
## Summary
- add a shared provider target-scope descriptor, normalizer, identity-context metadata, and surface-summary layer
- update provider connection list, detail, create, edit, and onboarding surfaces to use neutral target-scope vocabulary while keeping Microsoft identity contextual
- align provider connection audit and resolver output with the neutral target-scope contract and add focused guard/unit/feature coverage for regressions

## Validation
- browser smoke: opened the tenant-scoped provider connection list, drilled into detail, and verified the edit/create surfaces in local admin context

## Notes
- this PR comes from the session branch created for the active feature work
- no additional runtime or persistence layer was introduced in this slice

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #274
2026-04-25 09:07:40 +00:00

62 lines
2.6 KiB
PHP

<?php
declare(strict_types=1);
use App\Support\Badges\BadgeCatalog;
use App\Support\Badges\BadgeDomain;
it('maps provider consent status safely', function (): void {
$unknown = BadgeCatalog::spec(BadgeDomain::ProviderConsentStatus, 'unknown');
expect($unknown->color)->toBe('gray');
expect($unknown->label)->toBe('Unknown');
$required = BadgeCatalog::spec(BadgeDomain::ProviderConsentStatus, 'required');
expect($required->color)->toBe('warning');
expect($required->label)->toBe('Required');
$granted = BadgeCatalog::spec(BadgeDomain::ProviderConsentStatus, 'granted');
expect($granted->color)->toBe('success');
expect($granted->label)->toBe('Granted');
$failed = BadgeCatalog::spec(BadgeDomain::ProviderConsentStatus, 'failed');
expect($failed->color)->toBe('danger');
expect($failed->label)->toBe('Failed');
});
it('maps provider verification status safely', function (): void {
$unknown = BadgeCatalog::spec(BadgeDomain::ProviderVerificationStatus, 'unknown');
expect($unknown->color)->toBe('gray');
expect($unknown->label)->toBe('Unknown');
$pending = BadgeCatalog::spec(BadgeDomain::ProviderVerificationStatus, 'pending');
expect($pending->color)->toBe('info');
expect($pending->label)->toBe('Pending');
$healthy = BadgeCatalog::spec(BadgeDomain::ProviderVerificationStatus, 'healthy');
expect($healthy->color)->toBe('success');
expect($healthy->label)->toBe('Healthy');
$blocked = BadgeCatalog::spec(BadgeDomain::ProviderVerificationStatus, 'blocked');
expect($blocked->color)->toBe('danger');
expect($blocked->label)->toBe('Blocked');
$degraded = BadgeCatalog::spec(BadgeDomain::ProviderVerificationStatus, 'degraded');
expect($degraded->color)->toBe('warning');
expect($degraded->label)->toBe('Degraded');
});
it('does not reuse consent labels for provider verification summaries', function (): void {
expect(BadgeCatalog::spec(BadgeDomain::ProviderConsentStatus, 'required')->label)->toBe('Required')
->and(BadgeCatalog::spec(BadgeDomain::ProviderVerificationStatus, 'pending')->label)->toBe('Pending')
->and(BadgeCatalog::spec(BadgeDomain::ProviderConsentStatus, 'required')->label)
->not->toBe(BadgeCatalog::spec(BadgeDomain::ProviderVerificationStatus, 'pending')->label);
});
it('does not expose legacy provider status badge domains anymore', function (): void {
$domainValues = collect(BadgeDomain::cases())
->map(fn (BadgeDomain $domain): string => $domain->value)
->all();
expect($domainValues)->not->toContain('provider_connection.status', 'provider_connection.health');
});