ContainerBuilderTest.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. * (c) Fabien Potencier <fabien.potencier@symfony-project.com>
  5. *
  6. * For the full copyright and license information, please view the LICENSE
  7. * file that was distributed with this source code.
  8. */
  9. namespace Symfony\Tests\Component\DependencyInjection;
  10. use Symfony\Component\DependencyInjection\Alias;
  11. use Symfony\Component\DependencyInjection\ContainerBuilder;
  12. use Symfony\Component\DependencyInjection\ContainerInterface;
  13. use Symfony\Component\DependencyInjection\Definition;
  14. use Symfony\Component\DependencyInjection\Reference;
  15. use Symfony\Component\DependencyInjection\ParameterBag\ParameterBag;
  16. use Symfony\Component\DependencyInjection\Resource\FileResource;
  17. require_once __DIR__.'/Fixtures/includes/classes.php';
  18. require_once __DIR__.'/Fixtures/includes/ProjectExtension.php';
  19. class ContainerBuilderTest extends \PHPUnit_Framework_TestCase
  20. {
  21. /**
  22. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::setDefinitions
  23. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::getDefinitions
  24. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::setDefinition
  25. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::getDefinition
  26. */
  27. public function testDefinitions()
  28. {
  29. $builder = new ContainerBuilder();
  30. $definitions = array(
  31. 'foo' => new Definition('FooClass'),
  32. 'bar' => new Definition('BarClass'),
  33. );
  34. $builder->setDefinitions($definitions);
  35. $this->assertEquals($definitions, $builder->getDefinitions(), '->setDefinitions() sets the service definitions');
  36. $this->assertTrue($builder->hasDefinition('foo'), '->hasDefinition() returns true if a service definition exists');
  37. $this->assertFalse($builder->hasDefinition('foobar'), '->hasDefinition() returns false if a service definition does not exist');
  38. $builder->setDefinition('foobar', $foo = new Definition('FooBarClass'));
  39. $this->assertEquals($foo, $builder->getDefinition('foobar'), '->getDefinition() returns a service definition if defined');
  40. $this->assertTrue($builder->setDefinition('foobar', $foo = new Definition('FooBarClass')) === $foo, '->setDefinition() implements a fuild interface by returning the service reference');
  41. $builder->addDefinitions($defs = array('foobar' => new Definition('FooBarClass')));
  42. $this->assertEquals(array_merge($definitions, $defs), $builder->getDefinitions(), '->addDefinitions() adds the service definitions');
  43. try {
  44. $builder->getDefinition('baz');
  45. $this->fail('->getDefinition() throws an InvalidArgumentException if the service definition does not exist');
  46. } catch (\InvalidArgumentException $e) {
  47. $this->assertEquals('The service definition "baz" does not exist.', $e->getMessage(), '->getDefinition() throws an InvalidArgumentException if the service definition does not exist');
  48. }
  49. }
  50. /**
  51. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::register
  52. */
  53. public function testRegister()
  54. {
  55. $builder = new ContainerBuilder();
  56. $builder->register('foo', 'FooClass');
  57. $this->assertTrue($builder->hasDefinition('foo'), '->register() registers a new service definition');
  58. $this->assertInstanceOf('Symfony\Component\DependencyInjection\Definition', $builder->getDefinition('foo'), '->register() returns the newly created Definition instance');
  59. }
  60. /**
  61. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::has
  62. */
  63. public function testHas()
  64. {
  65. $builder = new ContainerBuilder();
  66. $this->assertFalse($builder->has('foo'), '->has() returns false if the service does not exist');
  67. $builder->register('foo', 'FooClass');
  68. $this->assertTrue($builder->has('foo'), '->has() returns true if a service definition exists');
  69. $builder->set('bar', new \stdClass());
  70. $this->assertTrue($builder->has('bar'), '->has() returns true if a service exists');
  71. }
  72. /**
  73. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::get
  74. */
  75. public function testGet()
  76. {
  77. $builder = new ContainerBuilder();
  78. try {
  79. $builder->get('foo');
  80. $this->fail('->get() throws an InvalidArgumentException if the service does not exist');
  81. } catch (\InvalidArgumentException $e) {
  82. $this->assertEquals('The service definition "foo" does not exist.', $e->getMessage(), '->get() throws an InvalidArgumentException if the service does not exist');
  83. }
  84. $this->assertNull($builder->get('foo', ContainerInterface::NULL_ON_INVALID_REFERENCE), '->get() returns null if the service does not exist and NULL_ON_INVALID_REFERENCE is passed as a second argument');
  85. $builder->register('foo', 'stdClass');
  86. $this->assertInternalType('object', $builder->get('foo'), '->get() returns the service definition associated with the id');
  87. $builder->set('bar', $bar = new \stdClass());
  88. $this->assertEquals($bar, $builder->get('bar'), '->get() returns the service associated with the id');
  89. $builder->register('bar', 'stdClass');
  90. $this->assertEquals($bar, $builder->get('bar'), '->get() returns the service associated with the id even if a definition has been defined');
  91. $builder->register('baz', 'stdClass')->setArguments(array(new Reference('baz')));
  92. try {
  93. @$builder->get('baz');
  94. $this->fail('->get() throws a LogicException if the service has a circular reference to itself');
  95. } catch (\LogicException $e) {
  96. $this->assertEquals('The service "baz" has a circular reference to itself.', $e->getMessage(), '->get() throws a LogicException if the service has a circular reference to itself');
  97. }
  98. $builder->register('foobar', 'stdClass')->setShared(true);
  99. $this->assertTrue($builder->get('bar') === $builder->get('bar'), '->get() always returns the same instance if the service is shared');
  100. }
  101. /**
  102. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::getServiceIds
  103. */
  104. public function testGetServiceIds()
  105. {
  106. $builder = new ContainerBuilder();
  107. $builder->register('foo', 'stdClass');
  108. $builder->bar = $bar = new \stdClass();
  109. $builder->register('bar', 'stdClass');
  110. $this->assertEquals(array('foo', 'bar', 'service_container'), $builder->getServiceIds(), '->getServiceIds() returns all defined service ids');
  111. }
  112. /**
  113. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::setAlias
  114. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::hasAlias
  115. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::getAlias
  116. */
  117. public function testAliases()
  118. {
  119. $builder = new ContainerBuilder();
  120. $builder->register('foo', 'stdClass');
  121. $builder->setAlias('bar', 'foo');
  122. $this->assertTrue($builder->hasAlias('bar'), '->hasAlias() returns true if the alias exists');
  123. $this->assertFalse($builder->hasAlias('foobar'), '->hasAlias() returns false if the alias does not exist');
  124. $this->assertEquals('foo', (string) $builder->getAlias('bar'), '->getAlias() returns the aliased service');
  125. $this->assertTrue($builder->has('bar'), '->setAlias() defines a new service');
  126. $this->assertTrue($builder->get('bar') === $builder->get('foo'), '->setAlias() creates a service that is an alias to another one');
  127. try {
  128. $builder->getAlias('foobar');
  129. $this->fail('->getAlias() throws an InvalidArgumentException if the alias does not exist');
  130. } catch (\InvalidArgumentException $e) {
  131. $this->assertEquals('The service alias "foobar" does not exist.', $e->getMessage(), '->getAlias() throws an InvalidArgumentException if the alias does not exist');
  132. }
  133. }
  134. /**
  135. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::getAliases
  136. */
  137. public function testGetAliases()
  138. {
  139. $builder = new ContainerBuilder();
  140. $builder->setAlias('bar', 'foo');
  141. $builder->setAlias('foobar', 'foo');
  142. $builder->setAlias('moo', new Alias('foo', false));
  143. $aliases = $builder->getAliases();
  144. $this->assertEquals('foo', (string) $aliases['bar']);
  145. $this->assertTrue($aliases['bar']->isPublic());
  146. $this->assertEquals('foo', (string) $aliases['foobar']);
  147. $this->assertEquals('foo', (string) $aliases['moo']);
  148. $this->assertFalse($aliases['moo']->isPublic());
  149. $builder->register('bar', 'stdClass');
  150. $this->assertFalse($builder->hasAlias('bar'));
  151. $builder->set('foobar', 'stdClass');
  152. $builder->set('moo', 'stdClass');
  153. $this->assertEquals(0, count($builder->getAliases()), '->getAliases() does not return aliased services that have been overridden');
  154. }
  155. /**
  156. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::setAliases
  157. */
  158. public function testSetAliases()
  159. {
  160. $builder = new ContainerBuilder();
  161. $builder->setAliases(array('bar' => 'foo', 'foobar' => 'foo'));
  162. $aliases = $builder->getAliases();
  163. $this->assertTrue(isset($aliases['bar']));
  164. $this->assertTrue(isset($aliases['foobar']));
  165. }
  166. /**
  167. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::addAliases
  168. */
  169. public function testAddAliases()
  170. {
  171. $builder = new ContainerBuilder();
  172. $builder->setAliases(array('bar' => 'foo'));
  173. $builder->addAliases(array('foobar' => 'foo'));
  174. $aliases = $builder->getAliases();
  175. $this->assertTrue(isset($aliases['bar']));
  176. $this->assertTrue(isset($aliases['foobar']));
  177. }
  178. /**
  179. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::createService
  180. */
  181. public function testCreateService()
  182. {
  183. $builder = new ContainerBuilder();
  184. $builder->register('foo1', 'FooClass')->setFile(__DIR__.'/Fixtures/includes/foo.php');
  185. $this->assertInstanceOf('\FooClass', $builder->get('foo1'), '->createService() requires the file defined by the service definition');
  186. $builder->register('foo2', 'FooClass')->setFile(__DIR__.'/Fixtures/includes/%file%.php');
  187. $builder->setParameter('file', 'foo');
  188. $this->assertInstanceOf('\FooClass', $builder->get('foo2'), '->createService() replaces parameters in the file provided by the service definition');
  189. }
  190. /**
  191. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::createService
  192. */
  193. public function testCreateServiceClass()
  194. {
  195. $builder = new ContainerBuilder();
  196. $builder->register('foo1', '%class%');
  197. $builder->setParameter('class', 'stdClass');
  198. $this->assertInstanceOf('\stdClass', $builder->get('foo1'), '->createService() replaces parameters in the class provided by the service definition');
  199. }
  200. /**
  201. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::createService
  202. */
  203. public function testCreateServiceArguments()
  204. {
  205. $builder = new ContainerBuilder();
  206. $builder->register('bar', 'stdClass');
  207. $builder->register('foo1', 'FooClass')->addArgument(array('foo' => '%value%', '%value%' => 'foo', new Reference('bar')));
  208. $builder->setParameter('value', 'bar');
  209. $this->assertEquals(array('foo' => 'bar', 'bar' => 'foo', $builder->get('bar')), $builder->get('foo1')->arguments, '->createService() replaces parameters and service references in the arguments provided by the service definition');
  210. }
  211. /**
  212. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::createService
  213. */
  214. public function testCreateServiceFactoryMethod()
  215. {
  216. $builder = new ContainerBuilder();
  217. $builder->register('bar', 'stdClass');
  218. $builder->register('foo1', 'FooClass')->setFactoryMethod('getInstance')->addArgument(array('foo' => '%value%', '%value%' => 'foo', new Reference('bar')));
  219. $builder->setParameter('value', 'bar');
  220. $this->assertTrue($builder->get('foo1')->called, '->createService() calls the factory method to create the service instance');
  221. $this->assertEquals(array('foo' => 'bar', 'bar' => 'foo', $builder->get('bar')), $builder->get('foo1')->arguments, '->createService() passes the arguments to the factory method');
  222. }
  223. /**
  224. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::createService
  225. */
  226. public function testCreateServiceFactoryService()
  227. {
  228. $builder = new ContainerBuilder();
  229. $builder->register('baz_service')->setFactoryService('baz_factory')->setFactoryMethod('getInstance');
  230. $builder->register('baz_factory', 'BazClass');
  231. $this->assertInstanceOf('BazClass', $builder->get('baz_service'));
  232. }
  233. /**
  234. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::createService
  235. */
  236. public function testCreateServiceMethodCalls()
  237. {
  238. $builder = new ContainerBuilder();
  239. $builder->register('bar', 'stdClass');
  240. $builder->register('foo1', 'FooClass')->addMethodCall('setBar', array(array('%value%', new Reference('bar'))));
  241. $builder->setParameter('value', 'bar');
  242. $this->assertEquals(array('bar', $builder->get('bar')), $builder->get('foo1')->bar, '->createService() replaces the values in the method calls arguments');
  243. }
  244. /**
  245. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::createService
  246. */
  247. public function testCreateServiceConfigurator()
  248. {
  249. $builder = new ContainerBuilder();
  250. $builder->register('foo1', 'FooClass')->setConfigurator('sc_configure');
  251. $this->assertTrue($builder->get('foo1')->configured, '->createService() calls the configurator');
  252. $builder->register('foo2', 'FooClass')->setConfigurator(array('%class%', 'configureStatic'));
  253. $builder->setParameter('class', 'BazClass');
  254. $this->assertTrue($builder->get('foo2')->configured, '->createService() calls the configurator');
  255. $builder->register('baz', 'BazClass');
  256. $builder->register('foo3', 'FooClass')->setConfigurator(array(new Reference('baz'), 'configure'));
  257. $this->assertTrue($builder->get('foo3')->configured, '->createService() calls the configurator');
  258. $builder->register('foo4', 'FooClass')->setConfigurator('foo');
  259. try {
  260. $builder->get('foo4');
  261. $this->fail('->createService() throws an InvalidArgumentException if the configure callable is not a valid callable');
  262. } catch (\InvalidArgumentException $e) {
  263. $this->assertEquals('The configure callable for class "FooClass" is not a callable.', $e->getMessage(), '->createService() throws an InvalidArgumentException if the configure callable is not a valid callable');
  264. }
  265. }
  266. /**
  267. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::resolveServices
  268. */
  269. public function testResolveServices()
  270. {
  271. $builder = new ContainerBuilder();
  272. $builder->register('foo', 'FooClass');
  273. $this->assertEquals($builder->get('foo'), $builder->resolveServices(new Reference('foo')), '->resolveServices() resolves service references to service instances');
  274. $this->assertEquals(array('foo' => array('foo', $builder->get('foo'))), $builder->resolveServices(array('foo' => array('foo', new Reference('foo')))), '->resolveServices() resolves service references to service instances in nested arrays');
  275. }
  276. /**
  277. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::merge
  278. */
  279. public function testMerge()
  280. {
  281. $container = new ContainerBuilder(new ParameterBag(array('bar' => 'foo')));
  282. $config = new ContainerBuilder(new ParameterBag(array('foo' => 'bar')));
  283. $container->merge($config);
  284. $this->assertEquals(array('bar' => 'foo', 'foo' => 'bar'), $container->getParameterBag()->all(), '->merge() merges current parameters with the loaded ones');
  285. $container = new ContainerBuilder(new ParameterBag(array('bar' => 'foo')));
  286. $config = new ContainerBuilder(new ParameterBag(array('foo' => '%bar%')));
  287. $container->merge($config);
  288. ////// FIXME
  289. $container->compile();
  290. $this->assertEquals(array('bar' => 'foo', 'foo' => 'foo'), $container->getParameterBag()->all(), '->merge() evaluates the values of the parameters towards already defined ones');
  291. $container = new ContainerBuilder(new ParameterBag(array('bar' => 'foo')));
  292. $config = new ContainerBuilder(new ParameterBag(array('foo' => '%bar%', 'baz' => '%foo%')));
  293. $container->merge($config);
  294. ////// FIXME
  295. $container->compile();
  296. $this->assertEquals(array('bar' => 'foo', 'foo' => 'foo', 'baz' => 'foo'), $container->getParameterBag()->all(), '->merge() evaluates the values of the parameters towards already defined ones');
  297. $container = new ContainerBuilder();
  298. $container->register('foo', 'FooClass');
  299. $container->register('bar', 'BarClass');
  300. $config = new ContainerBuilder();
  301. $config->setDefinition('baz', new Definition('BazClass'));
  302. $config->setAlias('alias_for_foo', 'foo');
  303. $container->merge($config);
  304. $this->assertEquals(array('foo', 'bar', 'baz'), array_keys($container->getDefinitions()), '->merge() merges definitions already defined ones');
  305. $aliases = $container->getAliases();
  306. $this->assertTrue(isset($aliases['alias_for_foo']));
  307. $this->assertEquals('foo', (string) $aliases['alias_for_foo']);
  308. $container = new ContainerBuilder();
  309. $container->register('foo', 'FooClass');
  310. $config->setDefinition('foo', new Definition('BazClass'));
  311. $container->merge($config);
  312. $this->assertEquals('BazClass', $container->getDefinition('foo')->getClass(), '->merge() overrides already defined services');
  313. }
  314. /**
  315. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::merge
  316. * @expectedException LogicException
  317. */
  318. public function testMergeLogicException()
  319. {
  320. $container = new ContainerBuilder();
  321. $container->compile();
  322. $container->merge(new ContainerBuilder());
  323. }
  324. /**
  325. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::findTaggedServiceIds
  326. */
  327. public function testfindTaggedServiceIds()
  328. {
  329. $builder = new ContainerBuilder();
  330. $builder
  331. ->register('foo', 'FooClass')
  332. ->addTag('foo', array('foo' => 'foo'))
  333. ->addTag('bar', array('bar' => 'bar'))
  334. ->addTag('foo', array('foofoo' => 'foofoo'))
  335. ;
  336. $this->assertEquals($builder->findTaggedServiceIds('foo'), array(
  337. 'foo' => array(
  338. array('foo' => 'foo'),
  339. array('foofoo' => 'foofoo'),
  340. )
  341. ), '->findTaggedServiceIds() returns an array of service ids and its tag attributes');
  342. $this->assertEquals(array(), $builder->findTaggedServiceIds('foobar'), '->findTaggedServiceIds() returns an empty array if there is annotated services');
  343. }
  344. /**
  345. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::findDefinition
  346. */
  347. public function testFindDefinition()
  348. {
  349. $container = new ContainerBuilder();
  350. $container->setDefinition('foo', $definition = new Definition('FooClass'));
  351. $container->setAlias('bar', 'foo');
  352. $container->setAlias('foobar', 'bar');
  353. $this->assertEquals($definition, $container->findDefinition('foobar'), '->findDefinition() returns a Definition');
  354. }
  355. /**
  356. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::getResources
  357. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::addResource
  358. */
  359. public function testResources()
  360. {
  361. $container = new ContainerBuilder();
  362. $container->addResource($a = new FileResource(__DIR__.'/Fixtures/xml/services1.xml'));
  363. $container->addResource($b = new FileResource(__DIR__.'/Fixtures/xml/services2.xml'));
  364. $this->assertEquals(array($a, $b), $container->getResources(), '->getResources() returns an array of resources read for the current configuration');
  365. }
  366. /**
  367. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::registerExtension
  368. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::getExtension
  369. */
  370. public function testExtension()
  371. {
  372. $container = new ContainerBuilder();
  373. $container->registerExtension($extension = new \ProjectExtension());
  374. $this->assertTrue($container->getExtension('project') === $extension, '->registerExtension() registers an extension');
  375. $this->setExpectedException('LogicException');
  376. $container->getExtension('no_registered');
  377. }
  378. /**
  379. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::addInterfaceInjector
  380. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::addInterfaceInjectors
  381. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::getInterfaceInjectors
  382. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::hasInterfaceInjectorForClass
  383. * @covers Symfony\Component\DependencyInjection\ContainerBuilder::setDefinition
  384. */
  385. public function testInterfaceInjection()
  386. {
  387. $definition = new Definition('Symfony\Tests\Component\DependencyInjection\FooClass');
  388. $injectors[] = $this->getMockInterfaceInjector('Symfony\Tests\Component\DependencyInjection\FooClass', 1);
  389. $injectors[] = $this->getMockInterfaceInjector('Symfony\Tests\Component\DependencyInjection\FooClass', 0);
  390. $container = new ContainerBuilder();
  391. $container->addInterfaceInjectors($injectors);
  392. $this->assertEquals(1, count($container->getInterfaceInjectors('Symfony\Tests\Component\DependencyInjection\FooClass')));
  393. $this->assertTrue($container->hasInterfaceInjectorForClass('Symfony\Tests\Component\DependencyInjection\FooClass'));
  394. $this->assertFalse($container->hasInterfaceInjectorForClass('\Foo'));
  395. $container->setDefinition('test', $definition);
  396. $test = $container->get('test');
  397. }
  398. /**
  399. * @expectedException BadMethodCallException
  400. */
  401. public function testThrowsExceptionWhenSetServiceOnAFrozenContainer()
  402. {
  403. $container = new ContainerBuilder();
  404. $container->compile();
  405. $container->set('a', new \stdClass());
  406. }
  407. /**
  408. * @expectedException BadMethodCallException
  409. */
  410. public function testThrowsExceptionWhenSetDefinitionOnAFrozenContainer()
  411. {
  412. $container = new ContainerBuilder();
  413. $container->compile();
  414. $container->setDefinition('a', new Definition());
  415. }
  416. /**
  417. * @param string $class
  418. * @param int $methodCallsCount
  419. * @return Symfony\Component\DependencyInjection\InterfaceInjector
  420. */
  421. private function getMockInterfaceInjector($class, $methodCallsCount)
  422. {
  423. $injector = $this->getMock('Symfony\Component\DependencyInjection\InterfaceInjector', array('processDefinition'), array('Symfony\Tests\Component\DependencyInjection\FooClass'), '', true, false);
  424. $injector->expects($this->exactly($methodCallsCount))
  425. ->method('processDefinition')
  426. ;
  427. return $injector;
  428. }
  429. }
  430. class FooClass {}