wallabag/tests/Wallabag/UserBundle/EventListener/AuthenticationFailureListenerTest.php

70 lines
2.1 KiB
PHP
Raw Normal View History

2017-06-09 07:45:43 +00:00
<?php
namespace Tests\Wallabag\UserBundle\EventListener;
2017-07-01 07:52:38 +00:00
use Monolog\Handler\TestHandler;
use Monolog\Logger;
2017-12-16 21:17:42 +00:00
use PHPUnit\Framework\TestCase;
2017-06-09 07:45:43 +00:00
use Symfony\Component\EventDispatcher\EventDispatcher;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\RequestStack;
2022-09-01 18:54:56 +00:00
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
2017-06-09 07:45:43 +00:00
use Symfony\Component\Security\Core\AuthenticationEvents;
use Symfony\Component\Security\Core\Event\AuthenticationFailureEvent;
2022-09-01 18:54:56 +00:00
use Symfony\Component\Security\Core\Exception\AuthenticationException;
2017-07-01 07:52:38 +00:00
use Wallabag\UserBundle\EventListener\AuthenticationFailureListener;
2017-06-09 07:45:43 +00:00
2017-12-16 21:17:42 +00:00
class AuthenticationFailureListenerTest extends TestCase
2017-06-09 07:45:43 +00:00
{
private $requestStack;
private $logHandler;
private $listener;
private $dispatcher;
Remove support for PHP < 7.2 Updating deps - Removing electrolinux/php-html5lib (0.1.0) - Updating doctrine/inflector (1.3.1 => 1.4.3) - Updating doctrine/lexer (1.0.2 => 1.2.1) - Installing symfony/polyfill-php80 (v1.17.0) - Updating symfony/service-contracts (v1.1.8 => v2.1.2) - Installing symfony/deprecation-contracts (v2.1.2) - Updating symfony/mime (v4.4.8 => v5.1.1) - Updating friendsofsymfony/rest-bundle (2.7.4 => 2.8.0) - Updating doctrine/instantiator (1.3.0 => 1.3.1) - Updating ocramius/proxy-manager (2.1.1 => 2.2.3) - Updating php-http/discovery (1.7.4 => 1.8.0) - Updating symfony/http-client-contracts (v1.1.8 => v2.1.2) - Updating symfony/http-client (v4.4.8 => v5.1.1) - Updating php-http/httplug-bundle (1.16.0 => 1.18.0) - Updating symfony/phpunit-bridge (v4.3.11 => v5.1.1) - Updating doctrine/data-fixtures (1.3.3 => 1.4.3) - Updating composer/xdebug-handler (1.4.1 => 1.4.2) - Updating masterminds/html5 (2.7.0 => 2.7.1) - Updating j0k3r/php-readability (1.2.4 => 1.2.5) - Updating phpoption/phpoption (1.7.3 => 1.7.4) - Updating nikic/php-parser (v4.4.0 => v4.5.0) - Installing thecodingmachine/safe (v1.1.1) - Updating spomky-labs/otphp (v9.1.4 => v10.0.1) - Updating pagerfanta/pagerfanta (v2.1.3 => v2.3.0) Package white-october/pagerfanta-bundle is abandoned, you should avoid using it. Use babdev/pagerfanta-bundle instead. - Removing white-october/pagerfanta-bundle (v1.3.2) - Installing babdev/pagerfanta-bundle (v2.4.2) Upgrading PHPStan to 0.12 and use extension installer - Removing phpstan/phpdoc-parser (0.3.5) - Removing nette/utils (v3.1.2) - Removing nette/schema (v1.0.2) - Removing nette/robot-loader (v3.2.3) - Removing nette/php-generator (v3.4.0) - Removing nette/neon (v3.1.2) - Removing nette/finder (v2.5.2) - Removing nette/di (v3.0.4) - Removing nette/bootstrap (v3.0.2) - Updating phpstan/phpstan (0.11.19 => 0.12.29) - Updating phpstan/phpstan-doctrine (0.11.6 => 0.12.16) - Updating phpstan/phpstan-phpunit (0.11.2 => 0.12.11) - Updating phpstan/phpstan-symfony (0.11.6 => 0.12.6) - Installing phpstan/extension-installer (1.0.4) Upgrading jms/serializer-bundle to version 3 (and willdurand/hateoas-bundle to version 2) - Removing phpoption/phpoption (1.7.4) - Removing phpcollection/phpcollection (0.5.0) - Removing jms/parser-lib (1.0.0) - Updating jms/metadata (1.7.0 => 2.3.0) - Updating jms/serializer (1.14.1 => 3.7.0) - Updating jms/serializer-bundle (2.4.4 => 3.6.0) - Updating willdurand/hateoas (2.12.0 => 3.6.0) - Updating willdurand/hateoas-bundle (1.4.0 => 2.1.0) Upgrading dama/doctrine-test-bundle to version 6 - Updating dama/doctrine-test-bundle (v5.0.3 => v6.2.0)
2020-06-15 06:25:59 +00:00
protected function setUp(): void
2017-06-09 07:45:43 +00:00
{
$request = Request::create('/');
$request->request->set('_username', 'admin');
$this->requestStack = new RequestStack();
$this->requestStack->push($request);
$this->logHandler = new TestHandler();
$logger = new Logger('test', [$this->logHandler]);
$this->listener = new AuthenticationFailureListener(
$this->requestStack,
$logger
);
$this->dispatcher = new EventDispatcher();
$this->dispatcher->addSubscriber($this->listener);
}
public function testOnAuthenticationFailure()
{
2022-09-01 18:54:56 +00:00
$token = $this->getMockBuilder(TokenInterface::class)
2017-06-09 07:45:43 +00:00
->disableOriginalConstructor()
->getMock();
2022-09-01 18:54:56 +00:00
$exception = $this->getMockBuilder(AuthenticationException::class)
2017-06-09 07:45:43 +00:00
->disableOriginalConstructor()
->getMock();
$event = new AuthenticationFailureEvent(
$token,
$exception
);
$this->dispatcher->dispatch(
AuthenticationEvents::AUTHENTICATION_FAILURE,
$event
);
$records = $this->logHandler->getRecords();
$this->assertCount(1, $records);
$this->assertSame('Authentication failure for user "admin", from IP "127.0.0.1", with UA: "Symfony".', $records[0]['message']);
2017-06-09 07:45:43 +00:00
}
}