summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Müller <DeepDiver1975@users.noreply.github.com>2016-04-12 12:49:11 +0200
committerThomas Müller <DeepDiver1975@users.noreply.github.com>2016-04-12 12:49:11 +0200
commitfdee771aca39f394c940edfcaa5a15826b078974 (patch)
tree400c956152f57c14bdfae094bbd3de265dd7baba
parent276b8a583112203b9b71e4ac2b372e50ca62df9b (diff)
downloadnextcloud-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.php2
-rw-r--r--core/templates/404.php3
-rw-r--r--lib/private/template.php8
-rw-r--r--lib/private/template/base.php58
-rw-r--r--tests/core/templates/templates.php20
-rw-r--r--tests/lib/testcase.php68
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);
+ }
+ }
+ }
+ }
}