diff options
Diffstat (limited to 'tests')
25 files changed, 476 insertions, 39 deletions
| diff --git a/tests/dbal/migration/dummy.php b/tests/dbal/migration/dummy.php index 041c529855..b68a3673c1 100644 --- a/tests/dbal/migration/dummy.php +++ b/tests/dbal/migration/dummy.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migration/fail.php b/tests/dbal/migration/fail.php index d90972720d..b0702a469a 100644 --- a/tests/dbal/migration/fail.php +++ b/tests/dbal/migration/fail.php @@ -3,7 +3,7 @@  *  * @package migration  * @copyright (c) 2012 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License v2 +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migration/if.php b/tests/dbal/migration/if.php index bbbda60ea3..883d93c6e4 100644 --- a/tests/dbal/migration/if.php +++ b/tests/dbal/migration/if.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migration/installed.php b/tests/dbal/migration/installed.php index 4b86896d9c..cc4e81aff6 100644 --- a/tests/dbal/migration/installed.php +++ b/tests/dbal/migration/installed.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migration/recall.php b/tests/dbal/migration/recall.php index 041d12ad27..af5e9243cf 100644 --- a/tests/dbal/migration/recall.php +++ b/tests/dbal/migration/recall.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migration/revert.php b/tests/dbal/migration/revert.php index 1882b20492..c2520f4d8a 100644 --- a/tests/dbal/migration/revert.php +++ b/tests/dbal/migration/revert.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migration/revert_with_dependency.php b/tests/dbal/migration/revert_with_dependency.php index 0b09fb784d..ece16eb67c 100644 --- a/tests/dbal/migration/revert_with_dependency.php +++ b/tests/dbal/migration/revert_with_dependency.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migration/schema.php b/tests/dbal/migration/schema.php index 98407eb1bd..efe6891aaa 100644 --- a/tests/dbal/migration/schema.php +++ b/tests/dbal/migration/schema.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2014 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migration/unfulfillable.php b/tests/dbal/migration/unfulfillable.php index a1cdef9a23..125629d27c 100644 --- a/tests/dbal/migration/unfulfillable.php +++ b/tests/dbal/migration/unfulfillable.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migrator_test.php b/tests/dbal/migrator_test.php index f22f5f5b30..c18c49b2a0 100644 --- a/tests/dbal/migrator_test.php +++ b/tests/dbal/migrator_test.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migrator_tool_config_test.php b/tests/dbal/migrator_tool_config_test.php index 807399385c..12644e4a23 100644 --- a/tests/dbal/migrator_tool_config_test.php +++ b/tests/dbal/migrator_tool_config_test.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migrator_tool_module_test.php b/tests/dbal/migrator_tool_module_test.php index 3c23891348..c3358ef944 100644 --- a/tests/dbal/migrator_tool_module_test.php +++ b/tests/dbal/migrator_tool_module_test.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/dbal/migrator_tool_permission_test.php b/tests/dbal/migrator_tool_permission_test.php index 1090b4726a..4016cbcf20 100644 --- a/tests/dbal/migrator_tool_permission_test.php +++ b/tests/dbal/migrator_tool_permission_test.php @@ -3,7 +3,7 @@  *  * @package testing  * @copyright (c) 2011 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  *  */ diff --git a/tests/di/create_container_test.php b/tests/di/create_container_test.php index a3a1ad3597..46d97ba8ba 100644 --- a/tests/di/create_container_test.php +++ b/tests/di/create_container_test.php @@ -59,19 +59,43 @@ namespace phpbb\db\driver  {  	class container_mock extends \phpbb\db\driver\driver  	{ -		public function sql_connect() +		public function sql_connect($sqlserver, $sqluser, $sqlpassword, $database, $port = false, $persistency = false, $new_link = false)  		{  		} -		public function sql_query() +		public function sql_query($query = '', $cache_ttl = 0)  		{  		} -		public function sql_fetchrow() +		public function sql_fetchrow($query_id = false)  		{  		} -		public function sql_freeresult() +		public function sql_freeresult($query_id = false) +		{ +		} + +		function sql_server_info($raw = false, $use_cache = true) +		{ +		} + +		function sql_affectedrows() +		{ +		} + +		function sql_rowseek($rownum, &$query_id) +		{ +		} + +		function sql_nextid() +		{ +		} + +		function sql_escape($msg) +		{ +		} + +		function sql_like_expression($expression)  		{  		}  	} diff --git a/tests/functional/disapprove_test.php b/tests/functional/disapprove_test.php new file mode 100644 index 0000000000..ea594b1062 --- /dev/null +++ b/tests/functional/disapprove_test.php @@ -0,0 +1,319 @@ +<?php +/** +* +* @package testing +* @copyright (c) 2014 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @group functional +*/ +class phpbb_functional_disapprove_test extends phpbb_functional_test_case +{ +	protected $data = array(); + +	public function test_setup_forums() +	{ +		$this->login(); +		$this->admin_login(); + +		$crawler = self::request('GET', "adm/index.php?i=acp_forums&mode=manage&sid={$this->sid}"); +		$form = $crawler->selectButton('addforum')->form(array( +			'forum_name'	=> 'Disapprove Test #1', +		)); +		$crawler = self::submit($form); +		$form = $crawler->selectButton('update')->form(array( +			'forum_perm_from'	=> 2, +		)); +		$crawler = self::submit($form); + +		// Set flood interval to 0 +		$this->set_flood_interval(0); +	} + +	public function test_create_posts() +	{ +		$this->login(); +		$this->load_ids(array( +			'forums' => array( +				'Disapprove Test #1', +			), +		)); + +		$this->assert_forum_details($this->data['forums']['Disapprove Test #1'], array( +			'forum_posts_approved'		=> 0, +			'forum_posts_unapproved'	=> 0, +			'forum_posts_softdeleted'	=> 0, +			'forum_topics_approved'		=> 0, +			'forum_topics_unapproved'	=> 0, +			'forum_topics_softdeleted'	=> 0, +			'forum_last_post_id'		=> 0, +		), 'initial comparison'); + +		// Test creating topic #1 +		$post = $this->create_topic($this->data['forums']['Disapprove Test #1'], 'Disapprove Test Topic #1', 'This is a test topic posted by the testing framework.'); +		$crawler = self::request('GET', "viewtopic.php?t={$post['topic_id']}&sid={$this->sid}"); + +		$this->assertContains('Disapprove Test Topic #1', $crawler->filter('html')->text()); +		$this->data['topics']['Disapprove Test Topic #1'] = (int) $post['topic_id']; +		$this->data['posts']['Disapprove Test Topic #1'] = (int) $this->get_parameter_from_link($crawler->filter('.post')->selectLink($this->lang('POST', '', ''))->link()->getUri(), 'p'); + +		$this->assert_forum_details($this->data['forums']['Disapprove Test #1'], array( +			'forum_posts_approved'		=> 1, +			'forum_posts_unapproved'	=> 0, +			'forum_posts_softdeleted'	=> 0, +			'forum_topics_approved'		=> 1, +			'forum_topics_unapproved'	=> 0, +			'forum_topics_softdeleted'	=> 0, +			'forum_last_post_id'		=> $this->data['posts']['Disapprove Test Topic #1'], +		), 'after creating topic #1'); + +		$this->logout(); +		$this->create_user('disapprove_testuser'); +		$this->add_user_group('NEWLY_REGISTERED', array('disapprove_testuser')); +		$this->login('disapprove_testuser'); + +		// Test creating a reply +		$post2 = $this->create_post($this->data['forums']['Disapprove Test #1'], $post['topic_id'], 'Re: Disapprove Test Topic #1-#2', 'This is a test post posted by the testing framework.', array(), 'POST_STORED_MOD'); + +		$crawler = self::request('GET', "viewtopic.php?t={$this->data['topics']['Disapprove Test Topic #1']}&sid={$this->sid}"); +		$this->assertNotContains('Re: Disapprove Test Topic #1-#2', $crawler->filter('html')->text()); + +		$this->assert_forum_details($this->data['forums']['Disapprove Test #1'], array( +			'forum_posts_approved'		=> 1, +			'forum_posts_unapproved'	=> 1, +			'forum_posts_softdeleted'	=> 0, +			'forum_topics_approved'		=> 1, +			'forum_topics_unapproved'	=> 0, +			'forum_topics_softdeleted'	=> 0, +			'forum_last_post_id'		=> $this->data['posts']['Disapprove Test Topic #1'], +		), 'after replying'); + +		// Test creating topic #2 +		$post = $this->create_topic($this->data['forums']['Disapprove Test #1'], 'Disapprove Test Topic #2', 'This is a test topic posted by the testing framework.', array(), 'POST_STORED_MOD'); +		$crawler = self::request('GET', "viewforum.php?f={$this->data['forums']['Disapprove Test #1']}&sid={$this->sid}"); + +		$this->assertNotContains('Disapprove Test Topic #2', $crawler->filter('html')->text()); + +		$this->assert_forum_details($this->data['forums']['Disapprove Test #1'], array( +			'forum_posts_approved'		=> 1, +			'forum_posts_unapproved'	=> 2, +			'forum_posts_softdeleted'	=> 0, +			'forum_topics_approved'		=> 1, +			'forum_topics_unapproved'	=> 1, +			'forum_topics_softdeleted'	=> 0, +			'forum_last_post_id'		=> $this->data['posts']['Disapprove Test Topic #1'], +		), 'after creating topic #2'); + +		$this->logout(); +	} + +	public function test_reset_flood_interval() +	{ +		$this->login(); +		$this->admin_login(); + +		// Set flood interval back to 15 +		$this->set_flood_interval(15); +	} + +	public function test_disapprove_post() +	{ +		$this->login(); +		$this->load_ids(array( +			'forums' => array( +				'Disapprove Test #1', +			), +			'topics' => array( +				'Disapprove Test Topic #1', +				'Disapprove Test Topic #2', +			), +			'posts' => array( +				'Disapprove Test Topic #1', +				'Re: Disapprove Test Topic #1-#2', +				'Disapprove Test Topic #2', +			), +		)); + +		$this->assert_forum_details($this->data['forums']['Disapprove Test #1'], array( +			'forum_posts_approved'		=> 1, +			'forum_posts_unapproved'	=> 2, +			'forum_posts_softdeleted'	=> 0, +			'forum_topics_approved'		=> 1, +			'forum_topics_unapproved'	=> 1, +			'forum_topics_softdeleted'	=> 0, +			'forum_last_post_id'		=> $this->data['posts']['Disapprove Test Topic #1'], +		), 'before disapproving post'); + +		$this->add_lang('posting'); +		$this->add_lang('viewtopic'); +		$this->add_lang('mcp'); +		$crawler = self::request('GET', "viewtopic.php?t={$this->data['topics']['Disapprove Test Topic #1']}&sid={$this->sid}"); +		$this->assertContains('Disapprove Test Topic #1', $crawler->filter('html')->text()); +		$this->assertContains('Re: Disapprove Test Topic #1-#2', $crawler->filter('html')->text()); + +		$form = $crawler->selectButton($this->lang('DISAPPROVE'))->form(); +		$crawler = self::submit($form); +		$form = $crawler->selectButton($this->lang('YES'))->form(); +		$crawler = self::submit($form); +		$this->assertContainsLang('POST_DISAPPROVED_SUCCESS', $crawler->text()); + +		$this->assert_forum_details($this->data['forums']['Disapprove Test #1'], array( +			'forum_posts_approved'		=> 1, +			'forum_posts_unapproved'	=> 1, +			'forum_posts_softdeleted'	=> 0, +			'forum_topics_approved'		=> 1, +			'forum_topics_unapproved'	=> 1, +			'forum_topics_softdeleted'	=> 0, +			'forum_last_post_id'		=> $this->data['posts']['Disapprove Test Topic #1'], +		), 'after disapproving post'); + +		$link = $crawler->selectLink($this->lang('RETURN_PAGE', '', ''))->link(); +		$link_url = $link->getUri(); +		$this->assertContains('viewtopic.php?f=' . $this->data['forums']['Disapprove Test #1'] . '&t=' . $this->data['topics']['Disapprove Test Topic #1'], $link_url); + +		$crawler = self::request('GET', "viewtopic.php?t={$this->data['topics']['Disapprove Test Topic #1']}&sid={$this->sid}"); +		$this->assertContains('Disapprove Test Topic #1', $crawler->filter('html')->text()); +		$this->assertNotContains('Re: Disapprove Test Topic #1-#2', $crawler->filter('html')->text()); +	} + +	public function test_disapprove_topic() +	{ +		$this->login(); +		$this->load_ids(array( +			'forums' => array( +				'Disapprove Test #1', +			), +			'topics' => array( +				'Disapprove Test Topic #1', +				'Disapprove Test Topic #2', +			), +			'posts' => array( +				'Disapprove Test Topic #1', +				'Disapprove Test Topic #2', +			), +		)); + +		$this->assert_forum_details($this->data['forums']['Disapprove Test #1'], array( +			'forum_posts_approved'		=> 1, +			'forum_posts_unapproved'	=> 1, +			'forum_posts_softdeleted'	=> 0, +			'forum_topics_approved'		=> 1, +			'forum_topics_unapproved'	=> 1, +			'forum_topics_softdeleted'	=> 0, +			'forum_last_post_id'		=> $this->data['posts']['Disapprove Test Topic #1'], +		), 'before disapproving topic'); + +		$this->add_lang('posting'); +		$this->add_lang('viewtopic'); +		$this->add_lang('mcp'); +		$crawler = self::request('GET', "viewtopic.php?t={$this->data['topics']['Disapprove Test Topic #2']}&sid={$this->sid}"); +		$this->assertContains('Disapprove Test Topic #2', $crawler->filter('html')->text()); + +		$form = $crawler->selectButton($this->lang('DISAPPROVE'))->form(); +		$crawler = self::submit($form); +		$form = $crawler->selectButton($this->lang('YES'))->form(); +		$crawler = self::submit($form); +		$this->assertContainsLang('TOPIC_DISAPPROVED_SUCCESS', $crawler->text()); + +		$this->assert_forum_details($this->data['forums']['Disapprove Test #1'], array( +			'forum_posts_approved'		=> 1, +			'forum_posts_unapproved'	=> 0, +			'forum_posts_softdeleted'	=> 0, +			'forum_topics_approved'		=> 1, +			'forum_topics_unapproved'	=> 0, +			'forum_topics_softdeleted'	=> 0, +			'forum_last_post_id'		=> $this->data['posts']['Disapprove Test Topic #1'], +		), 'after disapproving topic'); + +		$link = $crawler->selectLink($this->lang('RETURN_PAGE', '', ''))->link(); +		$link_url = $link->getUri(); +		$this->assertContains('viewforum.php?f=' . $this->data['forums']['Disapprove Test #1'], $link_url); + +		$crawler = self::request('GET', "viewtopic.php?t={$this->data['topics']['Disapprove Test Topic #2']}&sid={$this->sid}", array(), false); +		self::assert_response_html(404); +		$this->assertNotContains('Disapprove Test Topic #2', $crawler->filter('html')->text()); +	} + +	protected function assert_forum_details($forum_id, $details, $additional_error_message = '') +	{ +		$this->db = $this->get_db(); + +		$sql = 'SELECT ' . implode(', ', array_keys($details)) . ' +			FROM phpbb_forums +			WHERE forum_id = ' . (int) $forum_id; +		$result = $this->db->sql_query($sql); +		$data = $this->db->sql_fetchrow($result); +		$this->db->sql_freeresult($result); + +		$this->assertEquals($details, $data, "Forum {$forum_id} does not match expected {$additional_error_message}"); +	} + +	protected function set_flood_interval($flood_interval) +	{ +		$crawler = self::request('GET', 'adm/index.php?sid=' . $this->sid . '&i=acp_board&mode=post'); + +		$form = $crawler->selectButton('Submit')->form(); +		$values = $form->getValues(); + +		$values["config[flood_interval]"] = $flood_interval; +		$form->setValues($values); +		$crawler = self::submit($form); +		$this->assertGreaterThan(0, $crawler->filter('.successbox')->count()); +	} + +	protected function load_ids($data) +	{ +		$this->db = $this->get_db(); + +		if (!empty($data['forums'])) +		{ +			$sql = 'SELECT * +				FROM phpbb_forums +				WHERE ' . $this->db->sql_in_set('forum_name', $data['forums']); +			$result = $this->db->sql_query($sql); +			while ($row = $this->db->sql_fetchrow($result)) +			{ +				if (in_array($row['forum_name'], $data['forums'])) +				{ +					$this->data['forums'][$row['forum_name']] = (int) $row['forum_id']; +				} +			} +			$this->db->sql_freeresult($result); +		} + +		if (!empty($data['topics'])) +		{ +			$sql = 'SELECT * +				FROM phpbb_topics +				WHERE ' . $this->db->sql_in_set('topic_title', $data['topics']); +			$result = $this->db->sql_query($sql); +			while ($row = $this->db->sql_fetchrow($result)) +			{ +				if (in_array($row['topic_title'], $data['topics'])) +				{ +					$this->data['topics'][$row['topic_title']] = (int) $row['topic_id']; +				} +			} +			$this->db->sql_freeresult($result); +		} + +		if (!empty($data['posts'])) +		{ +			$sql = 'SELECT * +				FROM phpbb_posts +				WHERE ' . $this->db->sql_in_set('post_subject', $data['posts']); +			$result = $this->db->sql_query($sql); +			while ($row = $this->db->sql_fetchrow($result)) +			{ +				if (in_array($row['post_subject'], $data['posts'])) +				{ +					$this->data['posts'][$row['post_subject']] = (int) $row['post_id']; +				} +			} +			$this->db->sql_freeresult($result); +		} +	} +} diff --git a/tests/functional/ucp_profile_test.php b/tests/functional/ucp_profile_test.php new file mode 100644 index 0000000000..e0e6255f79 --- /dev/null +++ b/tests/functional/ucp_profile_test.php @@ -0,0 +1,33 @@ +<?php +/** +* +* @package testing +* @copyright (c) 2014 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @group functional +*/ +class phpbb_functional_ucp_profile_test extends phpbb_functional_test_case +{ +	public function test_submitting_profile_info() +	{ +		$this->add_lang('ucp'); +		$this->login(); + +		$crawler = self::request('GET', 'ucp.php?i=ucp_profile&mode=profile_info'); +		$this->assertContainsLang('UCP_PROFILE_PROFILE_INFO', $crawler->filter('#cp-main h2')->text()); + +		$form = $crawler->selectButton('Submit')->form(array( +			'pf_phpbb_location'	=> 'Bertie“s Empire', +		)); +		$crawler = self::submit($form); +		$this->assertContainsLang('PROFILE_UPDATED', $crawler->filter('#message')->text()); + +		$crawler = self::request('GET', 'ucp.php?i=ucp_profile&mode=profile_info'); +		$form = $crawler->selectButton('Submit')->form(); +		$this->assertEquals('Bertie“s Empire', $form->get('pf_phpbb_location')->getValue()); +	} +} diff --git a/tests/functions/parse_cfg_file_test.php b/tests/functions/parse_cfg_file_test.php index 69000ddf72..920fc2eaa7 100644 --- a/tests/functions/parse_cfg_file_test.php +++ b/tests/functions/parse_cfg_file_test.php @@ -21,7 +21,7 @@ class phpbb_functions_parse_cfg_file extends phpbb_test_case  					'#',  					'# @package phpBB3',  					'# @copyright (c) 2005 phpBB Group', -					'# @license http://opensource.org/licenses/gpl-license.php GNU Public License', +					'# @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2',  					'#',  					'#',  					'# At the left is the name, please do not change this', diff --git a/tests/log/function_view_log_test.php b/tests/log/function_view_log_test.php index 017484e8a7..9148d23bb4 100644 --- a/tests/log/function_view_log_test.php +++ b/tests/log/function_view_log_test.php @@ -44,7 +44,7 @@ class phpbb_log_function_view_log_test extends phpbb_database_test_case  				'topic_id'			=> 0,  				'viewforum'			=> '', -				'action'			=> 'installed: 3.1.0-dev', +				'action'			=> 'LOG_INSTALL_INSTALLED 3.1.0-dev',  			),  			2 => array(  				'id'				=> 2, diff --git a/tests/migrator/schema_generator_test.php b/tests/migrator/schema_generator_test.php new file mode 100644 index 0000000000..4bac447229 --- /dev/null +++ b/tests/migrator/schema_generator_test.php @@ -0,0 +1,49 @@ +<?php +/** +* +* @package testing +* @copyright (c) 2014 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +class schmema_generator_test extends phpbb_test_case +{ +	public function setUp() +	{ +		parent::setUp(); + +		$this->config = new \phpbb\config\config(array()); +		$this->db = new \phpbb\db\driver\sqlite(); +		$this->db_tools = new \phpbb\db\tools($this->db); +		$this->table_prefix = 'phpbb_'; +	} + +	protected function get_schema_generator(array $class_names) +	{ +		$this->generator = new \phpbb\db\migration\schema_generator($class_names, $this->config, $this->db, $this->db_tools, $this->phpbb_root_path, $this->php_ext, $this->table_prefix); + +		return $this->generator; +	} + +	/** +	 * @expectedException \UnexpectedValueException +	 */ +	public function test_check_dependencies_fail() +	{ +		$this->get_schema_generator(array('\phpbb\db\migration\data\v310\forgot_password')); + +		$this->generator->get_schema(); +	} + +	public function test_get_schema_success() +	{ +		$this->get_schema_generator(array( +			'\phpbb\db\migration\data\v30x\release_3_0_1_rc1', +			'\phpbb\db\migration\data\v30x\release_3_0_0', +			'\phpbb\db\migration\data\v310\boardindex' +		)); + +		$this->assertArrayHasKey('phpbb_users', $this->generator->get_schema()); +	} +} diff --git a/tests/mock/cache.php b/tests/mock/cache.php index 83bbb8ef30..9e5914b934 100644 --- a/tests/mock/cache.php +++ b/tests/mock/cache.php @@ -140,7 +140,7 @@ class phpbb_mock_cache implements \phpbb\cache\driver\driver_interface  	/**  	* {@inheritDoc}  	*/ -	public function sql_save(\phpbb\db\driver\driver $db, $query, $query_result, $ttl) +	public function sql_save(\phpbb\db\driver\driver_interface $db, $query, $query_result, $ttl)  	{  		return $query_result;  	} diff --git a/tests/mock/user.php b/tests/mock/user.php index bd547b3973..e57e86ae2f 100644 --- a/tests/mock/user.php +++ b/tests/mock/user.php @@ -46,4 +46,9 @@ class phpbb_mock_user  		}  		return false;  	} + +	public function lang() +	{ +		return implode(' ', func_get_args()); +	}  } diff --git a/tests/session/testable_factory.php b/tests/session/testable_factory.php index a58e208efc..c968012edf 100644 --- a/tests/session/testable_factory.php +++ b/tests/session/testable_factory.php @@ -63,10 +63,10 @@ class phpbb_session_testable_factory  	/**  	* Retrieve the configured session class instance  	* -	* @param \phpbb\db\driver\driver $dbal The database connection to use for session data +	* @param \phpbb\db\driver\driver_interface $dbal The database connection to use for session data  	* @return phpbb_mock_session_testable A session instance  	*/ -	public function get_session(\phpbb\db\driver\driver $dbal) +	public function get_session(\phpbb\db\driver\driver_interface $dbal)  	{  		// set up all the global variables used by session  		global $SID, $_SID, $db, $config, $cache, $request, $phpbb_container; diff --git a/tests/test_framework/phpbb_database_test_connection_manager.php b/tests/test_framework/phpbb_database_test_connection_manager.php index 5d8dae4a30..f6429b1ccb 100644 --- a/tests/test_framework/phpbb_database_test_connection_manager.php +++ b/tests/test_framework/phpbb_database_test_connection_manager.php @@ -321,7 +321,7 @@ class phpbb_database_test_connection_manager  	* Compile the correct schema filename (as per create_schema_files) and  	* load it into the database.  	*/ -	protected function load_schema_from_file($directory, \phpbb\db\driver\driver $db) +	protected function load_schema_from_file($directory, \phpbb\db\driver\driver_interface $db)  	{  		$schema = $this->dbms['SCHEMA']; diff --git a/tests/test_framework/phpbb_functional_test_case.php b/tests/test_framework/phpbb_functional_test_case.php index c0e58d1104..daa8b802b5 100644 --- a/tests/test_framework/phpbb_functional_test_case.php +++ b/tests/test_framework/phpbb_functional_test_case.php @@ -150,7 +150,7 @@ class phpbb_functional_test_case extends phpbb_test_case  	{  		global $phpbb_root_path, $phpEx;  		// so we don't reopen an open connection -		if (!($this->db instanceof \phpbb\db\driver\driver)) +		if (!($this->db instanceof \phpbb\db\driver\driver_interface))  		{  			$dbms = self::$config['dbms'];  			$this->db = new $dbms(); diff --git a/tests/wrapper/gmgetdate_test.php b/tests/wrapper/gmgetdate_test.php index a838cfdba9..2f6c74b434 100644 --- a/tests/wrapper/gmgetdate_test.php +++ b/tests/wrapper/gmgetdate_test.php @@ -11,26 +11,28 @@ require_once dirname(__FILE__) . '/../../phpBB/includes/functions.php';  class phpbb_wrapper_gmgetdate_test extends phpbb_test_case  { -	public function test_gmgetdate() +	public static function phpbb_gmgetdate_data()  	{ -		$this->run_gmgetdate_assertion(); -		$this->run_test_with_timezone('UTC'); -		$this->run_test_with_timezone('Europe/Berlin'); -		$this->run_test_with_timezone('America/Los_Angeles'); -		$this->run_test_with_timezone('Antarctica/South_Pole'); +		return array( +			array(''), +			array('UTC'), +			array('Europe/Berlin'), +			array('America/Los_Angeles'), +			array('Antarctica/South_Pole'), +		);  	} -	protected function run_test_with_timezone($timezone_identifier) +	/** +	 * @dataProvider phpbb_gmgetdate_data +	 */ +	public function test_phpbb_gmgetdate($timezone_identifier)  	{ -		$current_timezone = date_default_timezone_get(); - -		date_default_timezone_set($timezone_identifier); -		$this->run_gmgetdate_assertion(); -		date_default_timezone_set($current_timezone); -	} +		if ($timezone_identifier) +		{ +			$current_timezone = date_default_timezone_get(); +			date_default_timezone_set($timezone_identifier); +		} -	protected function run_gmgetdate_assertion() -	{  		$expected = time();  		$date_array = phpbb_gmgetdate($expected); @@ -45,5 +47,10 @@ class phpbb_wrapper_gmgetdate_test extends phpbb_test_case  		);  		$this->assertEquals($expected, $actual); + +		if (isset($current_timezone)) +		{ +			date_default_timezone_set($current_timezone); +		}  	}  } | 
