2023-06-06 16:31:14 -07:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Tests\Unit;
|
|
|
|
|
2024-08-06 13:25:21 -07:00
|
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
2023-06-06 16:31:14 -07:00
|
|
|
use App\Models\Accessory;
|
|
|
|
use App\Models\Asset;
|
|
|
|
use App\Models\AssetMaintenance;
|
|
|
|
use App\Models\Company;
|
|
|
|
use App\Models\Component;
|
|
|
|
use App\Models\Consumable;
|
|
|
|
use App\Models\License;
|
|
|
|
use App\Models\LicenseSeat;
|
|
|
|
use App\Models\User;
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
|
|
|
use Tests\TestCase;
|
|
|
|
|
2024-08-06 13:25:22 -07:00
|
|
|
final class CompanyScopingTest extends TestCase
|
2023-06-06 16:31:14 -07:00
|
|
|
{
|
2024-08-06 13:25:21 -07:00
|
|
|
public static function models(): array
|
2023-06-06 16:31:14 -07:00
|
|
|
{
|
|
|
|
return [
|
|
|
|
'Accessories' => [Accessory::class],
|
|
|
|
'Assets' => [Asset::class],
|
|
|
|
'Components' => [Component::class],
|
|
|
|
'Consumables' => [Consumable::class],
|
|
|
|
'Licenses' => [License::class],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2024-08-06 13:25:21 -07:00
|
|
|
#[DataProvider('models')]
|
2024-08-06 13:25:22 -07:00
|
|
|
public function testCompanyScoping($model): void
|
2023-06-06 16:31:14 -07:00
|
|
|
{
|
|
|
|
[$companyA, $companyB] = Company::factory()->count(2)->create();
|
|
|
|
|
|
|
|
$modelA = $model::factory()->for($companyA)->create();
|
|
|
|
$modelB = $model::factory()->for($companyB)->create();
|
|
|
|
|
|
|
|
$superUser = $companyA->users()->save(User::factory()->superuser()->make());
|
|
|
|
$userInCompanyA = $companyA->users()->save(User::factory()->make());
|
|
|
|
$userInCompanyB = $companyB->users()->save(User::factory()->make());
|
|
|
|
|
|
|
|
$this->settings->disableMultipleFullCompanySupport();
|
|
|
|
|
|
|
|
$this->actingAs($superUser);
|
|
|
|
$this->assertCanSee($modelA);
|
|
|
|
$this->assertCanSee($modelB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyA);
|
|
|
|
$this->assertCanSee($modelA);
|
|
|
|
$this->assertCanSee($modelB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyB);
|
|
|
|
$this->assertCanSee($modelA);
|
|
|
|
$this->assertCanSee($modelB);
|
|
|
|
|
|
|
|
$this->settings->enableMultipleFullCompanySupport();
|
|
|
|
|
|
|
|
$this->actingAs($superUser);
|
|
|
|
$this->assertCanSee($modelA);
|
|
|
|
$this->assertCanSee($modelB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyA);
|
|
|
|
$this->assertCanSee($modelA);
|
|
|
|
$this->assertCannotSee($modelB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyB);
|
|
|
|
$this->assertCannotSee($modelA);
|
|
|
|
$this->assertCanSee($modelB);
|
|
|
|
}
|
|
|
|
|
2024-08-06 13:25:22 -07:00
|
|
|
public function testAssetMaintenanceCompanyScoping(): void
|
2023-06-06 16:31:14 -07:00
|
|
|
{
|
|
|
|
[$companyA, $companyB] = Company::factory()->count(2)->create();
|
|
|
|
|
|
|
|
$assetMaintenanceForCompanyA = AssetMaintenance::factory()->for(Asset::factory()->for($companyA))->create();
|
|
|
|
$assetMaintenanceForCompanyB = AssetMaintenance::factory()->for(Asset::factory()->for($companyB))->create();
|
|
|
|
|
|
|
|
$superUser = $companyA->users()->save(User::factory()->superuser()->make());
|
|
|
|
$userInCompanyA = $companyA->users()->save(User::factory()->make());
|
|
|
|
$userInCompanyB = $companyB->users()->save(User::factory()->make());
|
|
|
|
|
|
|
|
$this->settings->disableMultipleFullCompanySupport();
|
|
|
|
|
|
|
|
$this->actingAs($superUser);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyA);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyA);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyA);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyB);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyA);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyB);
|
|
|
|
|
|
|
|
$this->settings->enableMultipleFullCompanySupport();
|
|
|
|
|
|
|
|
$this->actingAs($superUser);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyA);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyA);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyA);
|
|
|
|
$this->assertCannotSee($assetMaintenanceForCompanyB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyB);
|
|
|
|
$this->assertCannotSee($assetMaintenanceForCompanyA);
|
|
|
|
$this->assertCanSee($assetMaintenanceForCompanyB);
|
|
|
|
}
|
|
|
|
|
2024-08-06 13:25:22 -07:00
|
|
|
public function testLicenseSeatCompanyScoping(): void
|
2023-06-06 16:31:14 -07:00
|
|
|
{
|
|
|
|
[$companyA, $companyB] = Company::factory()->count(2)->create();
|
|
|
|
|
|
|
|
$licenseSeatA = LicenseSeat::factory()->for(Asset::factory()->for($companyA))->create();
|
|
|
|
$licenseSeatB = LicenseSeat::factory()->for(Asset::factory()->for($companyB))->create();
|
|
|
|
|
|
|
|
$superUser = $companyA->users()->save(User::factory()->superuser()->make());
|
|
|
|
$userInCompanyA = $companyA->users()->save(User::factory()->make());
|
|
|
|
$userInCompanyB = $companyB->users()->save(User::factory()->make());
|
|
|
|
|
|
|
|
$this->settings->disableMultipleFullCompanySupport();
|
|
|
|
|
|
|
|
$this->actingAs($superUser);
|
|
|
|
$this->assertCanSee($licenseSeatA);
|
|
|
|
$this->assertCanSee($licenseSeatB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyA);
|
|
|
|
$this->assertCanSee($licenseSeatA);
|
|
|
|
$this->assertCanSee($licenseSeatB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyB);
|
|
|
|
$this->assertCanSee($licenseSeatA);
|
|
|
|
$this->assertCanSee($licenseSeatB);
|
|
|
|
|
|
|
|
$this->settings->enableMultipleFullCompanySupport();
|
|
|
|
|
|
|
|
$this->actingAs($superUser);
|
|
|
|
$this->assertCanSee($licenseSeatA);
|
|
|
|
$this->assertCanSee($licenseSeatB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyA);
|
|
|
|
$this->assertCanSee($licenseSeatA);
|
|
|
|
$this->assertCannotSee($licenseSeatB);
|
|
|
|
|
|
|
|
$this->actingAs($userInCompanyB);
|
|
|
|
$this->assertCannotSee($licenseSeatA);
|
|
|
|
$this->assertCanSee($licenseSeatB);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function assertCanSee(Model $model)
|
|
|
|
{
|
|
|
|
$this->assertTrue(
|
|
|
|
get_class($model)::all()->contains($model),
|
|
|
|
'User was not able to see expected model'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function assertCannotSee(Model $model)
|
|
|
|
{
|
|
|
|
$this->assertFalse(
|
|
|
|
get_class($model)::all()->contains($model),
|
|
|
|
'User was able to see model from a different company'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|