#591 - profile, users and projects

This commit is contained in:
Saeed Vaziry
2025-05-18 18:25:27 +02:00
parent edd4ba1bc2
commit 8b4d156afa
67 changed files with 1467 additions and 760 deletions

View File

@ -5,10 +5,8 @@
use App\Enums\UserRole;
use App\Models\Project;
use App\Models\User;
use App\Web\Pages\Settings\Users\Index;
use App\Web\Pages\Settings\Users\Widgets\UsersList;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Livewire\Livewire;
use Inertia\Testing\AssertableInertia as Assert;
use Tests\TestCase;
class UserTest extends TestCase
@ -19,13 +17,14 @@ public function test_create_user(): void
{
$this->actingAs($this->user);
Livewire::test(Index::class)
->callAction('create', [
'name' => 'new user',
'email' => 'newuser@example.com',
'password' => 'password',
'role' => UserRole::USER,
]);
$this->post(route('users.store'), [
'name' => 'new user',
'email' => 'newuser@example.com',
'password' => 'password',
'role' => UserRole::USER,
])
->assertSessionDoesntHaveErrors()
->assertRedirect(route('users'));
$this->assertDatabaseHas('users', [
'name' => 'new user',
@ -38,13 +37,11 @@ public function test_see_users_list(): void
{
$this->actingAs($this->user);
$user = User::factory()->create();
User::factory()->create();
$this->get(Index::getUrl())
->assertSuccessful();
Livewire::test(UsersList::class)
->assertCanSeeTableRecords([$user]);
$this->get(route('users'))
->assertSuccessful()
->assertInertia(fn (Assert $page) => $page->component('users/index'));
}
public function test_must_be_admin_to_see_users_list(): void
@ -54,7 +51,7 @@ public function test_must_be_admin_to_see_users_list(): void
$this->actingAs($this->user);
$this->get(Index::getUrl())
$this->get(route('users'))
->assertForbidden();
}
@ -64,8 +61,9 @@ public function test_delete_user(): void
$user = User::factory()->create();
Livewire::test(UsersList::class)
->callTableAction('delete', $user);
$this->delete(route('users.destroy', $user))
->assertSessionDoesntHaveErrors()
->assertRedirect(route('users'));
$this->assertDatabaseMissing('users', [
'id' => $user->id,
@ -76,8 +74,8 @@ public function test_cannot_delete_yourself(): void
{
$this->actingAs($this->user);
Livewire::test(UsersList::class)
->assertTableActionHidden('delete', $this->user);
$this->delete(route('users.destroy', $this->user))
->assertForbidden();
}
public function test_edit_user_info(): void
@ -86,36 +84,33 @@ public function test_edit_user_info(): void
$user = User::factory()->create();
Livewire::test(UsersList::class)
->callTableAction('edit', $user, [
'name' => 'new-name',
'email' => 'newemail@example.com',
'timezone' => 'Europe/London',
'role' => UserRole::ADMIN,
])
->assertSuccessful();
$this->patch(route('users.update', $user), [
'name' => 'new-name',
'email' => 'newemail@example.com',
'role' => UserRole::ADMIN,
])
->assertRedirect(route('users'));
$this->assertDatabaseHas('users', [
'id' => $user->id,
'name' => 'new-name',
'email' => 'newemail@example.com',
'timezone' => 'Europe/London',
'role' => UserRole::ADMIN,
]);
}
public function test_edit_user_projects(): void
public function test_add_user_to_project(): void
{
$this->actingAs($this->user);
$user = User::factory()->create();
$project = Project::factory()->create();
Livewire::test(UsersList::class)
->callTableAction('update-projects', $user, [
'projects' => [$project->id],
])
->assertSuccessful();
$this->post(route('users.projects.store', $user), [
'project' => $project->id,
])
->assertSessionDoesntHaveErrors()
->assertRedirect(route('users'));
$this->assertDatabaseHas('user_project', [
'user_id' => $user->id,
@ -123,32 +118,22 @@ public function test_edit_user_projects(): void
]);
}
public function test_edit_user_projects_with_current_project(): void
public function test_remove_user_from_project(): void
{
$this->actingAs($this->user);
/** @var User $user */
$user = User::factory()->create();
$user->current_project_id = null;
$user->save();
/** @var Project $project */
$project = Project::factory()->create();
Livewire::test(UsersList::class)
->callTableAction('update-projects', $user, [
'projects' => [$project->id],
])
->assertSuccessful();
$user->projects()->attach($project);
$this->assertDatabaseHas('user_project', [
$this->delete(route('users.projects.destroy', [$user, $project]))
->assertSessionDoesntHaveErrors()
->assertRedirect(route('users'));
$this->assertDatabaseMissing('user_project', [
'user_id' => $user->id,
'project_id' => $project->id,
]);
$this->assertDatabaseHas('users', [
'id' => $user->id,
'current_project_id' => $project->id,
]);
}
}