144 lines
4.1 KiB
PHP
144 lines
4.1 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature\ProjectMembers;
|
|
|
|
use App\Models\Project;
|
|
use App\Models\User;
|
|
use Illuminate\Foundation\Testing\WithFaker;
|
|
use Tests\Facades\UserFactory;
|
|
use Tests\Facades\ProjectFactory;
|
|
use Tests\TestCase;
|
|
|
|
class BulkEditTest extends TestCase
|
|
{
|
|
use WithFaker;
|
|
|
|
private const URI = 'project-members/bulk-edit';
|
|
|
|
/** @var User $admin */
|
|
private User $admin;
|
|
/** @var User $manager */
|
|
private User $manager;
|
|
/** @var User $auditor */
|
|
private User $auditor;
|
|
/** @var User $user */
|
|
private User $user;
|
|
|
|
/** @var User $projectManager */
|
|
private User $projectManager;
|
|
/** @var User $projectAuditor */
|
|
private User $projectAuditor;
|
|
/** @var User $projectUser */
|
|
private User $projectUser;
|
|
|
|
/** @var Project $project */
|
|
private Project $project;
|
|
|
|
|
|
protected function setUp(): void
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->admin = UserFactory::refresh()->asAdmin()->withTokens()->create();
|
|
$this->manager = UserFactory::refresh()->asManager()->withTokens()->create();
|
|
$this->auditor = UserFactory::refresh()->asAuditor()->withTokens()->create();
|
|
$this->user = UserFactory::refresh()->asUser()->withTokens()->create();
|
|
|
|
$this->project = ProjectFactory::create();
|
|
|
|
$this->projectManager = UserFactory::refresh()->asUser()->withTokens()->create();
|
|
$this->projectManager->projects()->attach($this->project->id, ['role_id' => 1]);
|
|
|
|
$this->projectAuditor = UserFactory::refresh()->asUser()->withTokens()->create();
|
|
$this->projectAuditor->projects()->attach($this->project->id, ['role_id' => 3]);
|
|
|
|
$this->projectUser = UserFactory::refresh()->asUser()->withTokens()->create();
|
|
$this->projectUser->projects()->attach($this->project->id, ['role_id' => 2]);
|
|
}
|
|
|
|
public function test_bulk_edit_as_admin(): void
|
|
{
|
|
$response = $this->actingAs($this->admin)->postJson(self::URI, $this->generateRequest());
|
|
|
|
$response->assertOk();
|
|
}
|
|
|
|
public function test_bulk_edit_as_manager(): void
|
|
{
|
|
$response = $this->actingAs($this->manager)->postJson(self::URI, $this->generateRequest());
|
|
|
|
$response->assertOk();
|
|
}
|
|
|
|
public function test_bulk_edit_as_auditor(): void
|
|
{
|
|
$response = $this->actingAs($this->auditor)->postJson(self::URI, $this->generateRequest());
|
|
|
|
$response->assertForbidden();
|
|
}
|
|
|
|
public function test_bulk_edit_as_user(): void
|
|
{
|
|
$response = $this->actingAs($this->user)->postJson(self::URI, $this->generateRequest());
|
|
|
|
$response->assertForbidden();
|
|
}
|
|
|
|
public function test_bulk_edit_as_project_manager(): void
|
|
{
|
|
$response = $this->actingAs($this->projectManager)->postJson(self::URI, $this->generateRequest());
|
|
|
|
$response->assertOk();
|
|
}
|
|
|
|
public function test_bulk_edit_as_project_auditor(): void
|
|
{
|
|
$response = $this->actingAs($this->projectAuditor)->postJson(self::URI, $this->generateRequest());
|
|
|
|
$response->assertForbidden();
|
|
}
|
|
|
|
public function test_bulk_edit_as_project_user(): void
|
|
{
|
|
$response = $this->actingAs($this->projectUser)->postJson(self::URI, $this->generateRequest());
|
|
|
|
$response->assertForbidden();
|
|
}
|
|
|
|
public function test_not_existing_project(): void
|
|
{
|
|
$this->project->id = $this->faker->randomNumber();
|
|
|
|
$response = $this->actingAs($this->admin)->postJson(self::URI, $this->generateRequest());
|
|
|
|
$response->assertValidationError();
|
|
}
|
|
|
|
public function test_unauthorized(): void
|
|
{
|
|
$response = $this->postJson(self::URI);
|
|
|
|
$response->assertUnauthorized();
|
|
}
|
|
|
|
public function test_without_params(): void
|
|
{
|
|
$response = $this->actingAs($this->admin)->postJson(self::URI);
|
|
|
|
$response->assertValidationError();
|
|
}
|
|
|
|
private function generateRequest(): array
|
|
{
|
|
return [
|
|
'project_id' => $this->project->id,
|
|
'user_roles' => [
|
|
[
|
|
'user_id' => UserFactory::refresh()->asUser()->create()->id,
|
|
'role_id' => $this->faker->numberBetween(1, 3),
|
|
]
|
|
],
|
|
];
|
|
}
|
|
}
|