TenantAtlas/apps/platform/tests/Browser/Spec281ProviderConnectionScopeSmokeTest.php
ahmido 292d555eac refactor: consolidate internal tenant model naming (#355)
## Summary
- consolidate internal platform naming from `Tenant` to `Environment` / `ManagedEnvironment` across models, controllers, services, and Filament resources
- rename environment-scoped UI surfaces such as dashboards, chooser flows, navigation, and related widgets to match the updated environment-first domain language
- align middleware, onboarding/review lifecycle services, jobs, and route/context controllers with the new environment-scoped architecture

## Validation
- not rerun as part of this commit/push/PR request

## Notes
- branch is 1 commit ahead of `platform-dev`
- main commit: `refactor: consolidate internal tenant model naming`

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #355
2026-05-14 11:13:28 +00:00

93 lines
3.6 KiB
PHP

<?php
declare(strict_types=1);
use App\Filament\Resources\ProviderConnectionResource;
use App\Models\ManagedEnvironment;
use App\Models\ProviderConnection;
use App\Models\ManagedEnvironmentOnboardingSession;
use App\Support\ManagedEnvironmentLinks;
use App\Support\Workspaces\WorkspaceContext;
use Illuminate\Foundation\Testing\RefreshDatabase;
uses(RefreshDatabase::class);
pest()->browser()->timeout(20_000);
it('smokes provider-connection detail and managed-environment related provider summary continuity', function (): void {
[$user, $tenant] = createUserWithTenant(
role: 'owner',
workspaceRole: 'manager',
ensureDefaultMicrosoftProviderConnection: false,
);
$tenant->forceFill([
'name' => 'Spec 281 Browser Environment',
'managed_environment_id' => '88888888-8888-8888-8888-888888888888',
'status' => ManagedEnvironment::STATUS_ONBOARDING,
])->save();
$connection = ProviderConnection::factory()->consentGranted()->create([
'workspace_id' => (int) $tenant->workspace_id,
'managed_environment_id' => (int) $tenant->getKey(),
'provider' => 'microsoft',
'display_name' => 'Spec 281 Browser Connection',
'entra_tenant_id' => '88888888-8888-8888-8888-888888888888',
'is_default' => true,
'verification_status' => 'healthy',
]);
$draft = ManagedEnvironmentOnboardingSession::query()->create([
'workspace_id' => (int) $tenant->workspace_id,
'managed_environment_id' => (int) $tenant->getKey(),
'entra_tenant_id' => '88888888-8888-8888-8888-888888888888',
'current_step' => 'connection',
'state' => [
'provider_connection_id' => (int) $connection->getKey(),
],
'started_by_user_id' => (int) $user->getKey(),
'updated_by_user_id' => (int) $user->getKey(),
]);
$this->actingAs($user)->withSession([
WorkspaceContext::SESSION_KEY => (int) $tenant->workspace_id,
WorkspaceContext::LAST_TENANT_IDS_SESSION_KEY => [
(string) $tenant->workspace_id => (int) $tenant->getKey(),
],
]);
$providerConnectionViewPath = (string) parse_url(ProviderConnectionResource::getUrl('view', [
'record' => $connection,
'managed_environment_id' => $tenant->external_id,
], panel: 'admin'), PHP_URL_PATH);
$tenantViewPath = (string) parse_url(ManagedEnvironmentLinks::viewUrl($tenant), PHP_URL_PATH);
visit(ProviderConnectionResource::getUrl('view', [
'record' => $connection,
'managed_environment_id' => $tenant->external_id,
], panel: 'admin'))
->waitForText('Spec 281 Browser Connection')
->assertScript("window.location.pathname === '{$providerConnectionViewPath}'", true)
->assertSee('Target scope')
->assertSee('Spec 281 Browser Environment')
->assertSee('Provider context')
->assertSee('Microsoft tenant ID')
->assertNoJavaScriptErrors()
->assertNoConsoleLogs();
visit(route('admin.onboarding.draft', ['onboardingDraft' => (int) $draft->getKey()]))
->waitForText('Provider connection')
->assertSee('Ready - Spec 281 Browser Environment')
->assertSee('Spec 281 Browser Environment')
->assertNoJavaScriptErrors()
->assertNoConsoleLogs();
visit(ManagedEnvironmentLinks::viewUrl($tenant))
->waitForText('Provider connection')
->assertScript("window.location.pathname === '{$tenantViewPath}'", true)
->assertSee('Spec 281 Browser Connection')
->assertSee('Spec 281 Browser Environment')
->assertNoJavaScriptErrors()
->assertNoConsoleLogs();
});