create(); [$user, $tenantA] = createUserWithTenant(tenant: $tenantA, role: 'manager'); $tenantB = Tenant::factory()->create(['workspace_id' => (int) $tenantA->workspace_id]); createUserWithTenant(tenant: $tenantB, user: $user, role: 'manager'); $findingA = Finding::factory()->for($tenantA)->create([ 'subject_external_id' => 'finding-a', 'evidence_jsonb' => ['display_name' => 'Remembered finding'], ]); $findingB = Finding::factory()->for($tenantB)->create([ 'subject_external_id' => 'finding-b', 'evidence_jsonb' => ['display_name' => 'Other finding'], ]); $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(ListFindings::class) ->assertCanSeeTableRecords([$findingA]) ->assertCanNotSeeTableRecords([$findingB]); }); it('returns not found for admin finding detail outside the remembered canonical tenant', function (): void { $tenantA = Tenant::factory()->create(); [$user, $tenantA] = createUserWithTenant(tenant: $tenantA, role: 'manager'); $tenantB = Tenant::factory()->create(['workspace_id' => (int) $tenantA->workspace_id]); createUserWithTenant(tenant: $tenantB, user: $user, role: 'manager'); $findingA = Finding::factory()->for($tenantA)->create(); $findingB = Finding::factory()->for($tenantB)->create(); $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(), ], ]; $this->withSession($session) ->get(FindingResource::getUrl('view', ['record' => $findingA], panel: 'admin')) ->assertSuccessful(); $this->withSession($session) ->get(FindingResource::getUrl('view', ['record' => $findingB], panel: 'admin')) ->assertNotFound(); });