BaseFieldDescriptionTest.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  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(1, $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. $this->assertEquals('short_object_description_placeholder', $description->getOption('placeholder'));
  48. $description->setOptions(array('placeholder' => false));
  49. $this->assertFalse($description->getOption('placeholder'));
  50. $description->setOption('sortable', false);
  51. $this->assertFalse($description->isSortable());
  52. $description->setOption('sortable', 'field_name');
  53. $this->assertTrue($description->isSortable());
  54. }
  55. public function testAdmin()
  56. {
  57. $description = new FieldDescription();
  58. $admin = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  59. $description->setAdmin($admin);
  60. $this->isInstanceOf('Sonata\AdminBundle\Admin\AdminInterface', $description->getAdmin());
  61. $associationAdmin = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  62. $associationAdmin->expects($this->once())->method('setParentFieldDescription');
  63. $this->assertFalse($description->hasAssociationAdmin());
  64. $description->setAssociationAdmin($associationAdmin);
  65. $this->assertTrue($description->hasAssociationAdmin());
  66. $this->isInstanceOf('Sonata\AdminBundle\Admin\AdminInterface', $description->getAssociationAdmin());
  67. $parent = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  68. $description->setParent($parent);
  69. $this->isInstanceOf('Sonata\AdminBundle\Admin\AdminInterface', $description->getParent());
  70. }
  71. public function testGetValue()
  72. {
  73. $description = new FieldDescription();
  74. $mock = $this->getMock('stdClass', array('getFake'));
  75. $mock->expects($this->once())->method('getFake')->will($this->returnValue(42));
  76. $this->assertEquals(42, $description->getFieldValue($mock, 'fake'));
  77. }
  78. public function testGetValueCode()
  79. {
  80. $description = new FieldDescription();
  81. $description->setOption('code', 'getFoo');
  82. $mock = $this->getMock('stdClass', array('getFoo'));
  83. $mock->expects($this->once())->method('getFoo')->will($this->returnValue(42));
  84. $this->assertEquals(42, $description->getFieldValue($mock, 'fake'));
  85. }
  86. /**
  87. * @expectedException Sonata\AdminBundle\Exception\NoValueException
  88. */
  89. public function testGetValueNoValueException()
  90. {
  91. $description = new FieldDescription();
  92. $mock = $this->getMock('stdClass', array('getFoo'));
  93. $description->getFieldValue($mock, 'fake');
  94. }
  95. /**
  96. * @expectedException RuntimeException
  97. */
  98. public function testExceptionOnNonArrayOption()
  99. {
  100. $description = new FieldDescription();
  101. $description->setOption('bar', 'hello');
  102. $description->mergeOption('bar', array('exception'));
  103. }
  104. public function testGetTranslationDomain()
  105. {
  106. $description = new FieldDescription();
  107. $admin = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  108. $description->setAdmin($admin);
  109. $admin->expects($this->once())
  110. ->method('getTranslationDomain')
  111. ->will($this->returnValue('AdminDomain'));
  112. $this->assertEquals('AdminDomain', $description->getTranslationDomain());
  113. $admin->expects($this->never())
  114. ->method('getTranslationDomain');
  115. $description->setOption('translation_domain', 'ExtensionDomain');
  116. $this->assertEquals('ExtensionDomain', $description->getTranslationDomain());
  117. }
  118. public function testCamelize()
  119. {
  120. $this->assertEquals('FooBar', BaseFieldDescription::camelize('foo_bar'));
  121. $this->assertEquals('FooBar', BaseFieldDescription::camelize('foo bar'));
  122. $this->assertEquals('FOoBar', BaseFieldDescription::camelize('fOo bar'));
  123. }
  124. }
  125. class FieldDescription extends BaseFieldDescription
  126. {
  127. public function setAssociationMapping($associationMapping)
  128. {
  129. // TODO: Implement setAssociationMapping() method.
  130. }
  131. public function getTargetEntity()
  132. {
  133. // TODO: Implement getTargetEntity() method.
  134. }
  135. public function setFieldMapping($fieldMapping)
  136. {
  137. // TODO: Implement setFieldMapping() method.
  138. }
  139. public function isIdentifier()
  140. {
  141. // TODO: Implement isIdentifier() method.
  142. }
  143. /**
  144. * set the parent association mappings information
  145. *
  146. * @param array $parentAssociationMappings
  147. * @return void
  148. */
  149. public function setParentAssociationMappings(array $parentAssociationMappings)
  150. {
  151. // TODO: Implement setParentAssociationMappings() method.
  152. }
  153. /**
  154. * return the value linked to the description
  155. *
  156. * @param $object
  157. * @return bool|mixed
  158. */
  159. public function getValue($object)
  160. {
  161. // TODO: Implement getValue() method.
  162. }
  163. }