[FrameworkBundle] Return the invokable service if its name is the class name
This commit is contained in:
parent
ba1cd26237
commit
5c87d766d5
@ -78,6 +78,10 @@ class ControllerResolver extends BaseControllerResolver
|
|||||||
*/
|
*/
|
||||||
protected function instantiateController($class)
|
protected function instantiateController($class)
|
||||||
{
|
{
|
||||||
|
if ($this->container->has($class)) {
|
||||||
|
return $this->container->get($class);
|
||||||
|
}
|
||||||
|
|
||||||
$controller = parent::instantiateController($class);
|
$controller = parent::instantiateController($class);
|
||||||
|
|
||||||
if ($controller instanceof ContainerAwareInterface) {
|
if ($controller instanceof ContainerAwareInterface) {
|
||||||
|
@ -87,6 +87,8 @@ class ControllerResolverTest extends BaseControllerResolverTest
|
|||||||
|
|
||||||
public function testGetControllerInvokableService()
|
public function testGetControllerInvokableService()
|
||||||
{
|
{
|
||||||
|
$invokableController = new InvokableController('bar');
|
||||||
|
|
||||||
$container = $this->createMockContainer();
|
$container = $this->createMockContainer();
|
||||||
$container->expects($this->once())
|
$container->expects($this->once())
|
||||||
->method('has')
|
->method('has')
|
||||||
@ -96,7 +98,7 @@ class ControllerResolverTest extends BaseControllerResolverTest
|
|||||||
$container->expects($this->once())
|
$container->expects($this->once())
|
||||||
->method('get')
|
->method('get')
|
||||||
->with('foo')
|
->with('foo')
|
||||||
->will($this->returnValue($this))
|
->will($this->returnValue($invokableController))
|
||||||
;
|
;
|
||||||
|
|
||||||
$resolver = $this->createControllerResolver(null, null, $container);
|
$resolver = $this->createControllerResolver(null, null, $container);
|
||||||
@ -105,7 +107,33 @@ class ControllerResolverTest extends BaseControllerResolverTest
|
|||||||
|
|
||||||
$controller = $resolver->getController($request);
|
$controller = $resolver->getController($request);
|
||||||
|
|
||||||
$this->assertInstanceOf(get_class($this), $controller);
|
$this->assertEquals($invokableController, $controller);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetControllerInvokableServiceWithClassNameAsName()
|
||||||
|
{
|
||||||
|
$invokableController = new InvokableController('bar');
|
||||||
|
$className = __NAMESPACE__.'\InvokableController';
|
||||||
|
|
||||||
|
$container = $this->createMockContainer();
|
||||||
|
$container->expects($this->once())
|
||||||
|
->method('has')
|
||||||
|
->with($className)
|
||||||
|
->will($this->returnValue(true))
|
||||||
|
;
|
||||||
|
$container->expects($this->once())
|
||||||
|
->method('get')
|
||||||
|
->with($className)
|
||||||
|
->will($this->returnValue($invokableController))
|
||||||
|
;
|
||||||
|
|
||||||
|
$resolver = $this->createControllerResolver(null, null, $container);
|
||||||
|
$request = Request::create('/');
|
||||||
|
$request->attributes->set('_controller', $className);
|
||||||
|
|
||||||
|
$controller = $resolver->getController($request);
|
||||||
|
|
||||||
|
$this->assertEquals($invokableController, $controller);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -178,3 +206,14 @@ class ContainerAwareController implements ContainerAwareInterface
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class InvokableController
|
||||||
|
{
|
||||||
|
public function __construct($bar) // mandatory argument to prevent automatic instantiation
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __invoke()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user