BaseFieldDescriptionTest.php 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  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. $description->setOption('code', 'getFoo');
  75. $mock = $this->getMock('stdClass', array('getFoo'));
  76. $mock->expects($this->once())->method('getFoo')->will($this->returnValue(42));
  77. $this->assertEquals(42, $description->getFieldValue($mock, 'fake'));
  78. }
  79. /**
  80. * @expectedException Sonata\AdminBundle\Exception\NoValueException
  81. */
  82. public function testGetValueNoValueException()
  83. {
  84. $description = new FieldDescription();
  85. $mock = $this->getMock('stdClass', array('getFoo'));
  86. $description->getFieldValue($mock, 'fake');
  87. }
  88. /**
  89. * @expectedException RuntimeException
  90. */
  91. public function testExceptionOnNonArrayOption()
  92. {
  93. $description = new FieldDescription();
  94. $description->setOption('bar', 'hello');
  95. $description->mergeOption('bar', array('exception'));
  96. }
  97. public function testGetTranslationDomain()
  98. {
  99. $description = new FieldDescription();
  100. $admin = $this->getMock('Sonata\AdminBundle\Admin\AdminInterface');
  101. $description->setAdmin($admin);
  102. $admin->expects($this->once())
  103. ->method('getTranslationDomain')
  104. ->will($this->returnValue('AdminDomain'));
  105. $this->assertEquals('AdminDomain', $description->getTranslationDomain());
  106. $admin->expects($this->never())
  107. ->method('getTranslationDomain');
  108. $description->setOption('translation_domain', 'ExtensionDomain');
  109. $this->assertEquals('ExtensionDomain', $description->getTranslationDomain());
  110. }
  111. public function testCamelize()
  112. {
  113. $this->assertEquals('FooBar', BaseFieldDescription::camelize('foo_bar'));
  114. $this->assertEquals('FooBar', BaseFieldDescription::camelize('foo bar'));
  115. $this->assertEquals('FOoBar', BaseFieldDescription::camelize('fOo bar'));
  116. }
  117. }
  118. class FieldDescription extends BaseFieldDescription
  119. {
  120. public function setAssociationMapping($associationMapping)
  121. {
  122. // TODO: Implement setAssociationMapping() method.
  123. }
  124. public function getTargetEntity()
  125. {
  126. // TODO: Implement getTargetEntity() method.
  127. }
  128. public function setFieldMapping($fieldMapping)
  129. {
  130. // TODO: Implement setFieldMapping() method.
  131. }
  132. public function isIdentifier()
  133. {
  134. // TODO: Implement isIdentifier() method.
  135. }
  136. /**
  137. * set the parent association mappings information
  138. *
  139. * @param array $parentAssociationMappings
  140. * @return void
  141. */
  142. public function setParentAssociationMappings(array $parentAssociationMappings)
  143. {
  144. // TODO: Implement setParentAssociationMappings() method.
  145. }
  146. /**
  147. * return the value linked to the description
  148. *
  149. * @param $object
  150. * @return bool|mixed
  151. */
  152. public function getValue($object)
  153. {
  154. // TODO: Implement getValue() method.
  155. }
  156. }