## Summary This PR implements Spec 206 end to end and establishes the first checked-in test suite governance foundation for the platform app. Key changes: - add manifest-backed test lanes for fast-feedback, confidence, browser, heavy-governance, profiling, and junit - add budget and report helpers plus app-local artifact generation under `apps/platform/storage/logs/test-lanes` - add repo-root Sail-friendly lane/report wrappers - switch the default contributor test path to the fast-feedback lane - introduce explicit fixture profiles and cheaper defaults for shared tenant/provider test setup - add minimal/heavy factory states for tenant and provider connection setup - migrate the first high-usage and provider-sensitive tests to explicit fixture profiles - document budgets, taxonomy rules, DB reset guidance, and the full Spec 206 plan/contracts/tasks set ## Validation Executed during implementation: - focused Spec 206 guard/support/factory validation pack: 31 passed - provider-sensitive regression pack: 29 passed - first high-usage caller migration pack: 120 passed - lane routing and wrapper validation succeeded - pint completed successfully Measured lane baselines captured in docs: - fast-feedback: 176.74s - confidence: 394.38s - heavy-governance: 83.66s - browser: 128.87s - junit: 380.14s - profiling: 2701.51s - full-suite baseline anchor: 2624.60s ## Notes - Livewire v4 / Filament v5 runtime behavior is unchanged by this PR. - No new runtime routes, product UI flows, or database migrations are introduced. - Panel provider registration remains unchanged in `bootstrap/providers.php`. Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #239
34 lines
1.1 KiB
PHP
34 lines
1.1 KiB
PHP
<?php
|
|
|
|
use App\Models\TenantPermission;
|
|
|
|
it('renders required permissions overview with missing-first ordering and feature cards', function (): void {
|
|
[$user, $tenant] = createUserWithTenant(role: 'readonly');
|
|
|
|
$configured = config('intune_permissions.permissions', []);
|
|
if (! is_array($configured) || count($configured) < 2) {
|
|
test()->markTestSkipped('Need at least 2 required permissions configured.');
|
|
}
|
|
|
|
$grantedKey = (string) ($configured[0]['key'] ?? '');
|
|
$missingKey = (string) ($configured[1]['key'] ?? '');
|
|
|
|
if ($grantedKey === '' || $missingKey === '') {
|
|
test()->markTestSkipped('Configured permission keys missing.');
|
|
}
|
|
|
|
TenantPermission::create([
|
|
'tenant_id' => (int) $tenant->getKey(),
|
|
'permission_key' => $grantedKey,
|
|
'status' => 'granted',
|
|
'details' => ['source' => 'db'],
|
|
'last_checked_at' => now(),
|
|
]);
|
|
|
|
$this->actingAs($user)
|
|
->get("/admin/tenants/{$tenant->external_id}/required-permissions?status=all")
|
|
->assertSuccessful()
|
|
->assertSee('Blocked', false)
|
|
->assertSeeInOrder([$missingKey, $grantedKey], false);
|
|
});
|