|
|
@ -33,42 +33,41 @@ class JobPolicyTest extends TestCase |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/** @test */ |
|
|
/** @test */ |
|
|
public function an_admin_can_update_job() |
|
|
|
|
|
|
|
|
public function a_worker_only_can_view_jobs_that_has_been_assigned_to_them() |
|
|
{ |
|
|
{ |
|
|
$admin = $this->createUser('admin'); |
|
|
|
|
|
|
|
|
$worker = $this->createUser('worker'); |
|
|
$job = factory(Job::class)->create(); |
|
|
$job = factory(Job::class)->create(); |
|
|
|
|
|
|
|
|
$this->assertTrue($admin->can('update', $job)); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/** @test */ |
|
|
|
|
|
public function a_worker_can_only_update_job_that_assigned_to_them() |
|
|
|
|
|
{ |
|
|
|
|
|
$assignedWorker = $this->createUser('worker'); |
|
|
|
|
|
$job = factory(Job::class)->create(['worker_id' => $assignedWorker->id]); |
|
|
|
|
|
|
|
|
|
|
|
$this->assertTrue($assignedWorker->can('update', $job)); |
|
|
|
|
|
|
|
|
// Worker cannot view the job
|
|
|
|
|
|
$this->assertFalse($worker->can('view', $job)); |
|
|
|
|
|
|
|
|
$otherWorker = $this->createUser('worker'); |
|
|
|
|
|
|
|
|
// Assign the job to the worker
|
|
|
|
|
|
$job->worker_id = $worker->id; |
|
|
|
|
|
$job->save(); |
|
|
|
|
|
|
|
|
$this->assertFalse($otherWorker->can('update', $job)); |
|
|
|
|
|
|
|
|
// Worker can view the job
|
|
|
|
|
|
$this->assertTrue($worker->can('view', $job)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/** @test */ |
|
|
/** @test */ |
|
|
public function an_admin_can_delete_job() |
|
|
|
|
|
|
|
|
public function only_admin_can_update_job() |
|
|
{ |
|
|
{ |
|
|
$admin = $this->createUser('admin'); |
|
|
$admin = $this->createUser('admin'); |
|
|
$job = factory(Job::class)->create(); |
|
|
|
|
|
|
|
|
$worker = $this->createUser('worker'); |
|
|
|
|
|
$job = factory(Job::class)->create(['worker_id' => $worker->id]); |
|
|
|
|
|
|
|
|
$this->assertTrue($admin->can('delete', $job)); |
|
|
|
|
|
|
|
|
$this->assertTrue($admin->can('update', $job)); |
|
|
|
|
|
$this->assertFalse($worker->can('update', $job)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/** @test */ |
|
|
/** @test */ |
|
|
public function a_worker_cannot_delete_job() |
|
|
|
|
|
|
|
|
public function only_admin_can_delete_job() |
|
|
{ |
|
|
{ |
|
|
|
|
|
$admin = $this->createUser('admin'); |
|
|
$worker = $this->createUser('worker'); |
|
|
$worker = $this->createUser('worker'); |
|
|
$job = factory(Job::class)->create(); |
|
|
|
|
|
|
|
|
$job = factory(Job::class)->create(['worker_id' => $worker->id]); |
|
|
|
|
|
|
|
|
$this->assertFalse($worker->can('delete', $job)); |
|
|
|
|
|
|
|
|
$this->assertTrue($admin->can('update', $job)); |
|
|
|
|
|
$this->assertFalse($worker->can('update', $job)); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |