fixed RedirectController - removed parmanent attribute before generate new url, added tests

This commit is contained in:
Marcin Sikon 2011-02-06 21:51:02 +01:00 committed by Fabien Potencier
parent 7ad4f99153
commit b9ed739d75
2 changed files with 123 additions and 1 deletions

View File

@ -47,7 +47,7 @@ class RedirectController extends ContainerAware
$code = $permanent ? 301 : 302;
$attributes = $this->container->get('request')->attributes->all();
unset($attributes['_route'], $attributes['route']);
unset($attributes['_route'], $attributes['route'], $attributes['permanent'] );
$response = $this->container->get('response');
$response->setRedirect($this->container->get('router')->generate($route, $attributes), $code);

View File

@ -0,0 +1,122 @@
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien.potencier@symfony-project.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Bundle\FrameworkBundle\Tests\Controller;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpFoundation\ParameterBag;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Bundle\FrameworkBundle\Controller\RedirectController;
use Symfony\Bundle\FrameworkBundle\Tests\TestCase;
use Symfony\Bundle\FrameworkBundle\Controller\ControllerNameParser;
use Symfony\Bundle\FrameworkBundle\Tests\Logger;
use Symfony\Bundle\FrameworkBundle\Tests\Kernel;
/**
*
* @author Marcin Sikon<marcin.sikon@gmail.com>
*/
class RedirectControllerTest extends TestCase
{
public function testEmptyRoute()
{
$response = new Response();
$container = $this->getMock('Symfony\Component\DependencyInjection\ContainerInterface');
$container
->expects($this->once())
->method('get')
->with($this->equalTo('response'))
->will($this->returnValue($response))
;
$controller = new RedirectController();
$controller->setContainer($container);
$returnResponse = $controller->redirectAction('');
$this->assertInstanceOf('\Symfony\Component\HttpFoundation\Response', $returnResponse);
$this->assertEquals(410, $returnResponse->getStatusCode());
}
/**
* @dataProvider provider
*/
public function testRoute($permanent, $expectedCode)
{
$response = new Response();
$request = new Request();
$route = 'new-route';
$url = '/redirect-url';
$params = array('additional-parameter' => 'value');
$request->attributes = new ParameterBag(array('route' => $route, '_route' => 'current-route', 'permanent' => $permanent) + $params);
$router = $this->getMock('Symfony\Component\Routing\RouterInterface');
$router
->expects($this->once())
->method('generate')
->with($this->equalTo($route),$this->equalTo($params))
->will($this->returnValue($url));
$container = $this->getMock('Symfony\Component\DependencyInjection\ContainerInterface');
$container
->expects($this->at(0))
->method('get')
->with($this->equalTo('request'))
->will($this->returnValue($request));
$container
->expects($this->at(1))
->method('get')
->with($this->equalTo('response'))
->will($this->returnValue($response));
$container
->expects($this->at(2))
->method('get')
->with($this->equalTo('router'))
->will($this->returnValue($router));
$controller = new RedirectController();
$controller->setContainer($container);
$returnResponse = $controller->redirectAction($route, $permanent);
$this->assertInstanceOf('\Symfony\Component\HttpFoundation\Response', $returnResponse);
$this->assertTrue($returnResponse->isRedirect());
$this->assertTrue($returnResponse->isRedirected($url));
$this->assertEquals($expectedCode, $returnResponse->getStatusCode());
}
public function provider()
{
return array(
array(true, 301),
array(false, 302),
);
}
}