Merge pull request #561 from batuhawk/1.3-dev
Permission and Role tests
This commit is contained in:
commit
0abf3eae57
84
tests/Feature/Auth/PermissionsTest.php
Normal file
84
tests/Feature/Auth/PermissionsTest.php
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Feature\Auth;
|
||||||
|
|
||||||
|
use App\Models\Auth\Permission;
|
||||||
|
use Tests\Feature\FeatureTestCase;
|
||||||
|
|
||||||
|
class PermissionsTest extends FeatureTestCase
|
||||||
|
{
|
||||||
|
|
||||||
|
public function testItShouldSeePermissionListPage()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('permissions.index'))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSeeText(trans_choice('general.permissions', 2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldSeePermissionCreatePage()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('permissions.create'))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSeeText(trans('general.title.new', ['type' => trans_choice('general.permissions', 1)]));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldCreatePermission()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->post(route('permissions.store'), $this->getPermissionRequest())
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('permissions.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldSeePermissionUpdatePage()
|
||||||
|
{
|
||||||
|
$permission = Permission::create($this->getPermissionRequest());
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('permissions.edit', ['permission' => $permission->id]))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSee($permission->name);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldUpdatePermission()
|
||||||
|
{
|
||||||
|
$request = $this->getPermissionRequest();
|
||||||
|
|
||||||
|
$permission = Permission::create($request);
|
||||||
|
|
||||||
|
$request['name'] = $this->faker->name;
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->patch(route('permissions.update', $permission->id), $request)
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('permissions.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldDeletePermission()
|
||||||
|
{
|
||||||
|
$permission = Permission::create($this->getPermissionRequest());
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->delete(route('permissions.destroy', $permission->id))
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('permissions.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getPermissionRequest()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'name' => $this->faker->text(5),
|
||||||
|
'display_name' => $this->faker->text(5),
|
||||||
|
'description' => $this->faker->text(5),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
85
tests/Feature/Auth/RolesTest.php
Normal file
85
tests/Feature/Auth/RolesTest.php
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Feature\Auth;
|
||||||
|
|
||||||
|
use App\Models\Auth\Permission;
|
||||||
|
use App\Models\Auth\Role;
|
||||||
|
use Tests\Feature\FeatureTestCase;
|
||||||
|
|
||||||
|
class RolesTest extends FeatureTestCase
|
||||||
|
{
|
||||||
|
|
||||||
|
public function testItShouldSeeRoleListPage()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('roles.index'))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSeeText(trans_choice('general.roles', 2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldSeeRoleCreatePage()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('roles.create'))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSeeText(trans('general.title.new', ['type' => trans_choice('general.roles', 1)]));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldCreateRole()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->post(route('roles.store'), $this->getRoleRequest())
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('roles.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldSeeRoleUpdatePage()
|
||||||
|
{
|
||||||
|
$role = Role::create($this->getRoleRequest());
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('roles.edit', ['role' => $role->id]))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSee($role->name);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldUpdateRole()
|
||||||
|
{
|
||||||
|
$request = $this->getRoleRequest();
|
||||||
|
|
||||||
|
$role = Role::create($request);
|
||||||
|
|
||||||
|
$request['name'] = $this->faker->name;
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->patch(route('roles.update', $role->id), $request)
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('roles.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldDeleteRole()
|
||||||
|
{
|
||||||
|
$role = Role::create($this->getRoleRequest());
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->delete(route('roles.destroy', $role->id))
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('roles.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getRoleRequest()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'name' => $this->faker->text(5),
|
||||||
|
'display_name' => $this->faker->text(5),
|
||||||
|
'description' => $this->faker->text(5),
|
||||||
|
'permissions' => Permission::take(10)->pluck('id')->toArray(),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
91
tests/Feature/Auth/UsersTest.php
Normal file
91
tests/Feature/Auth/UsersTest.php
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Feature\Auth;
|
||||||
|
|
||||||
|
use App\Models\Auth\Role;
|
||||||
|
use App\Models\Auth\User;
|
||||||
|
use Tests\Feature\FeatureTestCase;
|
||||||
|
|
||||||
|
class UsersTest extends FeatureTestCase
|
||||||
|
{
|
||||||
|
|
||||||
|
public function testItShouldSeeUserListPage()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('users.index'))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSeeText(trans_choice('general.users', 2));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldSeeUserCreatePage()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('users.create'))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSeeText(trans('general.title.new', ['type' => trans_choice('general.users', 1)]));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldCreateUser()
|
||||||
|
{
|
||||||
|
$this->loginAs()
|
||||||
|
->post(route('users.store'), $this->getUserRequest())
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('users.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldSeeUserUpdatePage()
|
||||||
|
{
|
||||||
|
$user = User::create($this->getUserRequest());
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->get(route('users.edit', ['user' => $user->id]))
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertSee($user->name);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldUpdateUser()
|
||||||
|
{
|
||||||
|
$request = $this->getUserRequest();
|
||||||
|
|
||||||
|
$user = User::create($request);
|
||||||
|
|
||||||
|
$request['name'] = $this->faker->name;
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->patch(route('users.update', $user->id), $request)
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('users.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testItShouldDeleteUser()
|
||||||
|
{
|
||||||
|
$user = User::create($this->getUserRequest());
|
||||||
|
|
||||||
|
$this->loginAs()
|
||||||
|
->delete(route('users.destroy', $user->id))
|
||||||
|
->assertStatus(302)
|
||||||
|
->assertRedirect(route('users.index'));
|
||||||
|
|
||||||
|
$this->assertFlashLevel('success');
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getUserRequest()
|
||||||
|
{
|
||||||
|
$password = $this->faker->password();
|
||||||
|
|
||||||
|
return [
|
||||||
|
'name' => $this->faker->name,
|
||||||
|
'email' => $this->faker->email,
|
||||||
|
'password' => $password,
|
||||||
|
'password_confirmation' => $password,
|
||||||
|
'locale' => 'en-GB',
|
||||||
|
'companies' => [session('company_id')],
|
||||||
|
'roles' => Role::take(1)->pluck('id')->toArray(),
|
||||||
|
'enabled' => $this->faker->boolean ? 1 : 0,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user