diff options
| -rw-r--r-- | phpBB/viewtopic.php | 9 | ||||
| -rw-r--r-- | tests/functional/forum_style_test.php | 51 | ||||
| -rw-r--r-- | tests/test_framework/phpbb_functional_test_case.php | 103 | 
3 files changed, 162 insertions, 1 deletions
| diff --git a/phpBB/viewtopic.php b/phpBB/viewtopic.php index 74420a25c7..fb12dd925a 100644 --- a/phpBB/viewtopic.php +++ b/phpBB/viewtopic.php @@ -146,7 +146,14 @@ if ($view && !$post_id)  			if (!$row)  			{ -				$user->setup('viewtopic'); +				$sql = 'SELECT forum_style +					FROM ' . FORUMS_TABLE . " +					WHERE forum_id = $forum_id"; +				$result = $db->sql_query($sql); +				$forum_style = (int) $db->sql_fetchfield('forum_style'); +				$db->sql_freeresult($result); + +				$user->setup('viewtopic', $forum_style);  				trigger_error(($view == 'next') ? 'NO_NEWER_TOPICS' : 'NO_OLDER_TOPICS');  			}  			else diff --git a/tests/functional/forum_style_test.php b/tests/functional/forum_style_test.php new file mode 100644 index 0000000000..5d95538f68 --- /dev/null +++ b/tests/functional/forum_style_test.php @@ -0,0 +1,51 @@ +<?php +/** +* +* @package testing +* @copyright (c) 2013 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @group functional +*/ +class phpbb_functional_forum_style_test extends phpbb_functional_test_case +{ +	public function test_default_forum_style() +	{ +		$crawler = $this->request('GET', 'viewtopic.php?t=1&f=2'); +		$this->assert_response_success(); +		$this->assertContains('styles/prosilver/', $crawler->filter('head > link[rel=stylesheet]')->attr('href')); + +		$crawler = $this->request('GET', 'viewtopic.php?t=1'); +		$this->assert_response_success(); +		$this->assertContains('styles/prosilver/', $crawler->filter('head > link[rel=stylesheet]')->attr('href')); + +		$crawler = $this->request('GET', 'viewtopic.php?t=1&view=next'); +		$this->assert_response_success(); +		$this->assertContains('styles/prosilver/', $crawler->filter('head > link[rel=stylesheet]')->attr('href')); +	} + +	public function test_custom_forum_style() +	{ +		$db = $this->get_db(); +		$this->add_style(2, 'test_style'); +		$db->sql_query('UPDATE ' . FORUMS_TABLE . ' SET forum_style = 2 WHERE forum_id = 2'); + +		$crawler = $this->request('GET', 'viewtopic.php?t=1&f=2'); +		$this->assert_response_success(); +		$this->assertContains('styles/test_style/', $crawler->filter('head > link[rel=stylesheet]')->attr('href')); + +		$crawler = $this->request('GET', 'viewtopic.php?t=1'); +		$this->assert_response_success(); +		$this->assertContains('styles/test_style/', $crawler->filter('head > link[rel=stylesheet]')->attr('href')); + +		$crawler = $this->request('GET', 'viewtopic.php?t=1&view=next'); +		$this->assert_response_success(); +		$this->assertContains('styles/test_style/', $crawler->filter('head > link[rel=stylesheet]')->attr('href')); + +		$db->sql_query('UPDATE ' . FORUMS_TABLE . ' SET forum_style = 0 WHERE forum_id = 2'); +		$this->delete_style(2, 'test_style'); +	} +} diff --git a/tests/test_framework/phpbb_functional_test_case.php b/tests/test_framework/phpbb_functional_test_case.php index 6b423b56fd..4b08a1af72 100644 --- a/tests/test_framework/phpbb_functional_test_case.php +++ b/tests/test_framework/phpbb_functional_test_case.php @@ -324,6 +324,109 @@ class phpbb_functional_test_case extends phpbb_test_case  	}  	/** +	* Creates a new style +	* +	* @param string $style_id Style ID +	* @param string $style_path Style directory +	* @param string $parent_style_id Parent style id. Default = 1 +	* @param string $parent_style_path Parent style directory. Default = 'prosilver' +	*/ +	protected function add_style($style_id, $style_path, $parent_style_id = 1, $parent_style_path = 'prosilver') +	{ +		global $phpbb_root_path; + +		$db = $this->get_db(); +		if (version_compare(PHPBB_VERSION, '3.1.0-dev', '<')) +		{ +			$sql = 'INSERT INTO ' . STYLES_TABLE . ' ' . $db->sql_build_array('INSERT', array( +				'style_id' => $style_id, +				'style_name' => $style_path, +				'style_copyright' => '', +				'style_active' => 1, +				'template_id' => $style_id, +				'theme_id' => $style_id, +				'imageset_id' => $style_id, +			)); +			$db->sql_query($sql); + +			$sql = 'INSERT INTO ' . STYLES_IMAGESET_TABLE . ' ' . $db->sql_build_array('INSERT', array( +				'imageset_id' => $style_id, +				'imageset_name' => $style_path, +				'imageset_copyright' => '', +				'imageset_path' => $style_path, +			)); +			$db->sql_query($sql); + +			$sql = 'INSERT INTO ' . STYLES_TEMPLATE_TABLE . ' ' . $db->sql_build_array('INSERT', array( +				'template_id' => $style_id, +				'template_name' => $style_path, +				'template_copyright' => '', +				'template_path' => $style_path, +				'bbcode_bitfield' => 'kNg=', +				'template_inherits_id' => $parent_style_id, +				'template_inherit_path' => $parent_style_path, +			)); +			$db->sql_query($sql); + +			$sql = 'INSERT INTO ' . STYLES_THEME_TABLE . ' ' . $db->sql_build_array('INSERT', array( +				'theme_id' => $style_id, +				'theme_name' => $style_path, +				'theme_copyright' => '', +				'theme_path' => $style_path, +				'theme_storedb' => 0, +				'theme_mtime' => 0, +				'theme_data' => '', +			)); +			$db->sql_query($sql); + +			if ($style_path != 'prosilver' && $style_path != 'subsilver2') +			{ +				@mkdir($phpbb_root_path . 'styles/' . $style_path, 0777); +				@mkdir($phpbb_root_path . 'styles/' . $style_path . '/template', 0777); +			} +		} +		else +		{ +			$db->sql_multi_insert(STYLES_TABLE, array( +				'style_id' => $style_id, +				'style_name' => $style_path, +				'style_copyright' => '', +				'style_active' => 1, +				'style_path' => $style_path, +				'bbcode_bitfield' => 'kNg=', +				'style_parent_id' => $parent_style_id, +				'style_parent_tree' => $parent_style_path, +			)); +		} +	} + +	/** +	* Remove temporary style created by add_style() +	* +	* @param string $style_id Style ID +	* @param string $style_path Style directory +	*/ +	protected function delete_style($style_id, $style_path) +	{ +		global $phpbb_root_path; + +		$db = $this->get_db(); +		$db->sql_query('DELETE FROM ' . STYLES_TABLE . ' WHERE style_id = ' . $style_id); +		if (version_compare(PHPBB_VERSION, '3.1.0-dev', '<')) +		{ +			$db->sql_query('DELETE FROM ' . STYLES_IMAGESET_TABLE . ' WHERE imageset_id = ' . $style_id); +			$db->sql_query('DELETE FROM ' . STYLES_TEMPLATE_TABLE . ' WHERE template_id = ' . $style_id); +			$db->sql_query('DELETE FROM ' . STYLES_THEME_TABLE . ' WHERE theme_id = ' . $style_id); + +			if ($style_path != 'prosilver' && $style_path != 'subsilver2') +			{ +				@rmdir($phpbb_root_path . 'styles/' . $style_path . '/template'); +				@rmdir($phpbb_root_path . 'styles/' . $style_path); +			} +		} +	} + +	/**  	* Creates a new user with limited permissions  	*  	* @param string $username Also doubles up as the user's password | 
