BaseFieldDescriptionTest.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. <?php
  2. /*
  3. * This file is part of the Sonata package.
  4. *
  5. * (c) Thomas Rabaix <thomas.rabaix@sonata-project.org>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Sonata\AdminBundle\Tests\Admin;
  11. use Sonata\AdminBundle\Admin\BaseFieldDescription;
  12. use Sonata\AdminBundle\Admin\AdminInterface;
  13. class BaseFieldDescriptionTest extends \PHPUnit_Framework_TestCase
  14. {
  15. public function testSetName()
  16. {
  17. $description = new FieldDescription();
  18. $description->setName('foo');
  19. $this->assertEquals('foo', $description->getFieldName());
  20. $this->assertEquals('foo', $description->getName());
  21. }
  22. public function testOptions()
  23. {
  24. $description = new FieldDescription();
  25. $description->setOption('foo', 'bar');
  26. $this->assertNull($description->getOption('bar'));
  27. $this->assertEquals('bar', $description->getOption('foo'));
  28. $description->mergeOptions(array('settings' => array('value_1', 'value_2')));
  29. $description->mergeOptions(array('settings' => array('value_1', 'value_3')));
  30. $this->assertEquals(array('value_1', 'value_2', 'value_1', 'value_3'), $description->getOption('settings'));
  31. $description->mergeOption('settings', array('value_4'));
  32. $this->assertEquals(array('value_1', 'value_2', 'value_1', 'value_3', 'value_4'), $description->getOption('settings'));
  33. $description->mergeOption('bar', array('hello'));
  34. $this->assertCount(1, $description->getOption('bar'));
  35. $description->setOption('label', 'trucmuche');
  36. $this->assertEquals('trucmuche', $description->getLabel());
  37. $this->assertNull($description->getTemplate());
  38. $description->setOptions(array('type' => 'integer', 'template' => 'foo.twig.html', 'help' => 'fooHelp'));
  39. $this->assertEquals('integer', $description->getType());
  40. $this->assertEquals('foo.twig.html', $description->getTemplate());
  41. $this->assertEquals('fooHelp', $description->getHelp());
  42. $this->assertCount(0, $description->getOptions());
  43. $description->setHelp('Please enter an integer');
  44. $this->assertEquals('Please enter an integer', $description->getHelp());
  45. $description->setMappingType('int');
  46. $this->assertEquals('int', $description->getMappingType());
  47. }
  48. public function testAdmin()
  49. {
  50. $description = new FieldDescription();
  51. $admin = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  52. $description->setAdmin($admin);
  53. $this->isInstanceOf('Sonata\AdminBundle\Admin\AdminInterface', $description->getAdmin());
  54. $associationAdmin = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  55. $associationAdmin->expects($this->once())->method('setParentFieldDescription');
  56. $this->assertFalse($description->hasAssociationAdmin());
  57. $description->setAssociationAdmin($associationAdmin);
  58. $this->assertTrue($description->hasAssociationAdmin());
  59. $this->isInstanceOf('Sonata\AdminBundle\Admin\AdminInterface', $description->getAssociationAdmin());
  60. $parent = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  61. $description->setParent($parent);
  62. $this->isInstanceOf('Sonata\AdminBundle\Admin\AdminInterface', $description->getParent());
  63. }
  64. public function testGetValue()
  65. {
  66. $description = new FieldDescription();
  67. $description->setOption('code', 'getFoo');
  68. $mock = $this->getMock('stdClass', array('getFoo'));
  69. $mock->expects($this->once())->method('getFoo')->will($this->returnValue(42));
  70. $this->assertEquals(42, $description->getFieldValue($mock, 'fake'));
  71. /**
  72. * Test with One parameter int
  73. */
  74. $arg1 = 38;
  75. $oneParameter = array($arg1);
  76. $description1 = new FieldDescription();
  77. $description1->setOption('code', 'getWithOneParameter');
  78. $description1->setOption('parameters', $oneParameter);
  79. $mock1 = $this->getMock('stdClass', array('getWithOneParameter'));
  80. $returnValue1 = $arg1 + 2;
  81. $mock1->expects($this->once())->method('getWithOneParameter')->with($this->equalTo($arg1))->will($this->returnValue($returnValue1));
  82. $this->assertEquals(40, $description1->getFieldValue($mock1, 'fake'));
  83. /**
  84. * Test with Two parameters int
  85. */
  86. $arg2 = 4;
  87. $twoParameters = array($arg1,$arg2);
  88. $description2 = new FieldDescription();
  89. $description2->setOption('code', 'getWithTwoParameters');
  90. $description2->setOption('parameters', $twoParameters);
  91. $mock2 = $this->getMock('stdClass', array('getWithTwoParameters'));
  92. $returnValue2 = $arg1 + $arg2;
  93. $mock2->expects($this->any())->method('getWithTwoParameters')->with($this->equalTo($arg1),$this->equalTo($arg2))->will($this->returnValue($returnValue2));
  94. $this->assertEquals(42, $description2->getFieldValue($mock2, 'fake'));
  95. }
  96. /**
  97. * @expectedException Sonata\AdminBundle\Exception\NoValueException
  98. */
  99. public function testGetValueNoValueException()
  100. {
  101. $description = new FieldDescription();
  102. $mock = $this->getMock('stdClass', array('getFoo'));
  103. $description->getFieldValue($mock, 'fake');
  104. }
  105. /**
  106. * @expectedException RuntimeException
  107. */
  108. public function testExceptionOnNonArrayOption()
  109. {
  110. $description = new FieldDescription();
  111. $description->setOption('bar', 'hello');
  112. $description->mergeOption('bar', array('exception'));
  113. }
  114. public function testGetTranslationDomain()
  115. {
  116. $description = new FieldDescription();
  117. $admin = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  118. $description->setAdmin($admin);
  119. $admin->expects($this->once())
  120. ->method('getTranslationDomain')
  121. ->will($this->returnValue('AdminDomain'));
  122. $this->assertEquals('AdminDomain', $description->getTranslationDomain());
  123. $admin->expects($this->never())
  124. ->method('getTranslationDomain');
  125. $description->setOption('translation_domain', 'ExtensionDomain');
  126. $this->assertEquals('ExtensionDomain', $description->getTranslationDomain());
  127. }
  128. }
  129. class FieldDescription extends BaseFieldDescription
  130. {
  131. public function setAssociationMapping($associationMapping)
  132. {
  133. // TODO: Implement setAssociationMapping() method.
  134. }
  135. public function getTargetEntity()
  136. {
  137. // TODO: Implement getTargetEntity() method.
  138. }
  139. public function setFieldMapping($fieldMapping)
  140. {
  141. // TODO: Implement setFieldMapping() method.
  142. }
  143. public function isIdentifier()
  144. {
  145. // TODO: Implement isIdentifier() method.
  146. }
  147. /**
  148. * set the parent association mappings information
  149. *
  150. * @param array $parentAssociationMappings
  151. * @return void
  152. */
  153. public function setParentAssociationMappings(array $parentAssociationMappings)
  154. {
  155. // TODO: Implement setParentAssociationMappings() method.
  156. }
  157. /**
  158. * return the value linked to the description
  159. *
  160. * @param $object
  161. * @return bool|mixed
  162. */
  163. public function getValue($object)
  164. {
  165. // TODO: Implement getValue() method.
  166. }
  167. }