Skip to content

Commit

Permalink
[Security] Added tests for the DefaultAuthenticationFailureHandler.
Browse files Browse the repository at this point in the history
  • Loading branch information
jakzal committed May 24, 2013
1 parent 3129bee commit 12d9b0a
Showing 1 changed file with 182 additions and 0 deletions.
@@ -0,0 +1,182 @@
<?php

/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

namespace Symfony\Component\Security\Tests\Http;

use Symfony\Component\Security\Http\Authentication\DefaultAuthenticationFailureHandler;
use Symfony\Component\Security\Core\SecurityContextInterface;
use Symfony\Component\HttpKernel\HttpKernelInterface;

class DefaultAuthenticationFailureHandlerTest extends \PHPUnit_Framework_TestCase
{
private $httpKernel = null;

private $httpUtils = null;

private $logger = null;

private $request = null;

private $session = null;

private $exception = null;

protected function setUp()
{
if (!class_exists('Symfony\Component\HttpKernel\HttpKernel')) {
$this->markTestSkipped('The "HttpKernel" component is not available');
}

if (!class_exists('Symfony\Component\HttpFoundation\Request')) {
$this->markTestSkipped('The "HttpFoundation" component is not available');
}

$this->httpKernel = $this->getMock('Symfony\Component\HttpKernel\HttpKernelInterface');
$this->httpUtils = $this->getMock('Symfony\Component\Security\Http\HttpUtils');
$this->logger = $this->getMock('Psr\Log\LoggerInterface');

$this->session = $this->getMock('Symfony\Component\HttpFoundation\Session\Session');
$this->request = $this->getMock('Symfony\Component\HttpFoundation\Request');
$this->request->expects($this->any())->method('getSession')->will($this->returnValue($this->session));
$this->exception = $this->getMock('Symfony\Component\Security\Core\Exception\AuthenticationException');
}

public function testForward()
{
$options = array('failure_forward' => true);

$subRequest = $this->getRequest();
$subRequest->attributes->expects($this->once())
->method('set')->with(SecurityContextInterface::AUTHENTICATION_ERROR, $this->exception);
$this->httpUtils->expects($this->once())
->method('createRequest')->with($this->request, '/login')
->will($this->returnValue($subRequest));

$response = $this->getMock('Symfony\Component\HttpFoundation\Response');
$this->httpKernel->expects($this->once())
->method('handle')->with($subRequest, HttpKernelInterface::SUB_REQUEST)
->will($this->returnValue($response));

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, $options, $this->logger);
$result = $handler->onAuthenticationFailure($this->request, $this->exception);

$this->assertSame($response, $result);
}

public function testRedirect()
{
$response = $this->getMock('Symfony\Component\HttpFoundation\Response');
$this->httpUtils->expects($this->once())
->method('createRedirectResponse')->with($this->request, '/login')
->will($this->returnValue($response));

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, array(), $this->logger);
$result = $handler->onAuthenticationFailure($this->request, $this->exception);

$this->assertSame($response, $result);
}

public function testExceptionIsPersistedInSession()
{
$this->session->expects($this->once())
->method('set')->with(SecurityContextInterface::AUTHENTICATION_ERROR, $this->exception);

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, array(), $this->logger);
$handler->onAuthenticationFailure($this->request, $this->exception);
}

public function testExceptionIsPassedInRequestOnForward()
{
$options = array('failure_forward' => true);

$subRequest = $this->getRequest();
$subRequest->attributes->expects($this->once())
->method('set')->with(SecurityContextInterface::AUTHENTICATION_ERROR, $this->exception);

$this->httpUtils->expects($this->once())
->method('createRequest')->with($this->request, '/login')
->will($this->returnValue($subRequest));

$this->session->expects($this->never())->method('set');

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, $options, $this->logger);
$handler->onAuthenticationFailure($this->request, $this->exception);
}

public function testRedirectIsLogged()
{
$this->logger->expects($this->once())->method('debug')->with('Redirecting to /login');

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, array(), $this->logger);
$handler->onAuthenticationFailure($this->request, $this->exception);
}

public function testForwardIsLogged()
{
$options = array('failure_forward' => true);

$this->httpUtils->expects($this->once())
->method('createRequest')->with($this->request, '/login')
->will($this->returnValue($this->getRequest()));

$this->logger->expects($this->once())->method('debug')->with('Forwarding to /login');

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, $options, $this->logger);
$handler->onAuthenticationFailure($this->request, $this->exception);
}

public function testFailurePathCanBeOverwritten()
{
$options = array('failure_path' => '/auth/login');

$this->httpUtils->expects($this->once())
->method('createRedirectResponse')->with($this->request, '/auth/login');

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, $options, $this->logger);
$handler->onAuthenticationFailure($this->request, $this->exception);
}

public function testFailurePathCanBeOverwrittenWithRequest()
{
$this->request->expects($this->once())
->method('get')->with('_failure_path', null, true)
->will($this->returnValue('/auth/login'));

$this->httpUtils->expects($this->once())
->method('createRedirectResponse')->with($this->request, '/auth/login');

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, array(), $this->logger);
$handler->onAuthenticationFailure($this->request, $this->exception);
}

public function testFailurePathParameterCanBeOverwritten()
{
$options = array('failure_path_parameter' => '_my_failure_path');

$this->request->expects($this->once())
->method('get')->with('_my_failure_path', null, true)
->will($this->returnValue('/auth/login'));

$this->httpUtils->expects($this->once())
->method('createRedirectResponse')->with($this->request, '/auth/login');

$handler = new DefaultAuthenticationFailureHandler($this->httpKernel, $this->httpUtils, $options, $this->logger);
$handler->onAuthenticationFailure($this->request, $this->exception);
}

private function getRequest()
{
$request = $this->getMock('Symfony\Component\HttpFoundation\Request');
$request->attributes = $this->getMock('Symfony\Component\HttpFoundation\ParameterBag');

return $request;
}
}

0 comments on commit 12d9b0a

Please sign in to comment.