create(); [$user, $tenantA] = createUserWithTenant(tenant: $tenantA, role: 'owner'); $tenantB = Tenant::factory()->create(['workspace_id' => (int) $tenantA->workspace_id]); createUserWithTenant(tenant: $tenantB, user: $user, role: 'owner'); $policyA = Policy::factory()->for($tenantA)->create(['display_name' => 'Remembered tenant policy']); $policyB = Policy::factory()->for($tenantB)->create(['display_name' => 'Other tenant policy']); $this->actingAs($user); Filament::setCurrentPanel('admin'); Filament::setTenant(null, true); Filament::bootCurrentPanel(); session()->put(WorkspaceContext::SESSION_KEY, (int) $tenantA->workspace_id); session()->put(WorkspaceContext::LAST_TENANT_IDS_SESSION_KEY, [ (string) $tenantA->workspace_id => (int) $tenantA->getKey(), ]); Livewire::actingAs($user)->test(ListPolicies::class) ->assertCanSeeTableRecords([$policyA]) ->assertCanNotSeeTableRecords([$policyB]); }); it('renders remembered canonical tenant policy detail with shared normalized settings markers', function (): void { $tenantA = Tenant::factory()->create(); [$user, $tenantA] = createUserWithTenant(tenant: $tenantA, role: 'owner'); $tenantB = Tenant::factory()->create(['workspace_id' => (int) $tenantA->workspace_id]); createUserWithTenant(tenant: $tenantB, user: $user, role: 'owner'); $policyA = Policy::factory()->for($tenantA)->create(['display_name' => 'Remembered tenant policy']); $policyB = Policy::factory()->for($tenantB)->create(['display_name' => 'Other tenant policy']); PolicyVersion::factory()->for($tenantA)->for($policyA)->create([ 'version_number' => 1, 'policy_type' => $policyA->policy_type, 'platform' => $policyA->platform, 'created_by' => 'tester@example.com', 'captured_at' => CarbonImmutable::now(), 'snapshot' => [ '@odata.type' => '#microsoft.graph.windows10CustomConfiguration', 'omaSettings' => [ [ 'displayName' => 'Setting A', 'omaUri' => './Vendor/MSFT/SettingA', 'value' => 'Enabled', ], ], ], ]); PolicyVersion::factory()->for($tenantB)->for($policyB)->create([ 'version_number' => 1, 'policy_type' => $policyB->policy_type, 'platform' => $policyB->platform, 'created_by' => 'tester@example.com', 'captured_at' => CarbonImmutable::now(), 'snapshot' => [ '@odata.type' => '#microsoft.graph.windows10CustomConfiguration', 'omaSettings' => [], ], ]); $this->actingAs($user); Filament::setCurrentPanel('admin'); Filament::setTenant(null, true); Filament::bootCurrentPanel(); $session = [ WorkspaceContext::SESSION_KEY => (int) $tenantA->workspace_id, WorkspaceContext::LAST_TENANT_IDS_SESSION_KEY => [ (string) $tenantA->workspace_id => (int) $tenantA->getKey(), ], ]; $response = $this->withSession($session) ->get(\App\Filament\Resources\PolicyResource::getUrl('view', ['record' => $policyA], panel: 'admin')); $response->assertSuccessful()->assertSee('Setting A'); expect($response->getContent()) ->toContain('data-shared-detail-family="normalized-settings"') ->toContain('data-shared-normalized-settings-host="policy"'); $this->withSession($session) ->get(\App\Filament\Resources\PolicyResource::getUrl('view', ['record' => $policyB], panel: 'admin')) ->assertNotFound(); });