TenantAtlas/apps/platform/tests/Unit/Support/CreateUserWithTenantProfilesTest.php
ahmido d8e331e92f Spec 207: implement shared test fixture slimming (#240)
## Summary
- implement the canonical shared fixture profile model with minimal, standard, and full semantics plus temporary legacy alias resolution
- slim default factory behavior for operation runs, backup sets, provider connections, and provider credentials while keeping explicit heavy opt-in states
- migrate the first console, navigation, RBAC, and drift caller packs to explicit lean helpers and wire lane comparison reporting into the existing Spec 206 seams
- reconcile spec 207 docs, contracts, quickstart guidance, and task tracking with the implemented behavior

## Validation
- `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Unit/Support/CreateUserWithTenantProfilesTest.php tests/Unit/Factories/TenantFactoryTest.php tests/Unit/Factories/OperationRunFactoryTest.php tests/Unit/Factories/BackupSetFactoryTest.php tests/Unit/Factories/ProviderConnectionFactoryTest.php tests/Unit/Factories/ProviderCredentialFactoryTest.php tests/Feature/Guards/FixtureCostProfilesGuardTest.php tests/Feature/Guards/FixtureLaneImpactBudgetTest.php tests/Feature/Guards/TestLaneArtifactsContractTest.php tests/Feature/Console/ReconcileOperationRunsCommandTest.php tests/Feature/Console/ReconcileBackupScheduleOperationRunsCommandTest.php tests/Feature/Navigation/RelatedNavigationResolverMemoizationTest.php tests/Feature/Spec080WorkspaceManagedTenantAdminMigrationTest.php tests/Feature/BaselineDriftEngine/FindingFidelityTest.php`
- `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent`
- `./scripts/platform-test-lane fast-feedback`
- `./scripts/platform-test-lane confidence`
- `./scripts/platform-test-report fast-feedback`
- `./scripts/platform-test-report confidence`

## Lane outcome
- `fast-feedback`: 136.400761s vs 176.73623s baseline, status `improved`
- `confidence`: 394.5669s vs 394.383441s baseline, status `stable`

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #240
2026-04-16 17:29:25 +00:00

122 lines
5.0 KiB
PHP

<?php
declare(strict_types=1);
use App\Models\ProviderConnection;
use App\Models\ProviderCredential;
use App\Models\WorkspaceMembership;
use App\Services\Auth\CapabilityResolver;
use App\Services\Auth\WorkspaceCapabilityResolver;
use App\Support\Workspaces\WorkspaceContext;
use Filament\Facades\Filament;
use Illuminate\Foundation\Testing\RefreshDatabase;
uses(RefreshDatabase::class);
beforeEach(function (): void {
Filament::setTenant(null, true);
});
it('keeps the default tenant helper profile cheap by skipping provider setup and cache clears', function (): void {
$capabilities = \Mockery::mock(CapabilityResolver::class);
$workspaceCapabilities = \Mockery::mock(WorkspaceCapabilityResolver::class);
$capabilities->shouldNotReceive('clearCache');
$workspaceCapabilities->shouldNotReceive('clearCache');
app()->instance(CapabilityResolver::class, $capabilities);
app()->instance(WorkspaceCapabilityResolver::class, $workspaceCapabilities);
[$user, $tenant] = createUserWithTenant();
expect(WorkspaceMembership::query()
->where('workspace_id', (int) $tenant->workspace_id)
->where('user_id', (int) $user->getKey())
->exists())->toBeTrue()
->and(session(WorkspaceContext::SESSION_KEY))->toBe((int) $tenant->workspace_id)
->and(ProviderConnection::query()->where('tenant_id', (int) $tenant->getKey())->exists())->toBeFalse();
});
it('opt-ins a standard provider context only when the canonical standard profile asks for it', function (): void {
$capabilities = \Mockery::mock(CapabilityResolver::class);
$workspaceCapabilities = \Mockery::mock(WorkspaceCapabilityResolver::class);
$capabilities->shouldNotReceive('clearCache');
$workspaceCapabilities->shouldNotReceive('clearCache');
app()->instance(CapabilityResolver::class, $capabilities);
app()->instance(WorkspaceCapabilityResolver::class, $workspaceCapabilities);
[, $tenant] = createStandardUserWithTenant();
$connection = ProviderConnection::query()
->where('tenant_id', (int) $tenant->getKey())
->where('is_default', true)
->first();
expect($connection)->not->toBeNull()
->and($connection?->credential()->exists())->toBeFalse()
->and(Filament::getTenant())->toBeNull();
});
it('keeps the credential-enabled alias explicit without forcing cache or ui side effects', function (): void {
$capabilities = \Mockery::mock(CapabilityResolver::class);
$workspaceCapabilities = \Mockery::mock(WorkspaceCapabilityResolver::class);
$capabilities->shouldNotReceive('clearCache');
$workspaceCapabilities->shouldNotReceive('clearCache');
app()->instance(CapabilityResolver::class, $capabilities);
app()->instance(WorkspaceCapabilityResolver::class, $workspaceCapabilities);
[, $tenant] = createCredentialEnabledUserWithTenant();
$connection = ProviderConnection::query()
->where('tenant_id', (int) $tenant->getKey())
->where('is_default', true)
->first();
expect($connection)->not->toBeNull()
->and($connection?->credential()->exists())->toBeTrue()
->and(ProviderCredential::query()->where('provider_connection_id', (int) $connection?->getKey())->exists())->toBeTrue()
->and(Filament::getTenant())->toBeNull();
});
it('keeps the ui-context alias explicit without provider or credential side effects', function (): void {
$capabilities = \Mockery::mock(CapabilityResolver::class);
$workspaceCapabilities = \Mockery::mock(WorkspaceCapabilityResolver::class);
$capabilities->shouldReceive('clearCache')->once();
$workspaceCapabilities->shouldReceive('clearCache')->once();
app()->instance(CapabilityResolver::class, $capabilities);
app()->instance(WorkspaceCapabilityResolver::class, $workspaceCapabilities);
[, $tenant] = createUiContextUserWithTenant();
expect(ProviderConnection::query()->where('tenant_id', (int) $tenant->getKey())->exists())->toBeFalse()
->and(Filament::getTenant()?->is($tenant))->toBeTrue();
});
it('opt-ins provider, credential, ui-context, and cache resets only when the canonical full profile asks for them', function (): void {
$capabilities = \Mockery::mock(CapabilityResolver::class);
$workspaceCapabilities = \Mockery::mock(WorkspaceCapabilityResolver::class);
$capabilities->shouldReceive('clearCache')->once();
$workspaceCapabilities->shouldReceive('clearCache')->once();
app()->instance(CapabilityResolver::class, $capabilities);
app()->instance(WorkspaceCapabilityResolver::class, $workspaceCapabilities);
[, $tenant] = createFullUserWithTenant();
$connection = ProviderConnection::query()
->where('tenant_id', (int) $tenant->getKey())
->where('is_default', true)
->first();
expect($connection)->not->toBeNull()
->and($connection?->credential()->exists())->toBeTrue()
->and(ProviderCredential::query()->where('provider_connection_id', (int) $connection?->getKey())->exists())->toBeTrue()
->and(Filament::getTenant()?->is($tenant))->toBeTrue();
});