EngineTest.php 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien.potencier@symfony-project.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\Components\Templating;
  11. require_once __DIR__.'/../../../../lib/SymfonyTests/Components/Templating/SimpleHelper.php';
  12. use Symfony\Components\Templating\Engine;
  13. use Symfony\Components\Templating\Loader\Loader;
  14. use Symfony\Components\Templating\Renderer\Renderer;
  15. use Symfony\Components\Templating\Renderer\PhpRenderer;
  16. use Symfony\Components\Templating\Storage\Storage;
  17. use Symfony\Components\Templating\Storage\StringStorage;
  18. use Symfony\Components\Templating\Helper\SlotsHelper;
  19. class EngineTest extends \PHPUnit_Framework_TestCase
  20. {
  21. static protected $loader, $renderer;
  22. static public function setUpBeforeClass()
  23. {
  24. self::$loader = new ProjectTemplateLoader();
  25. self::$renderer = new ProjectTemplateRenderer();
  26. }
  27. public function testConstructor()
  28. {
  29. $engine = new ProjectTemplateEngine(self::$loader);
  30. $this->assertEquals(self::$loader, $engine->getLoader(), '__construct() takes a loader instance as its second first argument');
  31. $this->assertEquals(array('php'), array_keys($engine->getRenderers()), '__construct() automatically registers a PHP renderer if none is given');
  32. $engine = new ProjectTemplateEngine(self::$loader, array('foo' => self::$renderer));
  33. $this->assertEquals(array('foo', 'php'), array_keys($engine->getRenderers()), '__construct() takes an array of renderers as its third argument');
  34. $this->assertTrue(self::$renderer->getEngine() === $engine, '__construct() registers itself on all renderers');
  35. $engine = new ProjectTemplateEngine(self::$loader, array('php' => self::$renderer));
  36. $this->assertTrue($engine->getRenderers() === array('php' => self::$renderer), '__construct() can overridde the default PHP renderer');
  37. }
  38. public function testMagicGet()
  39. {
  40. $engine = new ProjectTemplateEngine(self::$loader);
  41. $engine->set($helper = new \SimpleHelper('bar'), 'foo');
  42. $this->assertEquals($helper, $engine->foo, '->__get() returns the value of a helper');
  43. try {
  44. $engine->bar;
  45. $this->fail('->__get() throws an InvalidArgumentException if the helper is not defined');
  46. } catch (\Exception $e) {
  47. $this->assertInstanceOf('\InvalidArgumentException', $e, '->__get() throws an InvalidArgumentException if the helper is not defined');
  48. $this->assertEquals('The helper "bar" is not defined.', $e->getMessage(), '->__get() throws an InvalidArgumentException if the helper is not defined');
  49. }
  50. }
  51. public function testGetSetHas()
  52. {
  53. $engine = new ProjectTemplateEngine(self::$loader);
  54. $foo = new \SimpleHelper('foo');
  55. $engine->set($foo);
  56. $this->assertEquals($foo, $engine->get('foo'), '->set() sets a helper');
  57. $engine->set($foo, 'bar');
  58. $this->assertEquals($foo, $engine->get('bar'), '->set() takes an alias as a second argument');
  59. try {
  60. $engine->get('foobar');
  61. $this->fail('->get() throws an InvalidArgumentException if the helper is not defined');
  62. } catch (\Exception $e) {
  63. $this->assertInstanceOf('\InvalidArgumentException', $e, '->get() throws an InvalidArgumentException if the helper is not defined');
  64. $this->assertEquals('The helper "foobar" is not defined.', $e->getMessage(), '->get() throws an InvalidArgumentException if the helper is not defined');
  65. }
  66. $this->assertTrue($engine->has('foo'), '->has() returns true if the helper exists');
  67. $this->assertFalse($engine->has('foobar'), '->has() returns false if the helper does not exist');
  68. }
  69. public function testExtendRender()
  70. {
  71. $engine = new ProjectTemplateEngine(self::$loader, array(), array(new SlotsHelper()));
  72. try {
  73. $engine->render('name');
  74. $this->fail('->render() throws an InvalidArgumentException if the template does not exist');
  75. } catch (\Exception $e) {
  76. $this->assertInstanceOf('\InvalidArgumentException', $e, '->render() throws an InvalidArgumentException if the template does not exist');
  77. $this->assertEquals('The template "name" does not exist (renderer: php).', $e->getMessage(), '->render() throws an InvalidArgumentException if the template does not exist');
  78. }
  79. try {
  80. self::$loader->setTemplate('name.foo', 'foo');
  81. $engine->render('foo:name');
  82. $this->fail('->render() throws an InvalidArgumentException if no renderer is registered for the given renderer');
  83. } catch (\Exception $e) {
  84. $this->assertInstanceOf('\InvalidArgumentException', $e, '->render() throws an InvalidArgumentException if no renderer is registered for the given renderer');
  85. $this->assertEquals('The template "foo" does not exist (renderer: name).', $e->getMessage(), '->render() throws an InvalidArgumentException if no renderer is registered for the given renderer');
  86. }
  87. $engine = new ProjectTemplateEngine(self::$loader, array(), array(new SlotsHelper()));
  88. $engine->set(new \SimpleHelper('bar'));
  89. self::$loader->setTemplate('foo.php', '<?php $view->extend("layout"); echo $view->foo.$foo ?>');
  90. self::$loader->setTemplate('layout.php', '-<?php echo $view->slots->get("_content") ?>-');
  91. $this->assertEquals('-barfoo-', $engine->render('foo', array('foo' => 'foo')), '->render() uses the decorator to decorate the template');
  92. $engine = new ProjectTemplateEngine(self::$loader, array(), array(new SlotsHelper()));
  93. $engine->set(new \SimpleHelper('bar'));
  94. self::$loader->setTemplate('bar.php', 'bar');
  95. self::$loader->setTemplate('foo.php', '<?php $view->extend("layout"); echo $foo ?>');
  96. self::$loader->setTemplate('layout.php', '<?php echo $view->render("bar") ?>-<?php echo $view->slots->get("_content") ?>-');
  97. $this->assertEquals('bar-foo-', $engine->render('foo', array('foo' => 'foo', 'bar' => 'bar')), '->render() supports render() calls in templates');
  98. }
  99. public function testEscape()
  100. {
  101. $engine = new ProjectTemplateEngine(self::$loader);
  102. $this->assertEquals('&lt;br /&gt;', $engine->escape('<br />'), '->escape() escapes strings');
  103. $foo = new \stdClass();
  104. $this->assertEquals($foo, $engine->escape($foo), '->escape() does nothing on non strings');
  105. }
  106. public function testGetSetCharset()
  107. {
  108. $engine = new ProjectTemplateEngine(self::$loader);
  109. $this->assertEquals('UTF-8', $engine->getCharset(), '->getCharset() returns UTF-8 by default');
  110. $engine->setCharset('ISO-8859-1');
  111. $this->assertEquals('ISO-8859-1', $engine->getCharset(), '->setCharset() changes the default charset to use');
  112. }
  113. }
  114. class ProjectTemplateEngine extends Engine
  115. {
  116. public function getLoader()
  117. {
  118. return $this->loader;
  119. }
  120. public function getRenderers()
  121. {
  122. return $this->renderers;
  123. }
  124. }
  125. class ProjectTemplateRenderer extends PhpRenderer
  126. {
  127. public function getEngine()
  128. {
  129. return $this->engine;
  130. }
  131. }
  132. class ProjectTemplateLoader extends Loader
  133. {
  134. public $templates = array();
  135. public function setTemplate($name, $template)
  136. {
  137. $this->templates[$name] = $template;
  138. }
  139. public function load($template, array $options = array())
  140. {
  141. if (isset($this->templates[$template.'.'.$options['renderer']])) {
  142. return new StringStorage($this->templates[$template.'.'.$options['renderer']]);
  143. }
  144. return false;
  145. }
  146. public function isFresh($template, array $options = array(), $time)
  147. {
  148. return false;
  149. }
  150. }
  151. class FooTemplateRenderer extends Renderer
  152. {
  153. public function evaluate(Storage $template, array $parameters = array())
  154. {
  155. return 'foo';
  156. }
  157. }