Merge pull request #561 from batuhawk/1.3-dev

Permission and Role tests
This commit is contained in:
Batuhan 2018-10-19 19:44:33 +03:00 committed by GitHub
commit 0abf3eae57
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 260 additions and 0 deletions

View 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),
];
}
}

View 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(),
];
}
}

View 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,
];
}
}