todo/tests/Feature/Auth/PasswordUpdateTest.php

59 lines
1.5 KiB
PHP
Raw Permalink Normal View History

2024-05-02 10:06:39 +03:00
<?php
namespace Tests\Feature\Auth;
2024-05-29 13:40:28 +03:00
use App\Models\Department;
2024-05-02 10:06:39 +03:00
use App\Models\User;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Support\Facades\Hash;
use Tests\TestCase;
class PasswordUpdateTest extends TestCase
{
use RefreshDatabase;
2024-05-29 13:40:28 +03:00
public function setUp(): void
{
parent::setUp();
Department::factory()->create();
}
2024-05-02 17:02:46 +03:00
public function testPasswordCanBeUpdated(): void
2024-05-02 10:06:39 +03:00
{
$user = User::factory()->create();
$response = $this
->actingAs($user)
->from('/profile')
->put('/password', [
'current_password' => 'password',
'password' => 'new-password',
'password_confirmation' => 'new-password',
]);
$response
->assertSessionHasNoErrors()
->assertRedirect('/profile');
$this->assertTrue(Hash::check('new-password', $user->refresh()->password));
}
2024-05-02 17:02:46 +03:00
public function testCorrectPasswordMustBeProvidedToUpdatePassword(): void
2024-05-02 10:06:39 +03:00
{
$user = User::factory()->create();
$response = $this
->actingAs($user)
->from('/profile')
->put('/password', [
'current_password' => 'wrong-password',
'password' => 'new-password',
'password_confirmation' => 'new-password',
]);
$response
->assertSessionHasErrorsIn('updatePassword', 'current_password')
->assertRedirect('/profile');
}
}