1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- <?php
-
- use App\Models\User;
- use App\Providers\RouteServiceProvider;
- use Illuminate\Auth\Events\Verified;
- use Illuminate\Support\Facades\Event;
- use Illuminate\Support\Facades\URL;
-
- test('email verification screen can be rendered', function () {
- $user = User::factory()->create([
- 'email_verified_at' => null,
- ]);
-
- $response = $this->actingAs($user)->get('/verify-email');
-
- $response->assertStatus(200);
- });
-
- test('email can be verified', function () {
- $user = User::factory()->create([
- 'email_verified_at' => null,
- ]);
-
- Event::fake();
-
- $verificationUrl = URL::temporarySignedRoute(
- 'verification.verify',
- now()->addMinutes(60),
- ['id' => $user->id, 'hash' => sha1($user->email)]
- );
-
- $response = $this->actingAs($user)->get($verificationUrl);
-
- Event::assertDispatched(Verified::class);
- expect($user->fresh()->hasVerifiedEmail())->toBeTrue();
- $response->assertRedirect(RouteServiceProvider::HOME.'?verified=1');
- });
-
- test('email is not verified with invalid hash', function () {
- $user = User::factory()->create([
- 'email_verified_at' => null,
- ]);
-
- $verificationUrl = URL::temporarySignedRoute(
- 'verification.verify',
- now()->addMinutes(60),
- ['id' => $user->id, 'hash' => sha1('wrong-email')]
- );
-
- $this->actingAs($user)->get($verificationUrl);
-
- expect($user->fresh()->hasVerifiedEmail())->toBeFalse();
- });
|