mirror of
https://github.com/solidtime-io/solidtime.git
synced 2026-05-07 20:32:26 +00:00
207 lines
6.3 KiB
PHP
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()
|
|
);
|
|
}
|
|
}
|