## 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
38 lines
1.7 KiB
PHP
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');
|
|
});
|