diff options
author | Thomas Müller <DeepDiver1975@users.noreply.github.com> | 2016-04-12 12:49:11 +0200 |
---|---|---|
committer | Thomas Müller <DeepDiver1975@users.noreply.github.com> | 2016-04-12 12:49:11 +0200 |
commit | fdee771aca39f394c940edfcaa5a15826b078974 (patch) | |
tree | 400c956152f57c14bdfae094bbd3de265dd7baba | |
parent | 276b8a583112203b9b71e4ac2b372e50ca62df9b (diff) | |
download | nextcloud-server-fdee771aca39f394c940edfcaa5a15826b078974.tar.gz nextcloud-server-fdee771aca39f394c940edfcaa5a15826b078974.zip |
Add unit testing capabilities for templates (#23708)
Add unit testing capabilities for templates
-rw-r--r-- | core/templates/403.php | 2 | ||||
-rw-r--r-- | core/templates/404.php | 3 | ||||
-rw-r--r-- | lib/private/template.php | 8 | ||||
-rw-r--r-- | lib/private/template/base.php | 58 | ||||
-rw-r--r-- | tests/core/templates/templates.php | 20 | ||||
-rw-r--r-- | tests/lib/testcase.php | 68 |
6 files changed, 132 insertions, 27 deletions
diff --git a/core/templates/403.php b/core/templates/403.php index a19009c3546..7d07c72c873 100644 --- a/core/templates/403.php +++ b/core/templates/403.php @@ -1,4 +1,5 @@ <?php +// @codeCoverageIgnoreStart if(!isset($_)) {//also provide standalone error page require_once '../../lib/base.php'; @@ -6,6 +7,7 @@ if(!isset($_)) {//also provide standalone error page $tmpl->printPage(); exit; } +// @codeCoverageIgnoreEnd ?> <ul> <li class='error'> diff --git a/core/templates/404.php b/core/templates/404.php index 2b12b12cff7..a0d2f0160b7 100644 --- a/core/templates/404.php +++ b/core/templates/404.php @@ -1,6 +1,8 @@ <?php /** @var $_ array */ /** @var $l OC_L10N */ +/** @var $theme OC_Theme */ +// @codeCoverageIgnoreStart if(!isset($_)) {//also provide standalone error page require_once '../../lib/base.php'; @@ -8,6 +10,7 @@ if(!isset($_)) {//also provide standalone error page $tmpl->printPage(); exit; } +// @codeCoverageIgnoreEnd ?> <?php if (isset($_['content'])): ?> <?php print_unescaped($_['content']) ?> diff --git a/lib/private/template.php b/lib/private/template.php index d39abdcd378..c6542356fac 100644 --- a/lib/private/template.php +++ b/lib/private/template.php @@ -34,6 +34,8 @@ * */ +use OC\TemplateLayout; + require_once __DIR__.'/template/functions.php'; /** @@ -218,11 +220,11 @@ class OC_Template extends \OC\Template\Base { * This function process the template. If $this->renderAs is set, it * will produce a full page. */ - public function fetchPage() { - $data = parent::fetchPage(); + public function fetchPage($additionalParams = null) { + $data = parent::fetchPage($additionalParams); if( $this->renderAs ) { - $page = new \OC\TemplateLayout($this->renderAs, $this->app); + $page = new TemplateLayout($this->renderAs, $this->app); // Add custom headers $headers = ''; diff --git a/lib/private/template/base.php b/lib/private/template/base.php index d06bcdc4b82..72abc38c36c 100644 --- a/lib/private/template/base.php +++ b/lib/private/template/base.php @@ -29,13 +29,17 @@ namespace OC\Template; class Base { private $template; // The template private $vars; // Vars - private $l10n; // The l10n-Object - private $theme; // theme defaults + + /** @var \OCP\IL10N */ + private $l10n; + + /** @var \OC_Defaults */ + private $theme; /** * @param string $template * @param string $requestToken - * @param \OC_L10N $l10n + * @param \OCP\IL10N $l10n * @param \OC_Defaults $theme */ public function __construct($template, $requestToken, $l10n, $theme ) { @@ -47,34 +51,36 @@ class Base { } /** - * @param string $serverroot + * @param string $serverRoot * @param string|false $app_dir * @param string $theme * @param string $app + * @return array */ - protected function getAppTemplateDirs($theme, $app, $serverroot, $app_dir) { + protected function getAppTemplateDirs($theme, $app, $serverRoot, $app_dir) { // Check if the app is in the app folder or in the root if( file_exists($app_dir.'/templates/' )) { - return array( - $serverroot.'/themes/'.$theme.'/apps/'.$app.'/templates/', + return [ + $serverRoot.'/themes/'.$theme.'/apps/'.$app.'/templates/', $app_dir.'/templates/', - ); + ]; } - return array( - $serverroot.'/themes/'.$theme.'/'.$app.'/templates/', - $serverroot.'/'.$app.'/templates/', - ); + return [ + $serverRoot.'/themes/'.$theme.'/'.$app.'/templates/', + $serverRoot.'/'.$app.'/templates/', + ]; } /** - * @param string $serverroot + * @param string $serverRoot * @param string $theme + * @return array */ - protected function getCoreTemplateDirs($theme, $serverroot) { - return array( - $serverroot.'/themes/'.$theme.'/core/templates/', - $serverroot.'/core/templates/', - ); + protected function getCoreTemplateDirs($theme, $serverRoot) { + return [ + $serverRoot.'/themes/'.$theme.'/core/templates/', + $serverRoot.'/core/templates/', + ]; } /** @@ -131,29 +137,33 @@ class Base { /** * Process the template - * @return string + * + * @param array|null $additionalParams + * @return string This function processes the template. * * This function processes the template. */ - public function fetchPage() { - return $this->load($this->template); + public function fetchPage($additionalParams = null) { + return $this->load($this->template, $additionalParams); } /** * doing the actual work + * * @param string $file + * @param array|null $additionalParams * @return string content * * Includes the template file, fetches its output */ - protected function load( $file, $additionalparams = null ) { + protected function load($file, $additionalParams = null) { // Register the variables $_ = $this->vars; $l = $this->l10n; $theme = $this->theme; - if( !is_null($additionalparams)) { - $_ = array_merge( $additionalparams, $this->vars ); + if( !is_null($additionalParams)) { + $_ = array_merge( $additionalParams, $this->vars ); } // Include diff --git a/tests/core/templates/templates.php b/tests/core/templates/templates.php new file mode 100644 index 00000000000..338d80b276c --- /dev/null +++ b/tests/core/templates/templates.php @@ -0,0 +1,20 @@ +<?php + +namespace Tests\Core\Templates; + +class Templates extends \Test\TestCase { + + public function test403() { + $template = \OC::$SERVERROOT . '/core/templates/403.php'; + $expectedHtml = "<ul><li class='error'>\n\t\tAccess forbidden<br><p class='hint'></p></li></ul>"; + $this->assertTemplate($expectedHtml, $template); + } + + public function test404() { + $template = \OC::$SERVERROOT . '/core/templates/404.php'; + $href = \OC::$server->getURLGenerator()->linkTo('', 'index.php'); + $expectedHtml = "<ul><li class='error'>\n\t\t\tFile not found<br><p class='hint'>The specified document has not been found on the server.</p>\n<p class='hint'><a href='$href'>You can click here to return to ownCloud.</a></p>\n\t\t</li></ul>"; + $this->assertTemplate($expectedHtml, $template); + } + +} diff --git a/tests/lib/testcase.php b/tests/lib/testcase.php index fb0db8cd86c..d7573337f87 100644 --- a/tests/lib/testcase.php +++ b/tests/lib/testcase.php @@ -22,10 +22,15 @@ namespace Test; +use DOMDocument; +use DOMNode; use OC\Command\QueueBus; use OC\Files\Filesystem; +use OC\Template\Base; +use OC_Defaults; use OCP\DB\QueryBuilder\IQueryBuilder; use OCP\IDBConnection; +use OCP\IL10N; use OCP\Security\ISecureRandom; abstract class TestCase extends \PHPUnit_Framework_TestCase { @@ -34,6 +39,8 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase { /** @var IDBConnection */ static protected $realDatabase = null; + + /** @var bool */ static private $wasDatabaseAllowed = false; /** @var array */ @@ -408,4 +415,65 @@ abstract class TestCase extends \PHPUnit_Framework_TestCase { return false; } + + /** + * @param string $expectedHtml + * @param string $template + * @param array $vars + */ + protected function assertTemplate($expectedHtml, $template, $vars = []) { + + require_once __DIR__.'/../../lib/private/template/functions.php'; + + $requestToken = 12345; + $theme = new OC_Defaults(); + /** @var IL10N | \PHPUnit_Framework_MockObject_MockObject $l10n */ + $l10n = $this->getMockBuilder('\OCP\IL10N') + ->disableOriginalConstructor()->getMock(); + $l10n + ->expects($this->any()) + ->method('t') + ->will($this->returnCallback(function($text, $parameters = array()) { + return vsprintf($text, $parameters); + })); + + $t = new Base($template, $requestToken, $l10n, $theme); + $buf = $t->fetchPage($vars); + $this->assertHtmlStringEqualsHtmlString($expectedHtml, $buf); + } + + /** + * @param string $expectedHtml + * @param string $actualHtml + * @param string $message + */ + protected function assertHtmlStringEqualsHtmlString($expectedHtml, $actualHtml, $message = '') { + $expected = new DOMDocument(); + $expected->preserveWhiteSpace = false; + $expected->formatOutput = true; + $expected->loadHTML($expectedHtml); + + $actual = new DOMDocument(); + $actual->preserveWhiteSpace = false; + $actual->formatOutput = true; + $actual->loadHTML($actualHtml); + $this->removeWhitespaces($actual); + + $expectedHtml1 = $expected->saveHTML(); + $actualHtml1 = $actual->saveHTML(); + self::assertEquals($expectedHtml1, $actualHtml1, $message); + } + + + private function removeWhitespaces(DOMNode $domNode) { + foreach ($domNode->childNodes as $node) { + if($node->hasChildNodes()) { + $this->removeWhitespaces($node); + } else { + if ($node instanceof \DOMText && $node->isWhitespaceInElementContent() ) { + $domNode->removeChild($node); + } + } + } + } } |