8000 [FrameworkBundle]: use __invoke function if no method is defined in r… · symfony/symfony@881a02f · GitHub
[go: up one dir, main page]

Skip to content

Commit 881a02f

Browse files
rjwebdevRuben Jacobs
authored and
Ruben Jacobs
committed
[FrameworkBundle]: use __invoke function if no method is defined in routing configuration
1 parent 37e277e commit 881a02f

File tree

2 files changed

+30
-1
lines changed

2 files changed

+30
-1
lines changed

src/Symfony/Bundle/FrameworkBundle/Controller/ControllerResolver.php

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,14 @@ protected function createController($controller)
4343
@trigger_error(sprintf('Referencing controllers with %s is deprecated since Symfony 4.1. Use %s instead.', $deprecatedNotation, $controller), E_USER_DEPRECATED);
4444
}
4545

46-
return parent::createController($controller);
46+
if (\is_object($resolvedController) && method_exists($resolvedController, '__invoke')) {
47+
$resolvedController = [
48+
$this->configureController($resolvedController),
49+
'__invoke',
50+
];
51+
}
52+
53+
return $resolvedController;
4754
}
4855

4956
/**

src/Symfony/Bundle/FrameworkBundle/Tests/Controller/ControllerResolverTest.php

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,24 @@
2424

2525
class ControllerResolverTest extends ContainerControllerResolverTest
2626
{
27+
public function testGetControllerWithServiceWithoutMethod()
28+
{
29+
class_exists(AbstractControllerTest::class);
30+
31+
$dummyController = new DummyController();
32+
$container = new Container();
33+
$container->set('app.index_controller', $dummyController);
34+
35+
$resolver = $this->createControllerResolver(null, $container);
36+
$request = Request::create('/');
37+
$request->attributes->set('_controller', 'app.index_controller');
38+
39+
$controller = $resolver->getController($request);
40+
41+
$this->assertSame($container, $controller[0]->getContainer());
42+
$this->assertSame('__invoke', $controller[1]);
43+
}
44+
2745
public function testGetControllerOnContainerAware()
2846
{
2947
$resolver = $this->createControllerResolver();
@@ -230,6 +248,10 @@ public function getContainer()
230248
return $this->container;
231249
}
232250

251+
public function __invoke()
252+
{
253+
}
254+
233255
public function fooAction()
234256
{
235257
}

0 commit comments

Comments
 (0)
0