2013-05-24 19:31:02 +01:00
|
|
|
<?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.
|
|
|
|
*/
|
|
|
|
|
2013-12-31 13:43:26 +00:00
|
|
|
namespace Symfony\Component\Security\Http\Tests\Authentication;
|
2013-05-24 19:31:02 +01:00
|
|
|
|
2016-08-25 13:47:32 +01:00
|
|
|
use Symfony\Component\HttpFoundation\Response;
|
2013-05-24 19:31:02 +01:00
|
|
|
use Symfony\Component\Security\Http\Authentication\DefaultAuthenticationSuccessHandler;
|
|
|
|
|
|
|
|
class DefaultAuthenticationSuccessHandlerTest extends \PHPUnit_Framework_TestCase
|
|
|
|
{
|
|
|
|
private $httpUtils = null;
|
|
|
|
|
|
|
|
private $request = null;
|
|
|
|
|
|
|
|
private $token = null;
|
|
|
|
|
|
|
|
protected function setUp()
|
|
|
|
{
|
2016-12-19 09:02:29 +00:00
|
|
|
$this->httpUtils = $this->getMockBuilder('Symfony\Component\Security\Http\HttpUtils')->getMock();
|
|
|
|
$this->request = $this->getMockBuilder('Symfony\Component\HttpFoundation\Request')->getMock();
|
|
|
|
$this->request->headers = $this->getMockBuilder('Symfony\Component\HttpFoundation\HeaderBag')->getMock();
|
|
|
|
$this->token = $this->getMockBuilder('Symfony\Component\Security\Core\Authentication\Token\TokenInterface')->getMock();
|
2013-05-24 19:31:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testRequestIsRedirected()
|
|
|
|
{
|
|
|
|
$response = $this->expectRedirectResponse('/');
|
|
|
|
|
|
|
|
$handler = new DefaultAuthenticationSuccessHandler($this->httpUtils, array());
|
|
|
|
$result = $handler->onAuthenticationSuccess($this->request, $this->token);
|
|
|
|
|
|
|
|
$this->assertSame($response, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDefaultTargetPathCanBeForced()
|
|
|
|
{
|
|
|
|
$options = array(
|
|
|
|
'always_use_default_target_path' => true,
|
2014-09-21 19:53:12 +01:00
|
|
|
'default_target_path' => '/dashboard',
|
2013-05-24 19:31:02 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
$response = $this->expectRedirectResponse('/dashboard');
|
|
|
|
|
|
|
|
$handler = new DefaultAuthenticationSuccessHandler($this->httpUtils, $options);
|
|
|
|
$result = $handler->onAuthenticationSuccess($this->request, $this->token);
|
|
|
|
|
|
|
|
$this->assertSame($response, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testTargetPathIsPassedWithRequest()
|
|
|
|
{
|
|
|
|
$this->request->expects($this->once())
|
|
|
|
->method('get')->with('_target_path')
|
|
|
|
->will($this->returnValue('/dashboard'));
|
|
|
|
|
|
|
|
$response = $this->expectRedirectResponse('/dashboard');
|
|
|
|
|
|
|
|
$handler = new DefaultAuthenticationSuccessHandler($this->httpUtils, array());
|
|
|
|
$result = $handler->onAuthenticationSuccess($this->request, $this->token);
|
|
|
|
|
|
|
|
$this->assertSame($response, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testTargetPathParameterIsCustomised()
|
|
|
|
{
|
|
|
|
$options = array('target_path_parameter' => '_my_target_path');
|
|
|
|
|
|
|
|
$this->request->expects($this->once())
|
|
|
|
->method('get')->with('_my_target_path')
|
|
|
|
->will($this->returnValue('/dashboard'));
|
|
|
|
|
|
|
|
$response = $this->expectRedirectResponse('/dashboard');
|
|
|
|
|
|
|
|
$handler = new DefaultAuthenticationSuccessHandler($this->httpUtils, $options);
|
|
|
|
$result = $handler->onAuthenticationSuccess($this->request, $this->token);
|
|
|
|
|
|
|
|
$this->assertSame($response, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testTargetPathIsTakenFromTheSession()
|
|
|
|
{
|
2016-12-19 09:02:29 +00:00
|
|
|
$session = $this->getMockBuilder('Symfony\Component\HttpFoundation\Session\SessionInterface')->getMock();
|
2013-05-24 19:31:02 +01:00
|
|
|
$session->expects($this->once())
|
|
|
|
->method('get')->with('_security.admin.target_path')
|
|
|
|
->will($this->returnValue('/admin/dashboard'));
|
|
|
|
$session->expects($this->once())
|
|
|
|
->method('remove')->with('_security.admin.target_path');
|
|
|
|
|
|
|
|
$this->request->expects($this->any())
|
|
|
|
->method('getSession')
|
|
|
|
->will($this->returnValue($session));
|
|
|
|
|
|
|
|
$response = $this->expectRedirectResponse('/admin/dashboard');
|
|
|
|
|
|
|
|
$handler = new DefaultAuthenticationSuccessHandler($this->httpUtils, array());
|
|
|
|
$handler->setProviderKey('admin');
|
|
|
|
|
|
|
|
$result = $handler->onAuthenticationSuccess($this->request, $this->token);
|
|
|
|
|
|
|
|
$this->assertSame($response, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testTargetPathIsPassedAsReferer()
|
|
|
|
{
|
|
|
|
$options = array('use_referer' => true);
|
|
|
|
|
|
|
|
$this->request->headers->expects($this->once())
|
|
|
|
->method('get')->with('Referer')
|
|
|
|
->will($this->returnValue('/dashboard'));
|
|
|
|
|
|
|
|
$response = $this->expectRedirectResponse('/dashboard');
|
|
|
|
|
|
|
|
$handler = new DefaultAuthenticationSuccessHandler($this->httpUtils, $options);
|
|
|
|
$result = $handler->onAuthenticationSuccess($this->request, $this->token);
|
|
|
|
|
|
|
|
$this->assertSame($response, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRefererHasToBeDifferentThatLoginUrl()
|
|
|
|
{
|
|
|
|
$options = array('use_referer' => true);
|
|
|
|
|
|
|
|
$this->request->headers->expects($this->any())
|
|
|
|
->method('get')->with('Referer')
|
|
|
|
->will($this->returnValue('/login'));
|
|
|
|
|
|
|
|
$this->httpUtils->expects($this->once())
|
|
|
|
->method('generateUri')->with($this->request, '/login')
|
|
|
|
->will($this->returnValue('/login'));
|
|
|
|
|
|
|
|
$response = $this->expectRedirectResponse('/');
|
|
|
|
|
|
|
|
$handler = new DefaultAuthenticationSuccessHandler($this->httpUtils, $options);
|
|
|
|
$result = $handler->onAuthenticationSuccess($this->request, $this->token);
|
|
|
|
|
|
|
|
$this->assertSame($response, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRefererTargetPathIsIgnoredByDefault()
|
|
|
|
{
|
|
|
|
$this->request->headers->expects($this->never())->method('get');
|
|
|
|
|
|
|
|
$response = $this->expectRedirectResponse('/');
|
|
|
|
|
|
|
|
$handler = new DefaultAuthenticationSuccessHandler($this->httpUtils, array());
|
|
|
|
$result = $handler->onAuthenticationSuccess($this->request, $this->token);
|
|
|
|
|
|
|
|
$this->assertSame($response, $result);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function expectRedirectResponse($path)
|
|
|
|
{
|
2016-08-25 13:47:32 +01:00
|
|
|
$response = new Response();
|
2013-05-24 19:31:02 +01:00
|
|
|
$this->httpUtils->expects($this->once())
|
|
|
|
->method('createRedirectResponse')
|
|
|
|
->with($this->request, $path)
|
|
|
|
->will($this->returnValue($response));
|
|
|
|
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
}
|