Files
solidtime/tests/Unit/Model/UserModelTest.php
T
2024-11-05 12:09:04 +01:00

207 lines
6.3 KiB
PHP

<?php
declare(strict_types=1);
namespace Tests\Unit\Model;
use App\Enums\Role;
use App\Models\Member;
use App\Models\Organization;
use App\Models\ProjectMember;
use App\Models\TimeEntry;
use App\Models\User;
use App\Providers\Filament\AdminPanelProvider;
use Filament\Panel;
use Illuminate\Support\Facades\Config;
use Laravel\Passport\AuthCode;
use Laravel\Passport\Client;
use Laravel\Passport\Token;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\UsesClass;
#[CoversClass(User::class)]
#[UsesClass(User::class)]
class UserModelTest extends ModelTestAbstract
{
public function test_normal_user_can_not_access_admin_panel(): void
{
// Arrange
Config::set('auth.super_admins', ['some@email.test', 'other@email.test']);
$user = User::factory()->create();
$panelProvider = new AdminPanelProvider(app());
$mainPanel = $panelProvider->panel(Panel::make());
// Act
$canAccess = $user->canAccessPanel($mainPanel);
// Assert
$this->assertFalse($canAccess);
}
public function test_user_in_super_admin_config_can_access_admin_panel(): void
{
// Arrange
Config::set('auth.super_admins', ['some@email.test', 'other@email.test']);
$user = User::factory()->create([
'email' => 'some@email.test',
]);
$panelProvider = new AdminPanelProvider(app());
$mainPanel = $panelProvider->panel(Panel::make());
// Act
$canAccess = $user->canAccessPanel($mainPanel);
// Assert
$this->assertTrue($canAccess);
}
public function test_scope_belongs_to_organization_returns_only_users_of_organization_including_owners(): void
{
// Arrange
$owner = User::factory()->create();
$organization = Organization::factory()->withOwner($owner)->create();
$user = User::factory()->create();
$user->organizations()->attach($organization, [
'role' => Role::Employee->value,
]);
$otherOrganization = Organization::factory()->create();
$otherUser = User::factory()->create();
$otherUser->organizations()->attach($otherOrganization, [
'role' => Role::Employee->value,
]);
// Act
$users = User::query()
->belongsToOrganization($organization)
->get();
// Assert
$this->assertCount(2, $users);
$userIds = $users->pluck('id')->toArray();
$this->assertContains($user->getKey(), $userIds);
$this->assertContains($owner->getKey(), $userIds);
}
public function test_it_has_many_time_entries(): void
{
// Arrange
$user = User::factory()->create();
$timeEntries = TimeEntry::factory()->forUser($user)->createMany(3);
// Act
$user->refresh();
$timeEntriesRel = $user->timeEntries;
// Assert
$this->assertNotNull($timeEntriesRel);
$this->assertCount(3, $timeEntriesRel);
$this->assertEqualsCanonicalizing(
$timeEntries->pluck('id')->toArray(),
$timeEntriesRel->pluck('id')->toArray()
);
}
public function test_it_has_many_project_members(): void
{
// Arrange
$user = User::factory()->create();
$otherUser = User::factory()->create();
$member = Member::factory()->forUser($user)->create();
$otherMember = Member::factory()->forUser($otherUser)->create();
$projectMembers = ProjectMember::factory()->forMember($member)->createMany(3);
$otherProjectMembers = ProjectMember::factory()->forMember($otherMember)->createMany(3);
// Act
$user->refresh();
$projectMembersRel = $user->projectMembers;
// Assert
$this->assertNotNull($projectMembersRel);
$this->assertCount(3, $projectMembersRel);
$this->assertEqualsCanonicalizing(
$projectMembers->pluck('id')->toArray(),
$projectMembersRel->pluck('id')->toArray()
);
}
public function test_scope_active_returns_only_non_placeholder_users(): void
{
// Arrange
$placeholder = User::factory()->create([
'is_placeholder' => true,
]);
$user = User::factory()->create([
'is_placeholder' => false,
]);
// Act
$activeUsers = User::query()->active()->get();
// Assert
$this->assertCount(1, $activeUsers);
$this->assertTrue($activeUsers->first()->is($user));
}
public function test_it_has_many_access_tokens(): void
{
// Arrange
$user = User::factory()->create();
$client = new Client;
$client->name = 'desktop';
$client->redirect = 'solidtime://oauth/callback';
$client->personal_access_client = false;
$client->password_client = false;
$client->revoked = false;
$client->save();
$token = new Token;
$token->id = 'some-id';
$token->user_id = $user->getKey();
$token->client_id = $client->getKey();
$token->revoked = false;
$token->save();
// Act
$user->refresh();
$tokensRel = $user->accessTokens;
// Assert
$this->assertNotNull($tokensRel);
$this->assertCount(1, $tokensRel);
$this->assertEqualsCanonicalizing(
[$token->getKey()],
$tokensRel->pluck('id')->toArray()
);
}
public function test_it_has_many_auth_codes(): void
{
// Arrange
$user = User::factory()->create();
$client = new Client;
$client->name = 'desktop';
$client->redirect = 'solidtime://oauth/callback';
$client->personal_access_client = false;
$client->password_client = false;
$client->revoked = false;
$client->save();
$authCode = new AuthCode;
$authCode->id = 'some-id';
$authCode->user_id = $user->getKey();
$authCode->client_id = $client->getKey();
$authCode->revoked = false;
$authCode->save();
// Act
$user->refresh();
$authCodesRel = $user->authCodes;
// Assert
$this->assertNotNull($authCodesRel);
$this->assertCount(1, $authCodesRel);
$this->assertEqualsCanonicalizing(
[$authCode->getKey()],
$authCodesRel->pluck('id')->toArray()
);
}
}