Вход Регистрация
Файл: vendor/laravel/ui/tests/AuthBackend/AuthenticatesUsersTest.php
Строк: 191
<?php

namespace LaravelUiTestsAuthBackend;

use 
IlluminateAuthEventsAttempting;
use 
IlluminateFoundationAuthAuthenticatesUsers;
use 
IlluminateHttpRequest;
use 
IlluminateRoutingPipeline;
use 
IlluminateSupportFacadesAuth;
use 
IlluminateSupportFacadesEvent;
use 
IlluminateTestingTestResponse;
use 
IlluminateValidationValidationException;
use 
OrchestraTestbenchFactoriesUserFactory;
use 
OrchestraTestbenchTestCase;

class 
AuthenticatesUsersTest extends TestCase
{
    use 
AuthenticatesUsers;

    protected function 
tearDown(): void
    
{
        
Auth::logout();

        
parent::tearDown();
    }

    
/**
     * Define database migrations.
     *
     * @return void
     */
    
protected function defineDatabaseMigrations()
    {
        
$this->loadLaravelMigrations();
    }

    
/** @test */
    
public function it_can_authenticate_a_user()
    {
        
Event::fake();

        
$user UserFactory::new()->create();

        
$request Request::create('/login''POST', [
            
'email' => $user->email,
            
'password' => 'password',
        ], [], [], [
            
'HTTP_ACCEPT' => 'application/json',
        ]);

        
$response $this->handleRequestUsing($request, function ($request) {
            return 
$this->login($request);
        })->
assertStatus(204);

        
Event::assertDispatched(function (Attempting $event) {
            return 
$event->remember === false;
        });
    }

    
/** @test */
    
public function it_can_authenticate_a_user_with_remember_as_false()
    {
        
Event::fake();

        
$user UserFactory::new()->create();

        
$request Request::create('/login''POST', [
            
'email' => $user->email,
            
'password' => 'password',
            
'remember' => false,
        ], [], [], [
            
'HTTP_ACCEPT' => 'application/json',
        ]);

        
$response $this->handleRequestUsing($request, function ($request) {
            return 
$this->login($request);
        })->
assertStatus(204);

        
Event::assertDispatched(function (Attempting $event) {
            return 
$event->remember === false;
        });
    }



    
/** @test */
    
public function it_can_authenticate_a_user_with_remember_as_true()
    {
        
Event::fake();

        
$user UserFactory::new()->create();

        
$request Request::create('/login''POST', [
            
'email' => $user->email,
            
'password' => 'password',
            
'remember' => true,
        ], [], [], [
            
'HTTP_ACCEPT' => 'application/json',
        ]);

        
$response $this->handleRequestUsing($request, function ($request) {
            return 
$this->login($request);
        })->
assertStatus(204);

        
Event::assertDispatched(function (Attempting $event) {
            return 
$event->remember === true;
        });
    }

    
/** @test */
    
public function it_cant_authenticate_a_user_with_invalid_password()
    {
        
$user UserFactory::new()->create();

        
$request Request::create('/login''POST', [
            
'email' => $user->email,
            
'password' => 'invalid-password',
        ], [], [], [
            
'HTTP_ACCEPT' => 'application/json',
        ]);

        
$response $this->handleRequestUsing($request, function ($request) {
            return 
$this->login($request);
        })->
assertUnprocessable();

        
$this->assertInstanceOf(ValidationException::class, $response->exception);
        
$this->assertSame([
            
'email' => [
                
'These credentials do not match our records.',
            ],
        ], 
$response->exception->errors());
    }

     
/** @test */
    
public function it_cant_authenticate_unknown_credential()
    {
        
$request Request::create('/login''POST', [
            
'email' => 'taylor@laravel.com',
            
'password' => 'password',
        ], [], [], [
            
'HTTP_ACCEPT' => 'application/json',
        ]);

        
$response $this->handleRequestUsing($request, function ($request) {
            return 
$this->login($request);
        })->
assertUnprocessable();

        
$this->assertInstanceOf(ValidationException::class, $response->exception);
        
$this->assertSame([
            
'email' => [
                
'These credentials do not match our records.',
            ],
        ], 
$response->exception->errors());
    }

    
/**
     * Handle Request using the following pipeline.
     *
     * @param  IlluminateHttpRequest  $request
     * @param  callable  $callback
     * @return IlluminateTestingTestResponse
     */
    
protected function handleRequestUsing(Request $request, callable $callback)
    {
        return new 
TestResponse(
            (new 
Pipeline($this->app))
                ->
send($request)
                ->
through([
                    
IlluminateSessionMiddlewareStartSession::class,
                ])
                ->
then($callback)
        );
    }
}
Онлайн: 0
Реклама