DefinitionTest.php 4.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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. require_once __DIR__.'/../../bootstrap.php';
  11. use Symfony\Components\DependencyInjection\Definition;
  12. class DefinitionTest extends \PHPUnit_Framework_TestCase
  13. {
  14. public function testConstructor()
  15. {
  16. $def = new Definition('stdClass');
  17. $this->assertEquals($def->getClass(), 'stdClass', '__construct() takes the class name as its first argument');
  18. $def = new Definition('stdClass', array('foo'));
  19. $this->assertEquals($def->getArguments(), array('foo'), '__construct() takes an optional array of arguments as its second argument');
  20. }
  21. public function testSetGetConstructor()
  22. {
  23. $def = new Definition('stdClass');
  24. $this->assertEquals(spl_object_hash($def->setConstructor('foo')), spl_object_hash($def), '->setConstructor() implements a fluent interface');
  25. $this->assertEquals($def->getConstructor(), 'foo', '->getConstructor() returns the constructor name');
  26. }
  27. public function testSetGetClass()
  28. {
  29. $def = new Definition('stdClass');
  30. $this->assertEquals(spl_object_hash($def->setClass('foo')), spl_object_hash($def), '->setClass() implements a fluent interface');
  31. $this->assertEquals($def->getClass(), 'foo', '->getClass() returns the class name');
  32. }
  33. public function testArguments()
  34. {
  35. $def = new Definition('stdClass');
  36. $this->assertEquals(spl_object_hash($def->setArguments(array('foo'))), spl_object_hash($def), '->setArguments() implements a fluent interface');
  37. $this->assertEquals($def->getArguments(), array('foo'), '->getArguments() returns the arguments');
  38. $this->assertEquals(spl_object_hash($def->addArgument('bar')), spl_object_hash($def), '->addArgument() implements a fluent interface');
  39. $this->assertEquals($def->getArguments(), array('foo', 'bar'), '->addArgument() adds an argument');
  40. }
  41. public function testMethodCalls()
  42. {
  43. $def = new Definition('stdClass');
  44. $this->assertEquals(spl_object_hash($def->setMethodCalls(array(array('foo', array('foo'))))), spl_object_hash($def), '->setMethodCalls() implements a fluent interface');
  45. $this->assertEquals($def->getMethodCalls(), array(array('foo', array('foo'))), '->getMethodCalls() returns the methods to call');
  46. $this->assertEquals(spl_object_hash($def->addMethodCall('bar', array('bar'))), spl_object_hash($def), '->addMethodCall() implements a fluent interface');
  47. $this->assertEquals($def->getMethodCalls(), array(array('foo', array('foo')), array('bar', array('bar'))), '->addMethodCall() adds a method to call');
  48. }
  49. public function testSetGetFile()
  50. {
  51. $def = new Definition('stdClass');
  52. $this->assertEquals(spl_object_hash($def->setFile('foo')), spl_object_hash($def), '->setFile() implements a fluent interface');
  53. $this->assertEquals($def->getFile(), 'foo', '->getFile() returns the file to include');
  54. }
  55. public function testSetIsShared()
  56. {
  57. $def = new Definition('stdClass');
  58. $this->assertEquals($def->isShared(), true, '->isShared() returns true by default');
  59. $this->assertEquals(spl_object_hash($def->setShared(false)), spl_object_hash($def), '->setShared() implements a fluent interface');
  60. $this->assertEquals($def->isShared(), false, '->isShared() returns false if the instance must not be shared');
  61. }
  62. public function testSetGetConfigurator()
  63. {
  64. $def = new Definition('stdClass');
  65. $this->assertEquals(spl_object_hash($def->setConfigurator('foo')), spl_object_hash($def), '->setConfigurator() implements a fluent interface');
  66. $this->assertEquals($def->getConfigurator(), 'foo', '->getConfigurator() returns the configurator');
  67. }
  68. public function testAnnotations()
  69. {
  70. $def = new Definition('stdClass');
  71. $this->assertEquals(spl_object_hash($def->addAnnotation('foo')), spl_object_hash($def), '->addAnnotation() implements a fluent interface');
  72. $this->assertEquals($def->getAnnotation('foo'), array(array()), '->getAnnotation() returns attributes for an annotation name');
  73. $def->addAnnotation('foo', array('foo' => 'bar'));
  74. $this->assertEquals($def->getAnnotation('foo'), array(array(), array('foo' => 'bar')), '->addAnnotation() can adds the same annotation several times');
  75. $def->addAnnotation('bar', array('bar' => 'bar'));
  76. $this->assertEquals($def->getAnnotations(), array(
  77. 'foo' => array(array(), array('foo' => 'bar')),
  78. 'bar' => array(array('bar' => 'bar')),
  79. ), '->getAnnotations() returns all annotations');
  80. }
  81. }