TenantAtlas/apps/platform/tests/Unit/Providers/ProviderCapabilityRegistryTest.php
ahmido 1debe40ced feat: implement provider capability registry (#342)
## Summary
- implement the provider capability registry and derived capability evaluation flow
- update provider connections, onboarding, required-permissions diagnostics, and provider blocker translation to use capability-first summaries
- add bounded unit, feature, and browser test coverage plus the prepared Spec 283 artifacts

## Notes
- branch: `283-provider-capability-registry`
- commit: `74e75c3e`
- no additional validation commands were run in this git/PR flow step

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #342
2026-05-08 21:17:05 +00:00

38 lines
1.7 KiB
PHP

<?php
declare(strict_types=1);
use App\Support\Badges\BadgeCatalog;
use App\Support\Badges\BadgeDomain;
use App\Support\Providers\Capabilities\ProviderCapabilityRegistry;
it('defines the canonical provider capability keys and operation mappings', function (): void {
$registry = app(ProviderCapabilityRegistry::class);
expect($registry->keys())->toBe([
'provider_connection_check',
'inventory_read',
'configuration_read',
'restore_execute',
'directory_groups_read',
'directory_role_definitions_read',
])
->and($registry->keysForOperationType('inventory.sync'))->toBe(['inventory_read'])
->and($registry->keysForOperationType('directory.role_definitions.sync'))->toBe(['directory_role_definitions_read'])
->and($registry->get('restore_execute')->providerRequirementKeys)->toBe([
'permissions.intune_configuration',
'permissions.intune_rbac_assignments',
])
->and($registry->get('directory_role_definitions_read')->providerRequirementKeys)->toBe([
'provider.directory_role_definitions',
'permissions.admin_consent',
]);
});
it('registers provider capability status badge semantics', function (): void {
expect(BadgeCatalog::spec(BadgeDomain::ProviderCapabilityStatus, 'supported')->label)->toBe('Supported')
->and(BadgeCatalog::spec(BadgeDomain::ProviderCapabilityStatus, 'missing')->color)->toBe('warning')
->and(BadgeCatalog::spec(BadgeDomain::ProviderCapabilityStatus, 'blocked')->color)->toBe('danger')
->and(BadgeCatalog::spec(BadgeDomain::ProviderCapabilityStatus, 'not_applicable')->label)->toBe('Not applicable');
});