|
|
|
@ -3,8 +3,9 @@ |
|
|
|
namespace Tests\Unit\Policies; |
|
|
|
|
|
|
|
use App\User; |
|
|
|
use Tests\TestCase; |
|
|
|
use Illuminate\Foundation\Testing\RefreshDatabase; |
|
|
|
use Illuminate\Support\Str; |
|
|
|
use Tests\TestCase; |
|
|
|
|
|
|
|
class UserPolicyTest extends TestCase |
|
|
|
{ |
|
|
|
@ -13,10 +14,32 @@ class UserPolicyTest extends TestCase |
|
|
|
/** @test */ |
|
|
|
public function manager_can_edit_users_profile() |
|
|
|
{ |
|
|
|
$otherUserManagerId = Str::random(); |
|
|
|
$manager = factory(User::class)->create(); |
|
|
|
$user = factory(User::class)->create(['manager_id' => $manager->id]); |
|
|
|
$otherUser = factory(User::class)->create(['manager_id' => $otherUserManagerId]); |
|
|
|
|
|
|
|
$this->assertTrue($manager->can('edit', $user)); |
|
|
|
$this->assertFalse($manager->can('edit', $otherUser)); |
|
|
|
} |
|
|
|
|
|
|
|
/** @test */ |
|
|
|
public function admins_can_edit_any_user_profile() |
|
|
|
{ |
|
|
|
$adminEmail = 'admin@example.net'; |
|
|
|
$otherUserManagerId = Str::random(); |
|
|
|
putenv('SYSTEM_ADMIN_EMAILS='.$adminEmail); |
|
|
|
|
|
|
|
$manager = factory(User::class)->create(); |
|
|
|
$admin = factory(User::class)->create(['email' => $adminEmail]); |
|
|
|
$user = factory(User::class)->create(['manager_id' => $manager->id]); |
|
|
|
$otherUser = factory(User::class)->create(['manager_id' => $otherUserManagerId]); |
|
|
|
|
|
|
|
$this->assertTrue($admin->can('edit', $user)); |
|
|
|
$this->assertTrue($admin->can('edit', $otherUser)); |
|
|
|
|
|
|
|
$this->assertTrue($manager->can('edit', $user)); |
|
|
|
$this->assertFalse($manager->can('edit', $otherUser)); |
|
|
|
} |
|
|
|
|
|
|
|
/** @test */ |
|
|
|
|