2FAuth/tests/Feature/Http/Auth/ForgotPasswordControllerTest.php

115 lines
3.3 KiB
PHP

<?php
namespace Tests\Feature\Http\Auth;
use App\Http\Controllers\Auth\ForgotPasswordController;
use App\Http\Middleware\RejectIfAuthenticated;
use App\Http\Middleware\RejectIfDemoMode;
use App\Models\User;
use Illuminate\Auth\Notifications\ResetPassword;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Notification;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\Test;
use Tests\FeatureTestCase;
/**
* ForgotPasswordControllerTest test class
*/
#[CoversClass(ForgotPasswordController::class)]
#[CoversClass(User::class)]
#[CoversClass(RejectIfDemoMode::class)]
#[CoversClass(RejectIfAuthenticated::class)]
class ForgotPasswordControllerTest extends FeatureTestCase
{
/**
* @var \App\Models\User
*/
protected $user;
#[Test]
public function test_submit_email_password_request_without_email_returns_validation_error()
{
$response = $this->json('POST', '/user/password/lost', [
'email' => '',
]);
$response->assertStatus(422)
->assertJsonValidationErrors(['email']);
}
#[Test]
public function test_submit_email_password_request_with_invalid_email_returns_validation_error()
{
$response = $this->json('POST', '/user/password/lost', [
'email' => 'nametest.com',
]);
$response->assertStatus(422)
->assertJsonValidationErrors(['email']);
}
#[Test]
public function test_submit_email_password_request_with_unknown_email_returns_validation_error()
{
$response = $this->json('POST', '/user/password/lost', [
'email' => 'name@test.com',
]);
$response->assertStatus(422)
->assertJsonValidationErrors(['email']);
}
#[Test]
public function test_submit_email_password_request_returns_success()
{
Notification::fake();
$this->user = User::factory()->create();
$response = $this->json('POST', '/user/password/lost', [
'email' => $this->user->email,
]);
$response->assertStatus(200);
$token = \Illuminate\Support\Facades\DB::table(config('auth.passwords.users.table'))->first();
$this->assertNotNull($token);
Notification::assertSentTo($this->user, ResetPassword::class, function ($notification, $channels) use ($token) {
return Hash::check($notification->token, $token->token) === true;
});
}
#[Test]
public function test_submit_email_password_request_in_demo_mode_returns_unauthorized()
{
Config::set('2fauth.config.isDemoApp', true);
$response = $this->json('POST', '/user/password/lost', [
'email' => '',
]);
$response->assertStatus(401);
}
#[Test]
public function test_submit_email_password_request_when_authenticated_returns_bad_request()
{
/**
* @var \App\Models\User|\Illuminate\Contracts\Auth\Authenticatable
*/
$user = User::factory()->create();
$this->actingAs($user, 'web-guard')
->json('POST', '/user/password/lost', [
'email' => $user->email,
])
->assertStatus(400)
->assertJsonStructure([
'message',
]);
}
}