BuilderConfigurationTest.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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\Components\DependencyInjection;
  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. use Symfony\Components\DependencyInjection\Resource\FileResource;
  15. use Symfony\Components\DependencyInjection\ParameterBag\ParameterBag;
  16. class BuilderConfigurationTest extends \PHPUnit_Framework_TestCase
  17. {
  18. static protected $fixturesPath;
  19. static public function setUpBeforeClass()
  20. {
  21. self::$fixturesPath = __DIR__.'/Fixtures/';
  22. }
  23. /**
  24. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::__construct
  25. */
  26. public function testConstructor()
  27. {
  28. $definitions = array(
  29. 'foo' => new Definition('FooClass'),
  30. 'bar' => new Definition('BarClass'),
  31. );
  32. $parameters = array(
  33. 'foo' => 'foo',
  34. 'bar' => 'bar',
  35. );
  36. $configuration = new BuilderConfiguration($definitions, new ParameterBag($parameters));
  37. $this->assertEquals($definitions, $configuration->getDefinitions(), '__construct() takes an array of definitions as its first argument');
  38. $this->assertEquals($parameters, $configuration->getParameterBag()->all(), '__construct() takes a ParameterBag instance as its second argument');
  39. }
  40. /**
  41. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::merge
  42. */
  43. public function testMerge()
  44. {
  45. $configuration = new BuilderConfiguration();
  46. $configuration->merge(null);
  47. $this->assertEquals(array(), $configuration->getParameterBag()->all(), '->merge() accepts null as an argument');
  48. $this->assertEquals(array(), $configuration->getDefinitions(), '->merge() accepts null as an argument');
  49. $configuration = new BuilderConfiguration(array(), new ParameterBag(array('bar' => 'foo')));
  50. $configuration1 = new BuilderConfiguration(array(), new ParameterBag(array('foo' => 'bar')));
  51. $configuration->merge($configuration1);
  52. $this->assertEquals(array('bar' => 'foo', 'foo' => 'bar'), $configuration->getParameterBag()->all(), '->merge() merges current parameters with the loaded ones');
  53. $configuration = new BuilderConfiguration(array(), new ParameterBag(array('bar' => 'foo', 'foo' => 'baz')));
  54. $config = new BuilderConfiguration(array(), new ParameterBag(array('foo' => 'bar')));
  55. $configuration->merge($config);
  56. $this->assertEquals(array('bar' => 'foo', 'foo' => 'bar'), $configuration->getParameterBag()->all(), '->merge() overrides existing parameters');
  57. $configuration = new BuilderConfiguration(array('foo' => new Definition('FooClass'), 'bar' => new Definition('BarClass')));
  58. $config = new BuilderConfiguration(array('baz' => new Definition('BazClass')));
  59. $config->setAlias('alias_for_foo', 'foo');
  60. $configuration->merge($config);
  61. $this->assertEquals(array('foo', 'bar', 'baz'), array_keys($configuration->getDefinitions()), '->merge() merges definitions already defined ones');
  62. $this->assertEquals(array('alias_for_foo' => 'foo'), $configuration->getAliases(), '->merge() registers defined aliases');
  63. $configuration = new BuilderConfiguration(array('foo' => new Definition('FooClass')));
  64. $config->setDefinition('foo', new Definition('BazClass'));
  65. $configuration->merge($config);
  66. $this->assertEquals('BazClass', $configuration->getDefinition('foo')->getClass(), '->merge() overrides already defined services');
  67. $configuration = new BuilderConfiguration();
  68. $configuration->addResource($a = new FileResource(self::$fixturesPath.'/xml/services1.xml'));
  69. $config = new BuilderConfiguration();
  70. $config->addResource($b = new FileResource(self::$fixturesPath.'/xml/services2.xml'));
  71. $configuration->merge($config);
  72. $this->assertEquals(array($a, $b), $configuration->getResources(), '->merge() merges resources');
  73. }
  74. /**
  75. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::getParameterBag
  76. */
  77. public function testGetParameterBag()
  78. {
  79. $configuration = new BuilderConfiguration();
  80. $this->assertEquals(array(), $configuration->getParameterBag()->all(), '->getParameterBag() returns an empty bag if no parameter has been defined');
  81. $configuration = new BuilderConfiguration(array(), new ParameterBag(array('foo' => 'bar')));
  82. $this->assertEquals(array('foo' => 'bar'), $configuration->getParameterBag()->all(), '->getParameterBag() returns the parameter bag passed at construction time');
  83. }
  84. /**
  85. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::getParameter
  86. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::setParameter
  87. */
  88. public function testSetGetParameter()
  89. {
  90. $configuration = new BuilderConfiguration(array(), new ParameterBag(array('foo' => 'bar')));
  91. $configuration->setParameter('bar', 'foo');
  92. $this->assertEquals('foo', $configuration->getParameter('bar'), '->setParameter() sets the value of a new parameter');
  93. $configuration->setParameter('foo', 'baz');
  94. $this->assertEquals('baz', $configuration->getParameter('foo'), '->setParameter() overrides previously set parameter');
  95. $configuration->setParameter('Foo', 'baz1');
  96. $this->assertEquals('baz1', $configuration->getParameter('foo'), '->setParameter() converts the key to lowercase');
  97. $this->assertEquals('baz1', $configuration->getParameter('FOO'), '->getParameter() converts the key to lowercase');
  98. try {
  99. $configuration->getParameter('baba');
  100. $this->fail('->getParameter() throws an \InvalidArgumentException if the key does not exist');
  101. } catch (\Exception $e) {
  102. $this->assertInstanceOf('\InvalidArgumentException', $e, '->getParameter() throws an \InvalidArgumentException if the key does not exist');
  103. $this->assertEquals('The parameter "baba" must be defined.', $e->getMessage(), '->getParameter() throws an \InvalidArgumentException if the key does not exist');
  104. }
  105. }
  106. /**
  107. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::setAlias
  108. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::getAlias
  109. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::hasAlias
  110. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::getAliases
  111. */
  112. public function testAliases()
  113. {
  114. $configuration = new BuilderConfiguration();
  115. $configuration->setAlias('bar', 'foo');
  116. $this->assertEquals('foo', $configuration->getAlias('bar'), '->setAlias() defines a new alias');
  117. $this->assertTrue($configuration->hasAlias('bar'), '->hasAlias() returns true if the alias is defined');
  118. $this->assertFalse($configuration->hasAlias('baba'), '->hasAlias() returns false if the alias is not defined');
  119. try {
  120. $configuration->getAlias('baba');
  121. $this->fail('->getAlias() throws an \InvalidArgumentException if the alias does not exist');
  122. } catch (\Exception $e) {
  123. $this->assertInstanceOf('\InvalidArgumentException', $e, '->getAlias() throws an \InvalidArgumentException if the alias does not exist');
  124. $this->assertEquals('The service alias "baba" does not exist.', $e->getMessage(), '->getAlias() throws an \InvalidArgumentException if the alias does not exist');
  125. }
  126. $configuration->setAlias('barbar', 'foofoo');
  127. $this->assertEquals(array('bar' => 'foo', 'barbar' => 'foofoo'), $configuration->getAliases(), '->getAliases() returns an array of all defined aliases');
  128. $configuration->addAliases(array('foo' => 'bar'));
  129. $this->assertEquals(array('bar' => 'foo', 'barbar' => 'foofoo', 'foo' => 'bar'), $configuration->getAliases(), '->addAliases() adds some aliases');
  130. }
  131. /**
  132. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::setDefinitions
  133. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::addDefinitions
  134. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::hasDefinition
  135. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::getDefinition
  136. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::setDefinition
  137. */
  138. public function testDefinitions()
  139. {
  140. $configuration = new BuilderConfiguration();
  141. $definitions = array(
  142. 'foo' => new Definition('FooClass'),
  143. 'bar' => new Definition('BarClass'),
  144. );
  145. $configuration->setDefinitions($definitions);
  146. $this->assertEquals($definitions, $configuration->getDefinitions(), '->setDefinitions() sets the service definitions');
  147. $this->assertTrue($configuration->hasDefinition('foo'), '->hasDefinition() returns true if a service definition exists');
  148. $this->assertFalse($configuration->hasDefinition('foobar'), '->hasDefinition() returns false if a service definition does not exist');
  149. $configuration->setDefinition('foobar', $foo = new Definition('FooBarClass'));
  150. $this->assertEquals($foo, $configuration->getDefinition('foobar'), '->getDefinition() returns a service definition if defined');
  151. $this->assertTrue($configuration->setDefinition('foobar', new Definition('FooBarClass')) === $configuration, '->setDefinition() implements a fuild interface');
  152. $configuration->addDefinitions($defs = array('foobar' => new Definition('FooBarClass')));
  153. $this->assertEquals(array_merge($definitions, $defs), $configuration->getDefinitions(), '->addDefinitions() adds the service definitions');
  154. try {
  155. $configuration->getDefinition('baz');
  156. $this->fail('->getDefinition() throws an InvalidArgumentException if the service definition does not exist');
  157. } catch (\Exception $e) {
  158. $this->assertInstanceOf('\InvalidArgumentException', $e, '->getDefinition() throws an InvalidArgumentException if the service definition does not exist');
  159. $this->assertEquals('The service definition "baz" does not exist.', $e->getMessage(), '->getDefinition() throws an InvalidArgumentException if the service definition does not exist');
  160. }
  161. }
  162. /**
  163. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::findDefinition
  164. */
  165. public function testFindDefinition()
  166. {
  167. $configuration = new BuilderConfiguration(array('foo' => $definition = new Definition('FooClass')));
  168. $configuration->setAlias('bar', 'foo');
  169. $configuration->setAlias('foobar', 'bar');
  170. $this->assertEquals($definition, $configuration->findDefinition('foobar'), '->findDefinition() returns a Definition');
  171. }
  172. /**
  173. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::getResources
  174. * @covers Symfony\Components\DependencyInjection\BuilderConfiguration::addResource
  175. */
  176. public function testResources()
  177. {
  178. $configuration = new BuilderConfiguration();
  179. $configuration->addResource($a = new FileResource(self::$fixturesPath.'/xml/services1.xml'));
  180. $configuration->addResource($b = new FileResource(self::$fixturesPath.'/xml/services2.xml'));
  181. $this->assertEquals(array($a, $b), $configuration->getResources(), '->getResources() returns an array of resources read for the current configuration');
  182. }
  183. }