TenantAtlas/apps/platform/tests/Unit/Support/ReasonTranslation/ReasonResolutionEnvelopeTest.php
2026-04-14 08:07:40 +02:00

65 lines
2.8 KiB
PHP

<?php
declare(strict_types=1);
use App\Support\ReasonTranslation\FallbackReasonTranslator;
use App\Support\ReasonTranslation\NextStepOption;
use App\Support\ReasonTranslation\PlatformReasonFamily;
use App\Support\ReasonTranslation\ReasonOwnershipDescriptor;
use App\Support\ReasonTranslation\ReasonResolutionEnvelope;
it('renders body lines and legacy next steps from the shared envelope', function (): void {
$envelope = new ReasonResolutionEnvelope(
internalCode: 'provider_consent_missing',
operatorLabel: 'Admin consent required',
shortExplanation: 'The provider connection cannot continue until admin consent is granted.',
actionability: 'prerequisite_missing',
nextSteps: [
NextStepOption::link('Grant admin consent', 'https://example.test/admin-consent'),
],
);
expect($envelope->toBodyLines())->toBe([
'Admin consent required',
'The provider connection cannot continue until admin consent is granted.',
'Next step: Grant admin consent.',
])->and($envelope->toLegacyNextSteps())->toBe([
[
'label' => 'Grant admin consent',
'url' => 'https://example.test/admin-consent',
],
]);
});
it('builds understandable fallback translations without exposing raw codes as operator labels', function (): void {
$envelope = app(FallbackReasonTranslator::class)->translate('custom_retry_timeout');
expect($envelope)->not->toBeNull()
->and($envelope?->operatorLabel)->toBe('Custom Retry Timeout')
->and($envelope?->operatorLabel)->not->toBe('custom_retry_timeout')
->and($envelope?->shortExplanation)->toContain('transient dependency issue')
->and($envelope?->guidanceText())->toBe('Next step: Retry after the dependency recovers.');
});
it('round-trips explicit reason ownership and platform-family metadata', function (): void {
$envelope = new ReasonResolutionEnvelope(
internalCode: 'provider_consent_missing',
operatorLabel: 'Admin consent required',
shortExplanation: 'The provider connection cannot continue until admin consent is granted.',
actionability: 'prerequisite_missing',
reasonOwnership: new ReasonOwnershipDescriptor(
ownerLayer: 'provider_owned',
ownerNamespace: 'provider.microsoft_graph',
reasonCode: 'provider_consent_missing',
platformReasonFamily: PlatformReasonFamily::Prerequisite,
),
);
$restored = ReasonResolutionEnvelope::fromArray($envelope->toArray());
expect($restored)->not->toBeNull()
->and($restored?->ownerLayer())->toBe('provider_owned')
->and($restored?->ownerNamespace())->toBe('provider.microsoft_graph')
->and($restored?->platformReasonFamily())->toBe(PlatformReasonFamily::Prerequisite->value);
});