BuilderConfigurationTest.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  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. require_once __DIR__.'/../../../bootstrap.php';
  10. use Symfony\Components\DependencyInjection\Builder;
  11. use Symfony\Components\DependencyInjection\BuilderConfiguration;
  12. use Symfony\Components\DependencyInjection\Definition;
  13. use Symfony\Components\DependencyInjection\Reference;
  14. $fixturesPath = __DIR__.'/../../../../fixtures/Symfony/Components/DependencyInjection/';
  15. $t = new LimeTest(1);
  16. // __construct()
  17. $t->diag('__construct()');
  18. $definitions = array(
  19. 'foo' => new Definition('FooClass'),
  20. 'bar' => new Definition('BarClass'),
  21. );
  22. $parameters = array(
  23. 'foo' => 'foo',
  24. 'bar' => 'bar',
  25. );
  26. $configuration = new BuilderConfiguration($definitions, $parameters);
  27. $t->is($configuration->getDefinitions(), $definitions, '__construct() takes an array of definitions as its first argument');
  28. $t->is($configuration->getParameters(), $parameters, '__construct() takes an array of parameters as its second argument');
  29. // ->merge()
  30. $t->diag('->merge()');
  31. $configuration = new BuilderConfiguration();
  32. $configuration->merge(null);
  33. $t->is($configuration->getParameters(), array(), '->merge() accepts null as an argument');
  34. $t->is($configuration->getDefinitions(), array(), '->merge() accepts null as an argument');
  35. $configuration = new BuilderConfiguration(array(), array('bar' => 'foo'));
  36. $configuration1 = new BuilderConfiguration(array(), array('foo' => 'bar'));
  37. $configuration->merge($configuration1);
  38. $t->is($configuration->getParameters(), array('bar' => 'foo', 'foo' => 'bar'), '->merge() merges current parameters with the loaded ones');
  39. $configuration = new BuilderConfiguration(array(), array('bar' => 'foo', 'foo' => 'baz'));
  40. $config = new BuilderConfiguration(array(), array('foo' => 'bar'));
  41. $configuration->merge($config);
  42. $t->is($configuration->getParameters(), array('bar' => 'foo', 'foo' => 'bar'), '->merge() overrides existing parameters');
  43. $configuration = new BuilderConfiguration(array('foo' => new Definition('FooClass'), 'bar' => new Definition('BarClass')));
  44. $config = new BuilderConfiguration(array('baz' => new Definition('BazClass')));
  45. $config->setAlias('alias_for_foo', 'foo');
  46. $configuration->merge($config);
  47. $t->is(array_keys($configuration->getDefinitions()), array('foo', 'bar', 'baz'), '->merge() merges definitions already defined ones');
  48. $t->is($configuration->getAliases(), array('alias_for_foo' => 'foo'), '->merge() registers defined aliases');
  49. $configuration = new BuilderConfiguration(array('foo' => new Definition('FooClass')));
  50. $config->setDefinition('foo', new Definition('BazClass'));
  51. $configuration->merge($config);
  52. $t->is($configuration->getDefinition('foo')->getClass(), 'BazClass', '->merge() overrides already defined services');
  53. // ->setParameters() ->getParameters()
  54. $t->diag('->setParameters() ->getParameters()');
  55. $configuration = new BuilderConfiguration();
  56. $t->is($configuration->getParameters(), array(), '->getParameters() returns an empty array if no parameter has been defined');
  57. $configuration->setParameters(array('foo' => 'bar'));
  58. $t->is($configuration->getParameters(), array('foo' => 'bar'), '->setParameters() sets the parameters');
  59. $configuration->setParameters(array('bar' => 'foo'));
  60. $t->is($configuration->getParameters(), array('bar' => 'foo'), '->setParameters() overrides the previous defined parameters');
  61. $configuration->setParameters(array('Bar' => 'foo'));
  62. $t->is($configuration->getParameters(), array('bar' => 'foo'), '->setParameters() converts the key to lowercase');
  63. // ->setParameter() ->getParameter()
  64. $t->diag('->setParameter() ->getParameter() ');
  65. $configuration = new BuilderConfiguration(array(), array('foo' => 'bar'));
  66. $configuration->setParameter('bar', 'foo');
  67. $t->is($configuration->getParameter('bar'), 'foo', '->setParameter() sets the value of a new parameter');
  68. $configuration->setParameter('foo', 'baz');
  69. $t->is($configuration->getParameter('foo'), 'baz', '->setParameter() overrides previously set parameter');
  70. $configuration->setParameter('Foo', 'baz1');
  71. $t->is($configuration->getParameter('foo'), 'baz1', '->setParameter() converts the key to lowercase');
  72. $t->is($configuration->getParameter('FOO'), 'baz1', '->getParameter() converts the key to lowercase');
  73. try
  74. {
  75. $configuration->getParameter('baba');
  76. $t->fail('->getParameter() throws an \InvalidArgumentException if the key does not exist');
  77. }
  78. catch (\InvalidArgumentException $e)
  79. {
  80. $t->pass('->getParameter() throws an \InvalidArgumentException if the key does not exist');
  81. }
  82. // ->hasParameter()
  83. $t->diag('->hasParameter()');
  84. $configuration = new BuilderConfiguration(array(), array('foo' => 'bar'));
  85. $t->ok($configuration->hasParameter('foo'), '->hasParameter() returns true if a parameter is defined');
  86. $t->ok($configuration->hasParameter('Foo'), '->hasParameter() converts the key to lowercase');
  87. $t->ok(!$configuration->hasParameter('bar'), '->hasParameter() returns false if a parameter is not defined');
  88. // ->addParameters()
  89. $t->diag('->addParameters()');
  90. $configuration = new BuilderConfiguration(array(), array('foo' => 'bar'));
  91. $configuration->addParameters(array('bar' => 'foo'));
  92. $t->is($configuration->getParameters(), array('foo' => 'bar', 'bar' => 'foo'), '->addParameters() adds parameters to the existing ones');
  93. $configuration->addParameters(array('Bar' => 'fooz'));
  94. $t->is($configuration->getParameters(), array('foo' => 'bar', 'bar' => 'fooz'), '->addParameters() converts keys to lowercase');
  95. // ->setAlias() ->getAlias() ->hasAlias() ->getAliases() ->addAliases()
  96. $t->diag('->setAlias() ->getAlias() ->hasAlias()');
  97. $configuration = new BuilderConfiguration();
  98. $configuration->setAlias('bar', 'foo');
  99. $t->is($configuration->getAlias('bar'), 'foo', '->setAlias() defines a new alias');
  100. $t->ok($configuration->hasAlias('bar'), '->hasAlias() returns true if the alias is defined');
  101. $t->ok(!$configuration->hasAlias('baba'), '->hasAlias() returns false if the alias is not defined');
  102. try
  103. {
  104. $configuration->getAlias('baba');
  105. $t->fail('->getAlias() throws an \InvalidArgumentException if the alias does not exist');
  106. }
  107. catch (\InvalidArgumentException $e)
  108. {
  109. $t->pass('->getAlias() throws an \InvalidArgumentException if the alias does not exist');
  110. }
  111. $configuration->setAlias('barbar', 'foofoo');
  112. $t->is($configuration->getAliases(), array('bar' => 'foo', 'barbar' => 'foofoo'), '->getAliases() returns an array of all defined aliases');
  113. $configuration->addAliases(array('foo' => 'bar'));
  114. $t->is($configuration->getAliases(), array('bar' => 'foo', 'barbar' => 'foofoo', 'foo' => 'bar'), '->addAliases() adds some aliases');
  115. // ->setDefinitions() ->addDefinitions() ->getDefinitions() ->setDefinition() ->getDefinition() ->hasDefinition()
  116. $t->diag('->setDefinitions() ->addDefinitions() ->getDefinitions() ->setDefinition() ->getDefinition() ->hasDefinition()');
  117. $configuration = new BuilderConfiguration();
  118. $definitions = array(
  119. 'foo' => new Definition('FooClass'),
  120. 'bar' => new Definition('BarClass'),
  121. );
  122. $configuration->setDefinitions($definitions);
  123. $t->is($configuration->getDefinitions(), $definitions, '->setDefinitions() sets the service definitions');
  124. $t->ok($configuration->hasDefinition('foo'), '->hasDefinition() returns true if a service definition exists');
  125. $t->ok(!$configuration->hasDefinition('foobar'), '->hasDefinition() returns false if a service definition does not exist');
  126. $configuration->setDefinition('foobar', $foo = new Definition('FooBarClass'));
  127. $t->is($configuration->getDefinition('foobar'), $foo, '->getDefinition() returns a service definition if defined');
  128. $t->ok($configuration->setDefinition('foobar', $foo = new Definition('FooBarClass')) === $foo, '->setDefinition() implements a fuild interface by returning the service reference');
  129. $configuration->addDefinitions($defs = array('foobar' => new Definition('FooBarClass')));
  130. $t->is($configuration->getDefinitions(), array_merge($definitions, $defs), '->addDefinitions() adds the service definitions');
  131. try
  132. {
  133. $configuration->getDefinition('baz');
  134. $t->fail('->getDefinition() throws an InvalidArgumentException if the service definition does not exist');
  135. }
  136. catch (InvalidArgumentException $e)
  137. {
  138. $t->pass('->getDefinition() throws an InvalidArgumentException if the service definition does not exist');
  139. }
  140. // ->findDefinition()
  141. $t->diag('->findDefinition()');
  142. $configuration = new BuilderConfiguration(array('foo' => $definition = new Definition('FooClass')));
  143. $configuration->setAlias('bar', 'foo');
  144. $configuration->setAlias('foobar', 'bar');
  145. $t->is($configuration->findDefinition('foobar'), $definition, '->findDefinition() returns a Definition');