Teren-app/tests/Feature/PermissionRoleBindingTest.php

39 lines
1.4 KiB
PHP

<?php
use App\Models\Permission;
use App\Models\Role;
use App\Models\User;
use Illuminate\Foundation\Testing\RefreshDatabase;
uses(RefreshDatabase::class);
it('binds selected roles to a newly created permission', function () {
// Create admin user with manage-settings permission via a role
$admin = User::factory()->create();
$role = Role::create(['name' => 'Admin', 'slug' => 'admin']);
$admin->roles()->syncWithoutDetaching([$role->id]);
// Grant manage-settings to the role so controller authorize passes
$permManage = Permission::create(['name' => 'Manage Settings', 'slug' => 'manage-settings']);
$role->permissions()->syncWithoutDetaching([$permManage->id]);
// Create some roles to bind
$r1 = Role::create(['name' => 'Editor', 'slug' => 'editor']);
$r2 = Role::create(['name' => 'Viewer', 'slug' => 'viewer']);
// Act
$response = $this->actingAs($admin)
->post(route('admin.permissions.store'), [
'name' => 'Export Data',
'slug' => 'export-data',
'description' => 'Can export data',
'roles' => [$r1->id, $r2->id],
]);
$response->assertRedirect();
$permission = Permission::where('slug', 'export-data')->firstOrFail();
expect($permission->roles()->pluck('slug')->sort()->values()->all())
->toEqualCanonicalizing(['editor', 'viewer']);
});