mirror of
https://github.com/phpbb/phpbb.git
synced 2025-06-28 22:28:51 +00:00
[ticket/10733] Adding test for locator
Adding test for $template->locate PHPBB3-10733
This commit is contained in:
parent
f80512f106
commit
2509853ca5
1 changed files with 84 additions and 0 deletions
84
tests/template/template_locate_test.php
Normal file
84
tests/template/template_locate_test.php
Normal file
|
@ -0,0 +1,84 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package testing
|
||||||
|
* @copyright (c) 2011 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/template_test_case.php';
|
||||||
|
|
||||||
|
class phpbb_template_template_locate_test extends phpbb_template_template_test_case
|
||||||
|
{
|
||||||
|
public static function template_data()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
// First element of the array is test name - keep them distinct
|
||||||
|
array(
|
||||||
|
'simple inheritance - only parent template exists',
|
||||||
|
'parent_only.html',
|
||||||
|
false,
|
||||||
|
true,
|
||||||
|
dirname(__FILE__) . '/parent_templates/parent_only.html',
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'simple inheritance - only child template exists',
|
||||||
|
'child_only.html',
|
||||||
|
false,
|
||||||
|
true,
|
||||||
|
dirname(__FILE__) . '/templates/child_only.html',
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'simple inheritance - both parent and child templates exist',
|
||||||
|
'parent_and_child.html',
|
||||||
|
false,
|
||||||
|
true,
|
||||||
|
dirname(__FILE__) . '/templates/parent_and_child.html',
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'find first template - only child template exists in main style',
|
||||||
|
array('parent_only.html', 'child_only.html'),
|
||||||
|
false,
|
||||||
|
false,
|
||||||
|
'child_only.html',
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'find first template - both templates exist in main style',
|
||||||
|
array('parent_and_child.html', 'child_only.html'),
|
||||||
|
false,
|
||||||
|
false,
|
||||||
|
'parent_and_child.html',
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider template_data
|
||||||
|
*/
|
||||||
|
public function test_template($name, $files, $return_default, $return_full_path, $expected)
|
||||||
|
{
|
||||||
|
// Reset the engine state
|
||||||
|
$this->setup_engine();
|
||||||
|
|
||||||
|
// Locate template
|
||||||
|
$result = $this->template->locate($files, $return_default, $return_full_path);
|
||||||
|
$this->assertEquals($result, $expected);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function setup_engine(array $new_config = array())
|
||||||
|
{
|
||||||
|
global $phpbb_root_path, $phpEx, $user;
|
||||||
|
|
||||||
|
$defaults = $this->config_defaults();
|
||||||
|
$config = new phpbb_config(array_merge($defaults, $new_config));
|
||||||
|
|
||||||
|
$this->template_path = dirname(__FILE__) . '/templates';
|
||||||
|
$this->parent_template_path = dirname(__FILE__) . '/parent_templates';
|
||||||
|
$this->style_resource_locator = new phpbb_style_resource_locator();
|
||||||
|
$this->style_provider = new phpbb_style_path_provider();
|
||||||
|
$this->template = new phpbb_style_template($phpbb_root_path, $phpEx, $config, $user, $this->style_resource_locator, $this->style_provider);
|
||||||
|
$this->style = new phpbb_style($phpbb_root_path, $phpEx, $config, $user, $this->style_resource_locator, $this->style_provider, $this->template);
|
||||||
|
$this->style->set_custom_style('tests', array($this->template_path, $this->parent_template_path), '');
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue