FormExtensionDivLayoutTest.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  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 Symfony\Tests\Bridge\Twig\Extension;
  11. require_once __DIR__.'/Fixtures/StubTranslator.php';
  12. require_once __DIR__.'/Fixtures/StubFilesystemLoader.php';
  13. use Symfony\Component\Form\FormView;
  14. use Symfony\Bridge\Twig\Extension\FormExtension;
  15. use Symfony\Bridge\Twig\Extension\TranslationExtension;
  16. use Symfony\Tests\Component\Form\AbstractDivLayoutTest;
  17. use Symfony\Tests\Bridge\Twig\Extension\Fixtures\StubTranslator;
  18. use Symfony\Tests\Bridge\Twig\Extension\Fixtures\StubFilesystemLoader;
  19. class FormExtensionDivLayoutTest extends AbstractDivLayoutTest
  20. {
  21. protected function setUp()
  22. {
  23. if (!class_exists('Twig_Environment')) {
  24. $this->markTestSkipped('Twig is not available.');
  25. }
  26. parent::setUp();
  27. $loader = new StubFilesystemLoader(array(
  28. __DIR__.'/../../../../../../src/Symfony/Bridge/Twig/Resources/views/Form',
  29. __DIR__,
  30. ));
  31. $this->extension = new FormExtension(array(
  32. 'div_layout.html.twig',
  33. 'custom_widgets.html.twig',
  34. ));
  35. $environment = new \Twig_Environment($loader);
  36. $environment->addExtension($this->extension);
  37. $environment->addExtension(new TranslationExtension(new StubTranslator()));
  38. $this->extension->initRuntime($environment);
  39. }
  40. public function testThemeInheritance()
  41. {
  42. $child = $this->factory->createNamedBuilder('form', 'child')
  43. ->add('field', 'text')
  44. ->getForm();
  45. $view = $this->factory->createNamedBuilder('form', 'parent')
  46. ->add('field', 'text')
  47. ->getForm()
  48. ->add($child)
  49. ->createView()
  50. ;
  51. $this->extension->setTheme($view, array('parent_label.html.twig'));
  52. $this->extension->setTheme($view['child'], array('child_label.html.twig'));
  53. $this->assertWidgetMatchesXpath($view, array(),
  54. '/div
  55. [
  56. ./input[@type="hidden"]
  57. /following-sibling::div
  58. [
  59. ./label[.="parent"]
  60. /following-sibling::input[@type="text"]
  61. ]
  62. /following-sibling::div
  63. [
  64. ./label
  65. /following-sibling::div
  66. [
  67. ./div
  68. [
  69. ./label[.="child"]
  70. /following-sibling::input[@type="text"]
  71. ]
  72. ]
  73. ]
  74. ]
  75. '
  76. );
  77. }
  78. protected function renderEnctype(FormView $view)
  79. {
  80. return (string)$this->extension->renderEnctype($view);
  81. }
  82. protected function renderLabel(FormView $view, $label = null, array $vars = array())
  83. {
  84. return (string)$this->extension->renderLabel($view, $label, $vars);
  85. }
  86. protected function renderErrors(FormView $view)
  87. {
  88. return (string)$this->extension->renderErrors($view);
  89. }
  90. protected function renderWidget(FormView $view, array $vars = array())
  91. {
  92. return (string)$this->extension->renderWidget($view, $vars);
  93. }
  94. protected function renderRow(FormView $view, array $vars = array())
  95. {
  96. return (string)$this->extension->renderRow($view, $vars);
  97. }
  98. protected function renderRest(FormView $view, array $vars = array())
  99. {
  100. return (string)$this->extension->renderRest($view, $vars);
  101. }
  102. }