Commit 6ebc1d3b authored by Viral Solani's avatar Viral Solani

Manger User Tests

Change Password Tests
parent 00e52fdf
...@@ -160,30 +160,25 @@ class UserRepository extends BaseRepository ...@@ -160,30 +160,25 @@ class UserRepository extends BaseRepository
} }
/** /**
* @param Model $user * Change Password
*
* @param $user
* @param $input * @param $input
* *
* @throws GeneralException * @throws GeneralException
* *
* @return bool * @return bool
*/ */
public function updatePassword(Model $user, $input) public function updatePassword($user, $input)
{ {
$user = $this->find(access()->id()); $user = $this->find(access()->id());
if (Hash::check($input['old_password'], $user->password)) { if (Hash::check($input['old_password'], $user->password)) {
$user->password = bcrypt($input['password']);
if ($user->save()) {
$input['email'] = $user->email;
// Send email to the user $user->password = bcrypt($input['password']);
$options = [
'data' => $input,
'email_template_type' => 4,
];
createNotification('', $user->id, 2, $options);
if ($user->save()) {
event(new UserPasswordChanged($user)); event(new UserPasswordChanged($user));
return true; return true;
} }
...@@ -200,7 +195,7 @@ class UserRepository extends BaseRepository ...@@ -200,7 +195,7 @@ class UserRepository extends BaseRepository
* *
* @return bool * @return bool
*/ */
public function delete(Model $user) public function delete($user)
{ {
if (access()->id() == $user->id) { if (access()->id() == $user->id) {
throw new GeneralException(trans('exceptions.backend.access.users.cant_delete_self')); throw new GeneralException(trans('exceptions.backend.access.users.cant_delete_self'));
......
...@@ -66,7 +66,7 @@ return [ ...@@ -66,7 +66,7 @@ return [
'active' => 'Active Users', 'active' => 'Active Users',
'all_permissions' => 'All Permissions', 'all_permissions' => 'All Permissions',
'change_password' => 'Change Password', 'change_password' => 'Change Password',
'change_password_for' => 'Change Password :user', 'change_password_for' => 'Change Password for :user',
'create' => 'Create User', 'create' => 'Create User',
'deactivated' => 'Deactivated Users', 'deactivated' => 'Deactivated Users',
'deleted' => 'Deleted Users', 'deleted' => 'Deleted Users',
......
<?php
namespace Tests\Feature\Backend;
use Tests\TestCase;
use Illuminate\Support\Facades\Event;
use App\Events\Backend\Access\User\UserPasswordChanged;
class ChangePasswordTest extends TestCase
{
/** @test */
public function a_user_require_old_password_to_change_password()
{
$data = [];
$data['old_password'] = '12345';
$data['password'] = 'Viral@1234';
$data['password_confirmation'] = 'Viral@1234';
$this->withExceptionHandling()
->actingAs($this->admin)
->patch(route('admin.access.user.change-password', $this->admin), $data)
->assertSessionHas(['flash_danger' => trans('exceptions.backend.access.users.change_mismatch')]);
}
/** @test */
public function a_user_require_strong_password_to_change_password()
{
$data = [];
$data['old_password'] = '1234';
$data['password'] = '12345678';
$data['password_confirmation'] = '12345678';
$this->withExceptionHandling()
->actingAs($this->admin)
->patch(route('admin.access.user.change-password', $this->admin), $data)
->assertSessionHas('The given data was invalid.');
}
/** @test */
public function a_user_can_change_password()
{
Event::fake();
$data = [];
$data['old_password'] = '1234';
$data['password'] = 'Viral@1234';
$data['password_confirmation'] = 'Viral@1234';
$this->actingAs($this->admin)
->patch(route('admin.access.user.change-password', $this->admin), $data)
->assertSessionHas(['flash_success' => trans('alerts.backend.users.updated_password')]);
Event::assertDispatched(UserPasswordChanged::class);
}
}
...@@ -2,14 +2,16 @@ ...@@ -2,14 +2,16 @@
namespace Tests\Feature\Backend; namespace Tests\Feature\Backend;
use App\Events\Backend\Access\User\UserCreated; use Tests\TestCase;
use App\Models\Access\Permission\Permission;
use App\Models\Access\Role\Role; use App\Models\Access\Role\Role;
use App\Models\Access\User\User; use App\Models\Access\User\User;
use App\Notifications\Frontend\Auth\UserNeedsConfirmation;
use Illuminate\Support\Facades\Event; use Illuminate\Support\Facades\Event;
use App\Models\Access\Permission\Permission;
use Illuminate\Support\Facades\Notification; use Illuminate\Support\Facades\Notification;
use Tests\TestCase; use App\Events\Backend\Access\User\UserCreated;
use App\Events\Backend\Access\User\UserDeleted;
use App\Events\Backend\Access\User\UserUpdated;
use App\Notifications\Frontend\Auth\UserNeedsConfirmation;
class ManageUsersTest extends TestCase class ManageUsersTest extends TestCase
{ {
...@@ -150,7 +152,6 @@ class ManageUsersTest extends TestCase ...@@ -150,7 +152,6 @@ class ManageUsersTest extends TestCase
$user = factory(User::class)->states('active', 'confirmed')->make()->toArray(); $user = factory(User::class)->states('active', 'confirmed')->make()->toArray();
$role = create(Role::class); $role = create(Role::class);
$permission = create(Permission::class); $permission = create(Permission::class);
$user['password'] = 'Viral@1234'; $user['password'] = 'Viral@1234';
...@@ -160,7 +161,8 @@ class ManageUsersTest extends TestCase ...@@ -160,7 +161,8 @@ class ManageUsersTest extends TestCase
$this->actingAs($this->admin) $this->actingAs($this->admin)
->post(route('admin.access.user.store'), $user) ->post(route('admin.access.user.store'), $user)
->assertRedirect(route('admin.access.user.index')); ->assertRedirect(route('admin.access.user.index'))
->assertSessionHas(['flash_success' => trans('alerts.backend.users.created')]);
$this->assertDatabaseHas(config('access.users_table'), [ $this->assertDatabaseHas(config('access.users_table'), [
'first_name' => $user['first_name'], 'first_name' => $user['first_name'],
...@@ -187,7 +189,6 @@ class ManageUsersTest extends TestCase ...@@ -187,7 +189,6 @@ class ManageUsersTest extends TestCase
$user = factory(User::class)->states('active')->make()->toArray(); $user = factory(User::class)->states('active')->make()->toArray();
$role = create(Role::class); $role = create(Role::class);
$permission = create(Permission::class); $permission = create(Permission::class);
$user['password'] = 'Viral@1234'; $user['password'] = 'Viral@1234';
...@@ -198,7 +199,8 @@ class ManageUsersTest extends TestCase ...@@ -198,7 +199,8 @@ class ManageUsersTest extends TestCase
$this->actingAs($this->admin) $this->actingAs($this->admin)
->post(route('admin.access.user.store'), $user) ->post(route('admin.access.user.store'), $user)
->assertRedirect(route('admin.access.user.index')); ->assertRedirect(route('admin.access.user.index'))
->assertSessionHas(['flash_success' => trans('alerts.backend.users.created')]);
$this->assertDatabaseHas(config('access.users_table'), [ $this->assertDatabaseHas(config('access.users_table'), [
'first_name' => $user['first_name'], 'first_name' => $user['first_name'],
...@@ -220,10 +222,82 @@ class ManageUsersTest extends TestCase ...@@ -220,10 +222,82 @@ class ManageUsersTest extends TestCase
Event::assertDispatched(UserCreated::class); Event::assertDispatched(UserCreated::class);
} }
//@todo /** @test */
// update user public function it_fails_for_validation_on_update_user()
// delete user {
// user can not delete himself $user = create(User::class);
$user1 = $user->toArray();
$user1['first_name'] = '';
$user1['last_name'] = '';
$user1['email'] = '';
$user1['assignees_roles'] = '';
$user1['permissions'] = '';
$this->withExceptionHandling()
->actingAs($this->admin)
->patch(route('admin.access.user.update', $user), $user1)
->assertSessionHasErrors(['first_name', 'last_name', 'email', 'assignees_roles', 'permissions']);
}
/** @test */
public function a_user_can_update_new_user()
{
Event::fake();
$user = create(User::class);
$role = create(Role::class);
$permission = create(Permission::class);
$data = $user->toArray();
$data['first_name'] = 'updated first_name';
$data['last_name'] = 'updated last_name';
$data['assignees_roles'] = [$role->id];
$data['permissions'] = [$permission->id];
$this->actingAs($this->admin)
->patch(route('admin.access.user.update', $user), $data)
->assertRedirect(route('admin.access.user.index'))
->assertSessionHas(['flash_success' => trans('alerts.backend.users.updated')]);
$this->assertDatabaseHas(config('access.users_table'),[
'id' => $user->id,
'first_name' => $data['first_name'],
'last_name' => $data['last_name'],
]);
Event::assertDispatched(UserUpdated::class);
}
/** @test */
public function a_user_can_delete_a_user()
{
Event::fake();
$user = create(User::class);
$this->actingAs($this->admin)
->delete(route('admin.access.user.destroy', $user))
->assertSessionHas(['flash_success' => trans('alerts.backend.users.deleted')]);
$this->assertDatabaseMissing(config('access.users_table'), ['name' => $user->first_name, 'id' => $user->id]);
Event::assertDispatched(UserDeleted::class);
}
/** @test */
public function a_user_can_not_delete_himself()
{
$this->withExceptionHandling()
->actingAs($this->admin)
->delete(route('admin.access.user.destroy', $this->admin))
->assertSessionHas(['flash_danger' => trans('exceptions.backend.access.users.cant_delete_self')]);
$this->assertDatabaseHas(config('access.users_table'), ['id' => $this->admin->id, 'deleted_at' => null]);
}
// change password // change password
// export / import feature // export / import feature
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment