Browse Source

Update project policy for user role authorization

pull/6/head
Nafies Luthfi 8 years ago
parent
commit
7eab331323
  1. 5
      app/Policies/Projects/ProjectPolicy.php
  2. 45
      tests/Unit/Policies/ProjectPolicyTest.php

5
app/Policies/Projects/ProjectPolicy.php

@ -25,8 +25,8 @@ class ProjectPolicy
*/ */
public function view(User $user, Project $project) public function view(User $user, Project $project)
{ {
// User can only view the project if he is the project's agency owner.
return true;
return $user->hasRole('admin')
|| ($user->hasRole('worker') && $user->projects->contains($project->id));
} }
/** /**
@ -39,7 +39,6 @@ class ProjectPolicy
*/ */
public function create(User $user, Project $project) public function create(User $user, Project $project)
{ {
// User can create a project if they owns an agency.
return $user->hasRole('admin'); return $user->hasRole('admin');
} }

45
tests/Unit/Policies/ProjectPolicyTest.php

@ -2,29 +2,24 @@
namespace Tests\Unit\Policies; namespace Tests\Unit\Policies;
use App\Entities\Projects\Job;
use App\Entities\Projects\Project; use App\Entities\Projects\Project;
use Tests\TestCase as TestCase; use Tests\TestCase as TestCase;
class ProjectPolicyTest extends TestCase class ProjectPolicyTest extends TestCase
{ {
/** @test */ /** @test */
public function an_admin_can_create_project()
public function only_admin_can_create_project()
{ {
$admin = $this->createUser('admin'); $admin = $this->createUser('admin');
$this->assertTrue($admin->can('create', new Project()));
}
/** @test */
public function a_worker_cannot_create_project()
{
$worker = $this->createUser('worker'); $worker = $this->createUser('worker');
$this->assertTrue($admin->can('create', new Project()));
$this->assertFalse($worker->can('create', new Project())); $this->assertFalse($worker->can('create', new Project()));
} }
/** @test */ /** @test */
public function an_admin_can_view_project()
public function an_admin_can_view_all_project_detail()
{ {
$admin = $this->createUser('admin'); $admin = $this->createUser('admin');
$project = factory(Project::class)->create(); $project = factory(Project::class)->create();
@ -33,38 +28,42 @@ class ProjectPolicyTest extends TestCase
} }
/** @test */ /** @test */
public function an_admin_can_update_project()
public function a_worker_can_only_view_the_project_in_which_they_are_involved()
{ {
$admin = $this->createUser('admin');
$worker = $this->createUser('worker');
$project = factory(Project::class)->create(); $project = factory(Project::class)->create();
$this->assertTrue($admin->can('update', $project));
}
// Worker cannot view the project
$this->assertFalse($worker->can('view', $project));
/** @test */
public function a_worker_cannot_update_project()
{
$worker = $this->createUser('worker');
$project = factory(Project::class)->create();
// Assign a job to worker on the project
factory(Job::class)->create([
'project_id' => $project->id,
'worker_id' => $worker->id,
]);
$this->assertFalse($worker->can('update', $project));
// Worker can view the project after assignment
$this->assertTrue($worker->fresh()->can('view', $project));
} }
/** @test */ /** @test */
public function an_admin_can_delete_project()
public function only_admin_can_update_project()
{ {
$admin = $this->createUser('admin'); $admin = $this->createUser('admin');
$project = factory(Project::class)->create();
$worker = $this->createUser('worker');
$this->assertTrue($admin->can('delete', $project));
$this->assertTrue($admin->can('update', new Project()));
$this->assertFalse($worker->can('update', new Project()));
} }
/** @test */ /** @test */
public function a_worker_cannot_delete_project()
public function only_admin_can_delete_project()
{ {
$admin = $this->createUser('admin');
$worker = $this->createUser('worker'); $worker = $this->createUser('worker');
$project = factory(Project::class)->create(); $project = factory(Project::class)->create();
$this->assertTrue($admin->can('delete', $project));
$this->assertFalse($worker->can('delete', $project)); $this->assertFalse($worker->can('delete', $project));
} }
} }
Loading…
Cancel
Save