diff options
Diffstat (limited to 'tests')
50 files changed, 1043 insertions, 104 deletions
| diff --git a/tests/bbcode/parser_test.php b/tests/bbcode/parser_test.php index 5677e49636..4e85737c4f 100644 --- a/tests/bbcode/parser_test.php +++ b/tests/bbcode/parser_test.php @@ -66,11 +66,6 @@ class phpbb_bbcode_parser_test extends \phpbb_test_case  				'[code:]unparsed code[/code:]',  			),  			array( -				'Test default bbcodes: simple php code', -				'[code=php]unparsed code[/code]', -				'[code=php:]<span class="syntaxdefault">unparsed code</span>[/code:]', -			), -			array(  				'Test default bbcodes: simple list',  				'[list]no item[/list]',  				'[list:]no item[/list:u:]', diff --git a/tests/console/cron/cron_list_test.php b/tests/console/cron/cron_list_test.php index 3bbe2078ba..fdc9a05cb2 100644 --- a/tests/console/cron/cron_list_test.php +++ b/tests/console/cron/cron_list_test.php @@ -50,19 +50,19 @@ class phpbb_console_command_cron_list_test extends phpbb_test_case  	public function test_only_ready()  	{  		$this->initiate_test(2, 0); -		$this->assertContains('TASKS_READY command1 command2', preg_replace('/\s+/', ' ', trim($this->command_tester->getDisplay()))); +		$this->assertContains('TASKS_READY command1 command2', preg_replace('/[\s*=]+/', ' ', trim($this->command_tester->getDisplay())));  	}  	public function test_only_not_ready()  	{  		$this->initiate_test(0, 2); -		$this->assertContains('TASKS_NOT_READY command1 command2', preg_replace('/\s+/', ' ', trim($this->command_tester->getDisplay()))); +		$this->assertContains('TASKS_NOT_READY command1 command2', preg_replace('/[\s*=]+/', ' ', trim($this->command_tester->getDisplay())));  	}  	public function test_both_ready()  	{  		$this->initiate_test(2, 2); -		$this->assertSame('TASKS_READY command1 command2 TASKS_NOT_READY command3 command4', preg_replace('/\s+/', ' ', trim($this->command_tester->getDisplay()))); +		$this->assertSame('TASKS_READY command1 command2 TASKS_NOT_READY command3 command4', preg_replace('/[\s*=]+/', ' ', trim($this->command_tester->getDisplay())));  	}  	public function get_cron_manager(array $tasks) diff --git a/tests/console/update/check_test.php b/tests/console/update/check_test.php new file mode 100644 index 0000000000..5cadc5cc97 --- /dev/null +++ b/tests/console/update/check_test.php @@ -0,0 +1,110 @@ +<?php +/** +* +* This file is part of the phpBB Forum Software package. +* +* @copyright (c) phpBB Limited <https://www.phpbb.com> +* @license GNU General Public License, version 2 (GPL-2.0) +* +* For full copyright and license information, please see +* the docs/CREDITS.txt file. +* +*/ + +use Symfony\Component\Console\Application; +use Symfony\Component\Console\Tester\CommandTester; +use phpbb\console\command\update\check; + +require_once dirname(__FILE__) . '/../../../phpBB/includes/functions_admin.php'; +require_once dirname(__FILE__) . '/../../../phpBB/includes/functions.php'; +require_once dirname(__FILE__) . '/../../../phpBB/includes/utf/utf_tools.php'; + +/** +* @slow +*/ +class phpbb_console_command_check_test extends phpbb_test_case +{ +	protected $command_name; + +	protected $version_helper; + +	/** @var \phpbb\language\language */ +	protected $language; + +	public function test_up_to_date() +	{ +		$command_tester = $this->get_command_tester('100000'); +		$status = $command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true)); +		$this->assertSame('', $command_tester->getDisplay()); +		$this->assertSame($status, 0); +	} + +	public function test_up_to_date_verbose() +	{ +		$command_tester = $this->get_command_tester('100000'); +		$status = $command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true, '--verbose' => true)); +		$this->assertContains($this->language->lang('UPDATE_NOT_NEEDED'), $command_tester->getDisplay()); +		$this->assertSame($status, 0); +	} + + +	public function test_not_up_to_date() +	{ +		$command_tester = $this->get_command_tester('0'); +		$status = $command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true)); +		$this->assertContains($this->language->lang('UPDATE_NEEDED'), $command_tester->getDisplay()); +		$this->assertSame($status, 1); +	} + +	public function test_not_up_to_date_verbose() +	{ +		$command_tester = $this->get_command_tester('0'); +		$status = $command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true, '--verbose' => true)); +		$this->assertContains($this->language->lang('UPDATE_NEEDED'), $command_tester->getDisplay()); +		$this->assertContains($this->language->lang('UPDATES_AVAILABLE'), $command_tester->getDisplay()); +		$this->assertSame($status, 1); +	} + +	/** +	 * @expectedException phpbb\exception\runtime_exception +	 */ +	public function test_error() +	{ +		$command_tester = $this->get_command_tester('1'); +		$this->version_helper->set_file_location('acme.corp','foo', 'bar.json'); + +		$status = $command_tester->execute(array('command' => $this->command_name, '--no-ansi' => true)); +		$this->assertContains('VERSIONCHECK_FAIL', $command_tester->getDisplay()); +		$this->assertSame($status, 2); +	} + +	public function get_command_tester($current_version) +	{ +		global $user, $phpbb_root_path, $phpEx; + +		$this->language = new \phpbb\language\language(new \phpbb\language\language_file_loader($phpbb_root_path, $phpEx)); + +		$user = $this->getMock('\phpbb\user', array(), array( +			$this->language, +			'\phpbb\datetime' +		)); +		$user->method('lang')->will($this->returnArgument(0)); + +		$cache = $this->getMockBuilder('\phpbb\cache\service') +			->disableOriginalConstructor() +			->getMock(); + +		$config = new \phpbb\config\config(array('version' => $current_version)); +		$this->version_helper = new \phpbb\version_helper($cache, $config, new \phpbb\file_downloader()); + +		$container = new phpbb_mock_container_builder; +		$container->set('version_helper', $this->version_helper); + +		$application = new Application(); +		$application->add(new check($user, $config, $container, $this->language)); + +		$command = $application->find('update:check'); +		$this->command_name = $command->getName(); +		return new CommandTester($command); +	} +} diff --git a/tests/di/create_container_test.php b/tests/di/create_container_test.php index aba7a3560b..1fd2cbd7ee 100644 --- a/tests/di/create_container_test.php +++ b/tests/di/create_container_test.php @@ -46,6 +46,7 @@ namespace  		{  			$container = $this->builder->get_container();  			$this->assertInstanceOf('Symfony\Component\DependencyInjection\ContainerBuilder', $container); +			$this->assertFalse($container->hasParameter('container_exception'));  			// Checks the core services  			$this->assertTrue($container->hasParameter('core')); @@ -54,7 +55,7 @@ namespace  			$this->assertTrue($container->isFrozen());  			// Checks inject_config -			$this->assertTrue($container->hasParameter('dbal.dbhost')); +			$this->assertTrue($container->hasParameter('core.table_prefix'));  			// Checks use_extensions  			$this->assertTrue($container->hasParameter('enabled')); diff --git a/tests/di/fixtures/config/production/container/environment.yml b/tests/di/fixtures/config/production/container/environment.yml index 4216b187cc..8281d9e941 100644 --- a/tests/di/fixtures/config/production/container/environment.yml +++ b/tests/di/fixtures/config/production/container/environment.yml @@ -10,6 +10,9 @@ services:          arguments:              - '@service_container' +    dbal.conn.driver: +        synthetic: true +      dispatcher:          class: phpbb\db\driver\container_mock diff --git a/tests/di/fixtures/config/test/container/environment.yml b/tests/di/fixtures/config/test/container/environment.yml index 7d528fed19..252117dd32 100644 --- a/tests/di/fixtures/config/test/container/environment.yml +++ b/tests/di/fixtures/config/test/container/environment.yml @@ -10,6 +10,9 @@ services:          arguments:              - '@service_container' +    dbal.conn.driver: +        synthetic: true +      dispatcher:          class: phpbb\db\driver\container_mock diff --git a/tests/di/fixtures/other_config/production/container/environment.yml b/tests/di/fixtures/other_config/production/container/environment.yml index 1170145b66..c0d2f87bab 100644 --- a/tests/di/fixtures/other_config/production/container/environment.yml +++ b/tests/di/fixtures/other_config/production/container/environment.yml @@ -10,6 +10,9 @@ services:          arguments:              - '@service_container' +    dbal.conn.driver: +        synthetic: true +      dispatcher:          class: phpbb\db\driver\container_mock diff --git a/tests/di/fixtures/other_config/test/container/environment.yml b/tests/di/fixtures/other_config/test/container/environment.yml index 6c36977d4d..b9f6d05018 100644 --- a/tests/di/fixtures/other_config/test/container/environment.yml +++ b/tests/di/fixtures/other_config/test/container/environment.yml @@ -10,6 +10,9 @@ services:          arguments:              - '@service_container' +    dbal.conn.driver: +        synthetic: true +      dispatcher:          class: phpbb\db\driver\container_mock diff --git a/tests/event/fixtures/trigger_many_vars.test b/tests/event/fixtures/trigger_many_vars.test index a624138588..5e0720d13b 100644 --- a/tests/event/fixtures/trigger_many_vars.test +++ b/tests/event/fixtures/trigger_many_vars.test @@ -34,7 +34,7 @@  	*				posting page via $template->assign_vars()  	* @var	object	message_parser	The message parser object  	* @since 3.1.0-a1 -	* @change 3.1.0-b3 Added vars post_data, moderators, mode, page_title, +	* @changed 3.1.0-b3 Added vars post_data, moderators, mode, page_title,  	*		s_topic_icons, form_enctype, s_action, s_hidden_fields,  	*		post_id, topic_id, forum_id, submit, preview, save, load,  	*		delete, cancel, refresh, error, page_data, message_parser diff --git a/tests/extension/manager_test.php b/tests/extension/manager_test.php index a24b0cf178..f619d4c19d 100644 --- a/tests/extension/manager_test.php +++ b/tests/extension/manager_test.php @@ -180,7 +180,7 @@ class phpbb_extension_manager_test extends phpbb_database_test_case  			'phpbb_ext',  			dirname(__FILE__) . '/',  			$php_ext, -			($with_cache) ? new phpbb_mock_cache() : null +			($with_cache) ? new \phpbb\cache\service(new phpbb_mock_cache(), $config, $db, $phpbb_root_path, $php_ext) : null  		);  	}  } diff --git a/tests/extension/metadata_manager_test.php b/tests/extension/metadata_manager_test.php index 19b99ee0ce..ce675f0d36 100644 --- a/tests/extension/metadata_manager_test.php +++ b/tests/extension/metadata_manager_test.php @@ -36,7 +36,6 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case  	{  		parent::setUp(); -		$this->cache = new phpbb_mock_cache();  		$this->config = new \phpbb\config\config(array(  			'version'		=> '3.1.0',  		)); @@ -45,6 +44,9 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case  		$this->db_tools = $factory->get($this->db);  		$this->phpbb_root_path = dirname(__FILE__) . '/';  		$this->phpEx = 'php'; + +		$this->cache =  new \phpbb\cache\service(new phpbb_mock_cache(), $this->config, $this->db, $this->phpbb_root_path, $this->phpEx); +  		$this->table_prefix = 'phpbb_';  		$container = new phpbb_mock_container_builder(); @@ -364,7 +366,6 @@ class phpbb_extension_metadata_manager_test extends phpbb_database_test_case  			$ext_name,  			$this->config,  			$this->extension_manager, -			$this->template,  			$this->phpbb_root_path  		);  	} diff --git a/tests/feed/attachments_base_test.php b/tests/feed/attachments_base_test.php new file mode 100644 index 0000000000..dd432d13f5 --- /dev/null +++ b/tests/feed/attachments_base_test.php @@ -0,0 +1,99 @@ +<?php +/** + * + * This file is part of the phpBB Forum Software package. + * + * @copyright (c) phpBB Limited <https://www.phpbb.com> + * @license GNU General Public License, version 2 (GPL-2.0) + * + * For full copyright and license information, please see + * the docs/CREDITS.txt file. + * + */ + +require_once(dirname(__FILE__) . '/attachments_mock_feed.php'); + +class phpbb_feed_attachments_base_test extends phpbb_database_test_case +{ +	protected $filesystem; + +	/** @var \phpbb_feed_attachments_mock_feed */ +	protected $attachments_mocks_feed; + +	public function getDataSet() +	{ +		return $this->createXMLDataSet(dirname(__FILE__) . '/../extension/fixtures/extensions.xml'); +	} + +	public function setUp() +	{ +		global $phpbb_root_path, $phpEx; + +		$this->filesystem = new \phpbb\filesystem(); +		$config = new \phpbb\config\config(array()); +		$user = new \phpbb\user( +			new \phpbb\language\language( +				new \phpbb\language\language_file_loader($phpbb_root_path, $phpEx) +			), +			'\phpbb\datetime' +		); +		$feed_helper = new \phpbb\feed\helper($config, $user, $phpbb_root_path, $phpEx); +		$db = $this->new_dbal(); +		$cache = new \phpbb_mock_cache(); +		$auth = new \phpbb\auth\auth(); +		$content_visibility = new \phpbb\content_visibility( +			$auth, +			$config, +			new \phpbb_mock_event_dispatcher(), +			$db, +			$user, +			$phpbb_root_path, +			$phpEx, +			FORUMS_TABLE, +			POSTS_TABLE, +			TOPICS_TABLE, +			USERS_TABLE +		); + +		$this->attachments_mocks_feed = new \phpbb_feed_attachments_mock_feed( +			$feed_helper, +			$config, +			$db, +			$cache, +			$user, +			$auth, +			$content_visibility, +			new \phpbb_mock_event_dispatcher(), +			$phpEx +		); +	} + +	public function data_fetch_attachments() +	{ +		return array( +			array(array(0), array(0)), +			array(array(), array(1)), +			array(array(), array(), 'RuntimeException') +		); +	} + +	/** +	 * @dataProvider data_fetch_attachments +	 */ +	public function test_fetch_attachments($post_ids, $topic_ids, $expected_exception = false) +	{ +		$this->attachments_mocks_feed->post_ids = $post_ids; +		$this->attachments_mocks_feed->topic_ids = $topic_ids; + +		if ($expected_exception !== false) +		{ +			$this->setExpectedException($expected_exception); + +			$this->attachments_mocks_feed->get_sql(); +		} +		else +		{ +			$this->assertTrue($this->attachments_mocks_feed->get_sql()); +		} +	} +} diff --git a/tests/feed/attachments_mock_feed.php b/tests/feed/attachments_mock_feed.php new file mode 100644 index 0000000000..fb67a48f7c --- /dev/null +++ b/tests/feed/attachments_mock_feed.php @@ -0,0 +1,36 @@ +<?php +/** + * + * This file is part of the phpBB Forum Software package. + * + * @copyright (c) phpBB Limited <https://www.phpbb.com> + * @license GNU General Public License, version 2 (GPL-2.0) + * + * For full copyright and license information, please see + * the docs/CREDITS.txt file. + * + */ + +/** + * Board wide feed (aka overall feed) + * + * This will give you the newest {$this->num_items} posts + * from the whole board. + */ +class phpbb_feed_attachments_mock_feed extends \phpbb\feed\attachments_base +{ +	public $topic_ids = array(); +	public $post_ids = array(); + +	function get_sql() +	{ +		parent::fetch_attachments($this->post_ids, $this->topic_ids); + +		return true; +	} + +	public function adjust_item(&$item_row, &$row) +	{ +		return array(); +	} +} diff --git a/tests/files/types_remote_test.php b/tests/files/types_remote_test.php index d103771c04..1a7d63d790 100644 --- a/tests/files/types_remote_test.php +++ b/tests/files/types_remote_test.php @@ -84,16 +84,16 @@ class phpbb_files_types_remote_test extends phpbb_test_case  	public function data_get_max_file_size()  	{  		return array( -			array('', 'http://example.com/foo/bar.png'), -			array('2k', 'http://example.com/foo/bar.png'), -			array('500k', 'http://example.com/foo/bar.png'), -			array('500M', 'http://example.com/foo/bar.png'), -			array('500m', 'http://example.com/foo/bar.png'), +			array('', 'http://phpbb.com/foo/bar.png'), +			array('2k', 'http://phpbb.com/foo/bar.png'), +			array('500k', 'http://phpbb.com/foo/bar.png'), +			array('500M', 'http://phpbb.com/foo/bar.png'), +			array('500m', 'http://phpbb.com/foo/bar.png'),  			array('500k', 'http://google.com/?.png', array('DISALLOWED_EXTENSION', 'DISALLOWED_CONTENT')),  			array('1', 'http://google.com/?.png', array('WRONG_FILESIZE')), -			array('500g', 'http://example.com/foo/bar.png'), -			array('foobar', 'http://example.com/foo/bar.png'), -			array('-5k', 'http://example.com/foo/bar.png'), +			array('500g', 'http://phpbb.com/foo/bar.png'), +			array('foobar', 'http://phpbb.com/foo/bar.png'), +			array('-5k', 'http://phpbb.com/foo/bar.png'),  		);  	} diff --git a/tests/functional/acp_bbcodes_test.php b/tests/functional/acp_bbcodes_test.php new file mode 100644 index 0000000000..58681dfa07 --- /dev/null +++ b/tests/functional/acp_bbcodes_test.php @@ -0,0 +1,46 @@ +<?php +/** + * + * This file is part of the phpBB Forum Software package. + * + * @copyright (c) phpBB Limited <https://www.phpbb.com> + * @license GNU General Public License, version 2 (GPL-2.0) + * + * For full copyright and license information, please see + * the docs/CREDITS.txt file. + * + */ + +/** + * @group functional + */ +class phpbb_functional_acp_bbcodes_test extends phpbb_functional_test_case +{ +	public function test_htmlspecialchars() +	{ +		$this->login(); +		$this->admin_login(); + +		// Create the BBCode +		$crawler = self::request('GET', 'adm/index.php?i=acp_bbcodes&sid=' . $this->sid . '&mode=bbcodes&action=add'); +		$form = $crawler->selectButton('Submit')->form(array( +			'bbcode_match' => '[mod="{TEXT1}"]{TEXT2}[/mod]', +			'bbcode_tpl'   => '<div>{TEXT1}</div><div>{TEXT2}</div>' +		)); +		self::submit($form); + +		// Test it in the "new topic" preview +		$crawler = self::request('GET', 'posting.php?mode=post&f=2&sid=' . $this->sid); +		$form = $crawler->selectButton('Preview')->form(array( +			'subject' => 'subject', +			'message' => '[mod=a]b[/mod][mod="c"]d[/mod]' +		)); +		$crawler = self::submit($form); + +		$html = $crawler->filter('#preview')->html(); +		$this->assertContains('<div>a</div>', $html); +		$this->assertContains('<div>b</div>', $html); +		$this->assertContains('<div>c</div>', $html); +		$this->assertContains('<div>d</div>', $html); +	} +} diff --git a/tests/functional/acp_smilies_test.php b/tests/functional/acp_smilies_test.php new file mode 100644 index 0000000000..ebe8717fa7 --- /dev/null +++ b/tests/functional/acp_smilies_test.php @@ -0,0 +1,43 @@ +<?php +/** + * + * This file is part of the phpBB Forum Software package. + * + * @copyright (c) phpBB Limited <https://www.phpbb.com> + * @license GNU General Public License, version 2 (GPL-2.0) + * + * For full copyright and license information, please see + * the docs/CREDITS.txt file. + * + */ + +/** + * @group functional + */ +class phpbb_functional_acp_smilies_test extends phpbb_functional_test_case +{ +	public function test_htmlspecialchars() +	{ +		$this->login(); +		$this->admin_login(); + +		// Create the BBCode +		$crawler = self::request('GET', 'adm/index.php?i=acp_icons&sid=' . $this->sid . '&mode=smilies&action=edit&id=1'); +		$form = $crawler->selectButton('Submit')->form(array( +			'code[icon_e_biggrin.gif]'    => '>:D', +			'emotion[icon_e_biggrin.gif]' => '>:D' +		)); +		self::submit($form); + +		// Test it in the "new topic" preview +		$crawler = self::request('GET', 'posting.php?mode=post&f=2&sid=' . $this->sid); +		$form = $crawler->selectButton('Preview')->form(array( +			'subject' => 'subject', +			'message' => '>:D' +		)); +		$crawler = self::submit($form); + +		$html = $crawler->filter('#preview')->html(); +		$this->assertRegexp('(<img [^>]+ alt=">:D" title=">:D"[^>]*>)', $html); +	} +} diff --git a/tests/functional/fileupload_remote_test.php b/tests/functional/fileupload_remote_test.php index b70d49cddd..88f8999005 100644 --- a/tests/functional/fileupload_remote_test.php +++ b/tests/functional/fileupload_remote_test.php @@ -100,8 +100,8 @@ class phpbb_functional_fileupload_remote_test extends phpbb_functional_test_case  		$upload = new \phpbb\files\upload($this->filesystem, $this->factory, $this->language, $this->php_ini, $this->request, $this->phpbb_root_path);  		$upload->set_error_prefix('')  			->set_allowed_extensions(array('gif')) -			->set_max_filesize(1000); -		$file = $upload->handle_upload('files.types.remote', self::$root_url . 'styles/prosilver/theme/images/forum_read.gif'); +			->set_max_filesize(2000); +		$file = $upload->handle_upload('files.types.remote', self::$root_url . 'develop/test.gif');  		$this->assertEquals(0, sizeof($file->error));  		$this->assertTrue(file_exists($file->get('filename')));  		$this->assertTrue($file->is_uploaded()); @@ -114,7 +114,7 @@ class phpbb_functional_fileupload_remote_test extends phpbb_functional_test_case  		$upload->set_error_prefix('')  			->set_allowed_extensions(array('gif'))  			->set_max_filesize(100); -		$file = $upload->handle_upload('files.types.remote', self::$root_url . 'styles/prosilver/theme/images/forum_read.gif'); +		$file = $upload->handle_upload('files.types.remote', self::$root_url . 'develop/test.gif');  		$this->assertEquals(1, sizeof($file->error));  		$this->assertEquals('WRONG_FILESIZE', $file->error[0]);  	} diff --git a/tests/functional/notification_test.php b/tests/functional/notification_test.php index 8751de8016..91fc962846 100644 --- a/tests/functional/notification_test.php +++ b/tests/functional/notification_test.php @@ -82,6 +82,7 @@ class phpbb_functional_notification_test extends phpbb_functional_test_case  		// Get form token  		$link = $crawler->selectLink($this->lang('NOTIFICATIONS_MARK_ALL_READ'))->link()->getUri();  		$crawler = self::request('GET', substr($link, strpos($link, 'ucp.'))); -		$this->assertCount(0, $crawler->filter('#notification_list_button strong')); +		$this->assertCount(1, $crawler->filter('#notification_list_button strong.badge.hidden')); +		$this->assertEquals("0", $crawler->filter('#notification_list_button strong.badge.hidden')->text());  	}  } diff --git a/tests/functional/posting_test.php b/tests/functional/posting_test.php index 9dd8a1dc91..8e6328d1d3 100644 --- a/tests/functional/posting_test.php +++ b/tests/functional/posting_test.php @@ -87,6 +87,24 @@ class phpbb_functional_posting_test extends phpbb_functional_test_case  	}  	/** +	 * @see https://tracker.phpbb.com/browse/PHPBB3-14962 +	 */ +	public function test_edit() +	{ +		$this->login(); +		$this->create_topic(2, 'Test Topic post', 'Test topic post'); + +		$url =  self::$client->getCrawler()->selectLink('Edit')->link()->getUri(); +		$post_id = $this->get_parameter_from_link($url, 'p'); +		$crawler = self::request('GET', "posting.php?mode=edit&f=2&p={$post_id}&sid={$this->sid}"); +		$form = $crawler->selectButton('Submit')->form(); +		$form->setValues(array('message' => 'Edited post')); +		$crawler = self::submit($form); + +		$this->assertContains('Edited post', $crawler->filter("#post_content{$post_id} .content")->text()); +	} + +	/**  	* @testdox max_quote_depth is applied to the text populating the posting form  	*/  	public function test_quote_depth_form() @@ -246,4 +264,45 @@ class phpbb_functional_posting_test extends phpbb_functional_test_case  		// Test that the preview contains the correct link  		$this->assertEquals($url, $crawler->filter('#preview a')->attr('href'));  	} + +	public function test_allowed_schemes_links() +	{ +		$text = 'http://example.org/ tcp://localhost:22/ServiceName'; + +		$this->login(); +		$this->admin_login(); + +		// Post with default settings +		$crawler = self::request('GET', 'posting.php?mode=post&f=2'); +		$form = $crawler->selectButton('Preview')->form(array( +			'subject' => 'Test subject', +			'message' => $text, +		)); +		$crawler = self::submit($form); +		$this->assertContains( +			'<a href="http://example.org/" class="postlink">http://example.org/</a> tcp://localhost:22/ServiceName', +			$crawler->filter('#preview .content')->html() +		); + +		// Update allowed schemes +		$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[allowed_schemes_links]'] = 'https,tcp'; +		$form->setValues($values); +		$crawler = self::submit($form); +		$this->assertEquals(1, $crawler->filter('.successbox')->count()); + +		// Post with new settings +		$crawler = self::request('GET', 'posting.php?mode=post&f=2'); +		$form = $crawler->selectButton('Preview')->form(array( +			'subject' => 'Test subject', +			'message' => $text, +		)); +		$crawler = self::submit($form); +		$this->assertContains( +			'http://example.org/ <a href="tcp://localhost:22/ServiceName" class="postlink">tcp://localhost:22/ServiceName</a>', +			$crawler->filter('#preview .content')->html() +		); +	}  } diff --git a/tests/functions_privmsgs/get_max_setting_from_group_test.php b/tests/functions_privmsgs/get_max_setting_from_group_test.php index 3eb7866802..fbabf1222a 100644 --- a/tests/functions_privmsgs/get_max_setting_from_group_test.php +++ b/tests/functions_privmsgs/get_max_setting_from_group_test.php @@ -33,12 +33,12 @@ class phpbb_functions_privmsgs_get_max_setting_from_group_test extends phpbb_dat  	static public function get_max_setting_from_group_data()  	{  		return array( -			array(1, 0, 'message_limit'), +			array(1, 2, 'message_limit'),  			array(2, 2, 'message_limit'),  			array(3, 0, 'message_limit'),  			array(4, 0, 'message_limit'),  			array(5, 2, 'message_limit'), -			array(1, 0, 'max_recipients'), +			array(1, 4, 'max_recipients'),  			array(2, 4, 'max_recipients'),  			array(3, 0, 'max_recipients'),  			array(4, 5, 'max_recipients'), diff --git a/tests/mock/phpbb_di_container_builder.php b/tests/mock/phpbb_di_container_builder.php index 23dc3d1e8b..c78b41d8ec 100644 --- a/tests/mock/phpbb_di_container_builder.php +++ b/tests/mock/phpbb_di_container_builder.php @@ -27,4 +27,12 @@ class phpbb_mock_phpbb_di_container_builder extends \phpbb\di\container_builder  	{  		return $this->phpbb_root_path . '../../tmp/autoload.' . $this->php_ext;  	} + +	/** +	 * {@inheritdoc} +	 */ +	protected function inject_dbal_driver() +	{ +		return; +	}  } diff --git a/tests/mock/request.php b/tests/mock/request.php index e7217a94a9..6a32ba0cf1 100644 --- a/tests/mock/request.php +++ b/tests/mock/request.php @@ -34,6 +34,11 @@ class phpbb_mock_request implements \phpbb\request\request_interface  		$this->data[$super_global][$var_name] = $value;  	} +	public function raw_variable($var_name, $default, $super_global = \phpbb\request\request_interface::REQUEST) +	{ +		return $this->variable($var_name, $default, true, $super_global); +	} +  	public function variable($var_name, $default, $multibyte = false, $super_global = \phpbb\request\request_interface::REQUEST)  	{  		return isset($this->data[$super_global][$var_name]) ? $this->data[$super_global][$var_name] : $default; diff --git a/tests/pagination/pagination_test.php b/tests/pagination/pagination_test.php index 024b6fc02d..2d7d1671a8 100644 --- a/tests/pagination/pagination_test.php +++ b/tests/pagination/pagination_test.php @@ -37,10 +37,11 @@ class phpbb_pagination_pagination_test extends phpbb_template_template_test_case  			->method('lang')  			->will($this->returnCallback(array($this, 'return_callback_implode'))); +		$this->config = new \phpbb\config\config(array('enable_mod_rewrite' => '1')); +  		$filesystem = new \phpbb\filesystem\filesystem();  		$manager = new phpbb_mock_extension_manager(dirname(__FILE__) . '/', array()); -		$this->config = new \phpbb\config\config(array('enable_mod_rewrite' => '1'));  		$loader = new \Symfony\Component\Routing\Loader\YamlFileLoader(  			new \phpbb\routing\file_locator($filesystem, dirname(__FILE__) . '/') @@ -218,6 +219,12 @@ class phpbb_pagination_pagination_test extends phpbb_template_template_test_case  				0,  				'PAGE_OF-1-1',  			), +			array( +				'10', +				'10', +				'0', +				'PAGE_OF-1-1', +			),  		);  	} diff --git a/tests/passwords/drivers_test.php b/tests/passwords/drivers_test.php index 5f9fd523c9..01c69a38bb 100644 --- a/tests/passwords/drivers_test.php +++ b/tests/passwords/drivers_test.php @@ -23,8 +23,8 @@ class phpbb_passwords_helper_test extends \phpbb_test_case  		$php_ext = 'php';  		$this->passwords_drivers = array( -			'passwords.driver.bcrypt_2y'	=> new \phpbb\passwords\driver\bcrypt_2y($config, $this->driver_helper), -			'passwords.driver.bcrypt'	=> new \phpbb\passwords\driver\bcrypt($config, $this->driver_helper), +			'passwords.driver.bcrypt_2y'	=> new \phpbb\passwords\driver\bcrypt_2y($config, $this->driver_helper, 10), +			'passwords.driver.bcrypt'	=> new \phpbb\passwords\driver\bcrypt($config, $this->driver_helper, 10),  			'passwords.driver.salted_md5'	=> new \phpbb\passwords\driver\salted_md5($config, $this->driver_helper),  			'passwords.driver.phpass'	=> new \phpbb\passwords\driver\phpass($config, $this->driver_helper),  			'passwords.driver.sha1_smf'	=> new \phpbb\passwords\driver\sha1_smf($config, $this->driver_helper), @@ -413,4 +413,23 @@ class phpbb_passwords_helper_test extends \phpbb_test_case  		);  		return strtr($string, $transform);  	} + +	public function data_needs_rehash() +	{ +		return array( +			array('passwords.driver.bcrypt_2y', '$2y$10$somerandomhash', false), +			array('passwords.driver.bcrypt', '$2a$10$somerandomhash', false), +			array('passwords.driver.salted_md5', 'foobar', false), +			array('passwords.driver.bcrypt_2y', '$2y$9$somerandomhash', true), +			array('passwords.driver.bcrypt', '$2a$04$somerandomhash', true), +		); +	} + +	/** +	 * @dataProvider data_needs_rehash +	 */ +	public function test_needs_rehash($driver, $hash, $expected) +	{ +		$this->assertSame($this->passwords_drivers[$driver]->needs_rehash($hash), $expected); +	}  } diff --git a/tests/passwords/manager_test.php b/tests/passwords/manager_test.php index 333834ee07..0410d7035f 100644 --- a/tests/passwords/manager_test.php +++ b/tests/passwords/manager_test.php @@ -29,8 +29,8 @@ class phpbb_passwords_manager_test extends \phpbb_test_case  		$php_ext = 'php';  		$this->passwords_drivers = array( -			'passwords.driver.bcrypt_2y'		=> new \phpbb\passwords\driver\bcrypt_2y($config, $this->driver_helper), -			'passwords.driver.bcrypt'		=> new \phpbb\passwords\driver\bcrypt($config, $this->driver_helper), +			'passwords.driver.bcrypt_2y'		=> new \phpbb\passwords\driver\bcrypt_2y($config, $this->driver_helper, 10), +			'passwords.driver.bcrypt'		=> new \phpbb\passwords\driver\bcrypt($config, $this->driver_helper, 10),  			'passwords.driver.salted_md5'		=> new \phpbb\passwords\driver\salted_md5($config, $this->driver_helper),  			'passwords.driver.phpass'		=> new \phpbb\passwords\driver\phpass($config, $this->driver_helper),  			'passwords.driver.convert_password'	=> new \phpbb\passwords\driver\convert_password($config, $this->driver_helper), @@ -344,4 +344,54 @@ class phpbb_passwords_manager_test extends \phpbb_test_case  	{  		$this->assertSame($expected, $this->driver_helper->string_compare($a, $b));  	} + +	public function data_driver_interface_driver() +	{ +		return array( +			array(false, false, false), +			array(true, false, false), +			array(true, true, true), +		); +	} + +	/** +	 * @dataProvider data_driver_interface_driver +	 */ +	public function test_driver_interface_driver($use_new_interface, $needs_rehash, $expected) +	{ +		if ($use_new_interface) +		{ +			$test_driver = $this->getMock('\phpbb\passwords\driver\rehashable_driver_interface', array('needs_rehash', 'get_prefix', 'check', 'is_supported', 'is_legacy', 'hash', 'get_settings_only')); +			$test_driver->method('needs_rehash') +				->willReturn($needs_rehash); +		} +		else +		{ +			$test_driver = $this->getMock('\phpbb\passwords\driver\driver_interface', array('get_prefix', 'check', 'is_supported', 'is_legacy', 'hash', 'get_settings_only')); +		} +		$config = new \phpbb\config\config(array()); + +		$test_driver->method('is_supported') +			->willReturn(true); +		$test_driver->method('get_prefix') +			->willReturn('$test$'); +		$test_driver->method('check') +			->with($this->anything()) +			->willReturn(true); +		$passwords_drivers = array( +			'passwords.driver.foobar'		=> $test_driver, +			'passwords.driver.bcrypt_2y'	=> new \phpbb\passwords\driver\bcrypt_2y($config, $this->driver_helper, 10), +		); +		// Set up another manager +		$foobar_manager = new \phpbb\passwords\manager($config, $passwords_drivers, $this->helper, array('passwords.driver.foobar')); + +		$this->assertTrue($foobar_manager->check('foobar', '$test$somerandomstuff')); +		$this->assertEquals($expected, $foobar_manager->convert_flag); + +		// Should always return true in case a different driver is default +		$foobar_manager = new \phpbb\passwords\manager($config, $passwords_drivers, $this->helper, array('passwords.driver.bcrypt_2y', 'passwords.driver.foobar')); + +		$this->assertTrue($foobar_manager->check('foobar', '$test$somerandomstuff')); +		$this->assertTrue($foobar_manager->convert_flag); +	}  } diff --git a/tests/plupload/plupload_test.php b/tests/plupload/plupload_test.php index 3312f4d0a0..46bebb8d35 100644 --- a/tests/plupload/plupload_test.php +++ b/tests/plupload/plupload_test.php @@ -24,7 +24,7 @@ class phpbb_plupload_test extends phpbb_test_case  			array(  				130,  				150, -				'resize: {width: 130, height: 150, quality: 100},' +				'resize: {width: 130, height: 150, quality: 85},'  			),  		);  	} diff --git a/tests/template/template_test.php b/tests/template/template_test.php index 63e7cb869a..ca1414ec45 100644 --- a/tests/template/template_test.php +++ b/tests/template/template_test.php @@ -680,22 +680,139 @@ EOT  			),  			array(  				'outer', +				array('VARIABLE' => 'changed'), +				0, +				'change', +				<<<EOT +outer - 0 - changed +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 +outer - 2 +middle - 0 +middle - 1 +EOT +, +				'Test changing at 0 on top level block', +			), +			array( +				'outer', +				array('VARIABLE' => 'changed'), +				array('S_ROW_NUM' => 2), +				'change', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 +outer - 2 - changed +middle - 0 +middle - 1 +EOT +, +				'Test changing at KEY on top level block', +			), +			array( +				'outer.middle', +				array('VARIABLE' => 'before'), +				false, +				'insert', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 +outer - 2 +middle - 0 - before +middle - 1 +middle - 2 +EOT +, +				'Test inserting before on middle level block', +			), +			array( +				'outer.middle', +				array('VARIABLE' => 'after'), +				true, +				'insert', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 +outer - 2 +middle - 0 +middle - 1 +middle - 2 - after +EOT +, +				'Test inserting after on middle level block', +			), +			array( +				'outer[1].middle',  				array('VARIABLE' => 'pos #1'), +				1, +				'insert', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1 +middle - 0 +middle - 1 - pos #1 +middle - 2 +outer - 2 +middle - 0 +middle - 1 +EOT +, +				'Test inserting at 1 on middle level block', +			), +			array( +				'outer[].middle', +				array('VARIABLE' => 'changed'),  				0,  				'change',  				<<<EOT -outer - 0 - pos #1 +outer - 0  middle - 0  middle - 1  outer - 1  middle - 0  middle - 1  outer - 2 +middle - 0 - changed +middle - 1 +EOT +, +				'Test changing at beginning of last top level block', +			), +			array( +				'outer.middle', +				array('VARIABLE' => 'changed'), +				array('S_ROW_NUM' => 1), +				'change', +				<<<EOT +outer - 0 +middle - 0 +middle - 1 +outer - 1  middle - 0  middle - 1 +outer - 2 +middle - 0 +middle - 1 - changed  EOT  , -				'Test inserting at 1 on top level block', +				'Test changing at beginning of last top level block',  			),  		);  	} @@ -753,8 +870,55 @@ EOT  		$expect = 'outer - 0[outer|4]outer - 1[outer|4]middle - 0[middle|1]outer - 2 - test[outer|4]middle - 0[middle|2]middle - 1[middle|2]outer - 3[outer|4]middle - 0[middle|3]middle - 1[middle|3]middle - 2[middle|3]';  		$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring S_NUM_ROWS is correct after modification'); + +		$this->template->alter_block_array('outer.middle', array()); + +		$expect = 'outer - 0[outer|4]outer - 1[outer|4]middle - 0[middle|1]outer - 2 - test[outer|4]middle - 0[middle|2]middle - 1[middle|2]outer - 3[outer|4]middle - 0[middle|4]middle - 1[middle|4]middle - 2[middle|4]middle - 3[middle|4]'; +		$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring S_NUM_ROWS is correct after insertion at middle level'); + +		$this->template->alter_block_array('outer.middle', array('VARIABLE' => 'test'), 2, 'change'); + +		$expect = 'outer - 0[outer|4]outer - 1[outer|4]middle - 0[middle|1]outer - 2 - test[outer|4]middle - 0[middle|2]middle - 1[middle|2]outer - 3[outer|4]middle - 0[middle|4]middle - 1[middle|4]middle - 2 - test[middle|4]middle - 3[middle|4]'; +		$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring S_NUM_ROWS is correct after modification at middle level');  	} +	public function test_find_key_index() +	{ +		$this->template->set_filenames(array('test' => 'loop_nested.html')); + +		$this->template->assign_var('TEST_MORE', true); + +		// @todo Change this +		$this->template->assign_block_vars('outer', array('VARIABLE' => 'zero')); +		$this->template->assign_block_vars('outer', array('VARIABLE' => 'one')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '1A')); +		$this->template->assign_block_vars('outer', array('VARIABLE' => 'two')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '2A')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '2B')); +		$this->template->assign_block_vars('outer', array('VARIABLE' => 'three')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '3A')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '3B')); +		$this->template->assign_block_vars('outer.middle', array('VARIABLE' => '3C')); + +		$expect = 'outer - 0 - zero[outer|4]outer - 1 - one[outer|4]middle - 0 - 1A[middle|1]outer - 2 - two[outer|4]middle - 0 - 2A[middle|2]middle - 1 - 2B[middle|2]outer - 3 - three[outer|4]middle - 0 - 3A[middle|3]middle - 1 - 3B[middle|3]middle - 2 - 3C[middle|3]'; +		$this->assertEquals($expect, str_replace(array("\n", "\r", "\t"), '', $this->display('test')), 'Ensuring template is built correctly before modification'); + +		$this->template->find_key_index('outer', false); + +		$this->assertEquals(0, $this->template->find_key_index('outer', false), 'Find index at the beginning of outer loop'); +		$this->assertEquals(1, $this->template->find_key_index('outer', 1), 'Find index by index in outer loop'); +		$this->assertEquals(2, $this->template->find_key_index('outer', array('VARIABLE' => 'two')), 'Find index by key in outer loop'); +		$this->assertEquals(3, $this->template->find_key_index('outer', true), 'Find index at the end of outer loop'); +		$this->assertEquals(false, $this->template->find_key_index('outer', 7), 'Find index out of bounds of outer loop'); + +		$this->assertEquals(false, $this->template->find_key_index('outer[0].middle', false), 'Find index at the beginning of middle loop, no middle block'); +		$this->assertEquals(false, $this->template->find_key_index('outer[1].middle', 1), 'Find index by index in inner loop, out of bounds'); +		$this->assertEquals(1, $this->template->find_key_index('outer[2].middle', array('VARIABLE' => '2B')), 'Find index by key in middle loop'); +		$this->assertEquals(2, $this->template->find_key_index('outer.middle', true), 'Find index at the end of middle loop'); + +		$this->assertEquals(false, $this->template->find_key_index('outer.wrong', true), 'Wrong middle block name'); +		$this->assertEquals(false, $this->template->find_key_index('wrong.middle', false), 'Wrong outer block name'); +	}  	public function assign_block_vars_array_data()  	{  		return array( diff --git a/tests/test_framework/phpbb_functional_test_case.php b/tests/test_framework/phpbb_functional_test_case.php index 20b89aba4e..eb56049515 100644 --- a/tests/test_framework/phpbb_functional_test_case.php +++ b/tests/test_framework/phpbb_functional_test_case.php @@ -263,7 +263,7 @@ class phpbb_functional_test_case extends phpbb_test_case  			self::$config['table_prefix'] . 'ext',  			dirname(__FILE__) . '/',  			$phpEx, -			$this->get_cache_driver() +			new \phpbb\cache\service($this->get_cache_driver(), $config, $this->db, $phpbb_root_path, $phpEx)  		);  		return $extension_manager; @@ -291,6 +291,13 @@ class phpbb_functional_test_case extends phpbb_test_case  			}  		} +		$install_config_file = $phpbb_root_path . 'store/install_config.php'; + +		if (file_exists($install_config_file)) +		{ +			unlink($install_config_file); +		} +  		$container_builder = new \phpbb\di\container_builder($phpbb_root_path, $phpEx);  		$container = $container_builder  			->with_environment('installer') @@ -304,11 +311,14 @@ class phpbb_functional_test_case extends phpbb_test_case  				],  				'cache.driver.class' => 'phpbb\cache\driver\file'  			]) +			->with_config(new \phpbb\config_php_file($phpbb_root_path, $phpEx))  			->without_compiled_container()  			->get_container();  		$container->register('installer.install_finish.notify_user')->setSynthetic(true);  		$container->set('installer.install_finish.notify_user', new phpbb_mock_null_installer_task()); +		$container->register('installer.install_finish.install_extensions')->setSynthetic(true); +		$container->set('installer.install_finish.install_extensions', new phpbb_mock_null_installer_task());  		$container->compile();  		$language = $container->get('language'); diff --git a/tests/test_framework/phpbb_ui_test_case.php b/tests/test_framework/phpbb_ui_test_case.php index e3f636679c..b875d3212b 100644 --- a/tests/test_framework/phpbb_ui_test_case.php +++ b/tests/test_framework/phpbb_ui_test_case.php @@ -78,14 +78,11 @@ class phpbb_ui_test_case extends phpbb_test_case  			self::markTestSkipped('phpbb_functional_url was not set in test_config and wasn\'t set as PHPBB_FUNCTIONAL_URL environment variable either.');  		} -		if (!self::$webDriver) -		{ -			try { -				$capabilities = DesiredCapabilities::firefox(); -				self::$webDriver = RemoteWebDriver::create(self::$host . ':' . self::$port, $capabilities); -			} catch (WebDriverCurlException $e) { -				self::markTestSkipped('PhantomJS webserver is not running.'); -			} +		try { +			$capabilities = DesiredCapabilities::firefox(); +			self::$webDriver = RemoteWebDriver::create(self::$host . ':' . self::$port, $capabilities); +		} catch (WebDriverCurlException $e) { +			self::markTestSkipped('PhantomJS webserver is not running.');  		}  		if (!self::$already_installed) @@ -146,9 +143,14 @@ class phpbb_ui_test_case extends phpbb_test_case  		}  	} -	static public function visit($path) +	public function getDriver() +	{ +		return self::$webDriver; +	} + +	public function visit($path)  	{ -		self::$webDriver->get(self::$root_url . $path); +		$this->getDriver()->get(self::$root_url . $path);  	}  	static protected function recreate_database($config) @@ -157,14 +159,14 @@ class phpbb_ui_test_case extends phpbb_test_case  		$db_conn_mgr->recreate_db();  	} -	static public function find_element($type, $value) +	public function find_element($type, $value)  	{ -		return self::$webDriver->findElement(WebDriverBy::$type($value)); +		return $this->getDriver()->findElement(WebDriverBy::$type($value));  	} -	static public function submit($type = 'id', $value = 'submit') +	public function submit($type = 'id', $value = 'submit')  	{ -		$element = self::find_element($type, $value); +		$element = $this->find_element($type, $value);  		$element->click();  	} @@ -305,21 +307,21 @@ class phpbb_ui_test_case extends phpbb_test_case  		$ext_path = str_replace('/', '%2F', $extension);  		$this->visit('adm/index.php?i=acp_extensions&mode=main&action=enable_pre&ext_name=' . $ext_path . '&sid=' . $this->sid); -		$this->assertNotEmpty(count(self::find_element('cssSelector', '.submit-buttons'))); +		$this->assertNotEmpty(count($this->find_element('cssSelector', '.submit-buttons'))); -		self::find_element('cssSelector', "input[value='Enable']")->submit(); +		$this->find_element('cssSelector', "input[value='Enable']")->submit();  		$this->add_lang('acp/extensions');  		try  		{ -			$meta_refresh = self::find_element('cssSelector', 'meta[http-equiv="refresh"]'); +			$meta_refresh = $this->find_element('cssSelector', 'meta[http-equiv="refresh"]');  			// Wait for extension to be fully enabled  			while (sizeof($meta_refresh))  			{  				preg_match('#url=.+/(adm+.+)#', $meta_refresh->getAttribute('content'), $match); -				self::$webDriver->execute(array('method' => 'post', 'url' => $match[1])); -				$meta_refresh = self::find_element('cssSelector', 'meta[http-equiv="refresh"]'); +				$this->getDriver()->execute(array('method' => 'post', 'url' => $match[1])); +				$meta_refresh = $this->find_element('cssSelector', 'meta[http-equiv="refresh"]');  			}  		}  		catch (\Facebook\WebDriver\Exception\NoSuchElementException $e) @@ -327,7 +329,7 @@ class phpbb_ui_test_case extends phpbb_test_case  			// Probably no refresh triggered  		} -		$this->assertContainsLang('EXTENSION_ENABLE_SUCCESS', self::find_element('cssSelector', 'div.successbox')->getText()); +		$this->assertContainsLang('EXTENSION_ENABLE_SUCCESS', $this->find_element('cssSelector', 'div.successbox')->getText());  		$this->logout();  	} @@ -415,7 +417,7 @@ class phpbb_ui_test_case extends phpbb_test_case  		}  		$this->visit('ucp.php?sid=' . $this->sid . '&mode=logout'); -		$this->assertContains($this->lang('REGISTER'), self::$webDriver->getPageSource()); +		$this->assertContains($this->lang('REGISTER'), $this->getDriver()->getPageSource());  		unset($this->sid);  	} @@ -435,17 +437,17 @@ class phpbb_ui_test_case extends phpbb_test_case  			return;  		} -		self::$webDriver->manage()->deleteAllCookies(); +		$this->getDriver()->manage()->deleteAllCookies();  		$this->visit('adm/index.php?sid=' . $this->sid); -		$this->assertContains($this->lang('LOGIN_ADMIN_CONFIRM'), self::$webDriver->getPageSource()); +		$this->assertContains($this->lang('LOGIN_ADMIN_CONFIRM'), $this->getDriver()->getPageSource()); -		self::find_element('cssSelector', 'input[name=username]')->clear()->sendKeys($username); -		self::find_element('cssSelector', 'input[type=password]')->sendKeys($username . $username); -		self::find_element('cssSelector', 'input[name=login]')->click(); +		$this->find_element('cssSelector', 'input[name=username]')->clear()->sendKeys($username); +		$this->find_element('cssSelector', 'input[type=password]')->sendKeys($username . $username); +		$this->find_element('cssSelector', 'input[name=login]')->click();  		$this->assertContains($this->lang('ADMIN_PANEL'), $this->find_element('cssSelector', 'h1')->getText()); -		$cookies = self::$webDriver->manage()->getCookies(); +		$cookies = $this->getDriver()->manage()->getCookies();  		// The session id is stored in a cookie that ends with _sid - we assume there is only one such cookie  		foreach ($cookies as $cookie) @@ -550,19 +552,19 @@ class phpbb_ui_test_case extends phpbb_test_case  	{  		$this->add_lang('ucp'); -		self::$webDriver->manage()->deleteAllCookies(); +		$this->getDriver()->manage()->deleteAllCookies();  		$this->visit('ucp.php'); -		$this->assertContains($this->lang('LOGIN_EXPLAIN_UCP'), self::$webDriver->getPageSource()); +		$this->assertContains($this->lang('LOGIN_EXPLAIN_UCP'), $this->getDriver()->getPageSource()); -		self::$webDriver->manage()->deleteAllCookies(); +		$this->getDriver()->manage()->deleteAllCookies(); -		self::find_element('cssSelector', 'input[name=username]')->sendKeys($username); -		self::find_element('cssSelector', 'input[name=password]')->sendKeys($username . $username); -		self::find_element('cssSelector', 'input[name=login]')->click(); +		$this->find_element('cssSelector', 'input[name=username]')->sendKeys($username); +		$this->find_element('cssSelector', 'input[name=password]')->sendKeys($username . $username); +		$this->find_element('cssSelector', 'input[name=login]')->click();  		$this->assertNotContains($this->lang('LOGIN'), $this->find_element('className', 'navbar')->getText()); -		$cookies = self::$webDriver->manage()->getCookies(); +		$cookies = $this->getDriver()->manage()->getCookies();  		// The session id is stored in a cookie that ends with _sid - we assume there is only one such cookie  		foreach ($cookies as $cookie) @@ -586,6 +588,6 @@ class phpbb_ui_test_case extends phpbb_test_case  		// Change the Path to your own settings  		$screenshot = time() . ".png"; -		self::$webDriver->takeScreenshot($screenshot); +		$this->getDriver()->takeScreenshot($screenshot);  	}  } diff --git a/tests/text_formatter/s9e/default_formatting_test.php b/tests/text_formatter/s9e/default_formatting_test.php index e25c3246b5..a0c57214e4 100644 --- a/tests/text_formatter/s9e/default_formatting_test.php +++ b/tests/text_formatter/s9e/default_formatting_test.php @@ -298,7 +298,7 @@ class phpbb_textformatter_s9e_default_formatting_test extends phpbb_test_case  			),  			array(  				"Emoji: \xF0\x9F\x98\x80", -				'Emoji: <img alt="' . "\xF0\x9F\x98\x80" . '" class="smilies" draggable="false" width="18" height="18" src="//cdn.jsdelivr.net/emojione/assets/svg/1f600.svg">' +				'Emoji: <img alt="' . "\xF0\x9F\x98\x80" . '" class="emoji smilies" draggable="false" src="//cdn.jsdelivr.net/emojione/assets/svg/1f600.svg">'  			),  			array(  				"Emoji: \xF0\x9F\x98\x80", diff --git a/tests/text_formatter/s9e/factory_test.php b/tests/text_formatter/s9e/factory_test.php index 368b8a4f4b..3d3ea8b794 100644 --- a/tests/text_formatter/s9e/factory_test.php +++ b/tests/text_formatter/s9e/factory_test.php @@ -165,7 +165,7 @@ class phpbb_textformatter_s9e_factory_test extends phpbb_database_test_case  		$renderer = $this->get_test_case_helpers()->set_s9e_services(null, $fixture)->get('text_formatter.renderer');  		$this->assertSame( -			'<img class="smilies" src="phpBB/images/smilies/%22%27%3C&%3E.png" alt=""\'<&>" title=""\'<&>">', +			'<img class="smilies" src="phpBB/images/smilies/%22%27%3C&%3E.png" width="15" height="17" alt=""\'<&>" title=""\'<&>">',  			$renderer->render('<r><E>"\'<&></E></r>')  		);  	} diff --git a/tests/text_formatter/s9e/renderer_test.php b/tests/text_formatter/s9e/renderer_test.php index 2b034259c9..175b90fdc7 100644 --- a/tests/text_formatter/s9e/renderer_test.php +++ b/tests/text_formatter/s9e/renderer_test.php @@ -115,7 +115,7 @@ class phpbb_textformatter_s9e_renderer_test extends phpbb_test_case  			),  			array(  				'<r><E>:)</E></r>', -				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" alt=":)" title="Smile">', +				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" width="15" height="17" alt=":)" title="Smile">',  				array('set_viewsmilies' => true)  			),  			array( @@ -248,7 +248,7 @@ class phpbb_textformatter_s9e_renderer_test extends phpbb_test_case  			),  			array(  				'<r><E>:)</E></r>', -				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" alt=":)" title="Smile">' +				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" width="15" height="17" alt=":)" title="Smile">'  			),  			array(  				'<r><E>:)</E></r>', diff --git a/tests/text_processing/generate_text_for_display_test.php b/tests/text_processing/generate_text_for_display_test.php index dfbd0977a0..b8b5b18561 100644 --- a/tests/text_processing/generate_text_for_display_test.php +++ b/tests/text_processing/generate_text_for_display_test.php @@ -190,7 +190,7 @@ class phpbb_text_processing_generate_text_for_display_test extends phpbb_test_ca  			),  			array(  				'<r><E>:)</E></r>', -				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" alt=":)" title="Smile">' +				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" width="15" height="17" alt=":)" title="Smile">'  			),  			array(  				'<r><E>:)</E></r>', diff --git a/tests/text_processing/smilies_test.php b/tests/text_processing/smilies_test.php index ebdbe7dadc..3778e5f58c 100644 --- a/tests/text_processing/smilies_test.php +++ b/tests/text_processing/smilies_test.php @@ -30,19 +30,19 @@ class phpbb_text_processing_smilies_test extends phpbb_test_case  		return array(  			array(  				':) beginning', -				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" alt=":)" title="Smile"> beginning' +				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" width="15" height="17" alt=":)" title="Smile"> beginning'  			),  			array(  				'end :)', -				'end <img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" alt=":)" title="Smile">' +				'end <img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" width="15" height="17" alt=":)" title="Smile">'  			),  			array(  				':)', -				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" alt=":)" title="Smile">' +				'<img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" width="15" height="17" alt=":)" title="Smile">'  			),  			array(  				'xx (18) 8) xx', -				'xx (18) <img class="smilies" src="phpBB/images/smilies/custom.gif" alt="8)" title="8)"> xx' +				'xx (18) <img class="smilies" src="phpBB/images/smilies/custom.gif" width="17" height="18" alt="8)" title="8)"> xx'  			),  		);  	} diff --git a/tests/text_processing/tickets_data/PHPBB3-13425.html b/tests/text_processing/tickets_data/PHPBB3-13425.html index 9a042dc558..a3b6d21f40 100644 --- a/tests/text_processing/tickets_data/PHPBB3-13425.html +++ b/tests/text_processing/tickets_data/PHPBB3-13425.html @@ -1 +1 @@ -<blockquote class="uncited"><div><img class="smilies" src="phpBB/images/smilies/icon_lol.gif" alt=":lol:" title="Laughing"> starts with a smiley</div></blockquote>
\ No newline at end of file +<blockquote class="uncited"><div><img class="smilies" src="phpBB/images/smilies/icon_lol.gif" width="15" height="17" alt=":lol:" title="Laughing"> starts with a smiley</div></blockquote>
\ No newline at end of file diff --git a/tests/text_processing/tickets_data/PHPBB3-14790.html b/tests/text_processing/tickets_data/PHPBB3-14790.html new file mode 100644 index 0000000000..7624b2d36c --- /dev/null +++ b/tests/text_processing/tickets_data/PHPBB3-14790.html @@ -0,0 +1,4 @@ +<span style="color: #0000FF"></span><ul><li><span style="color: #0000FF">text</span></li> +<li><span style="color: #0000FF">text</span></li> +<li><span style="color: #0000FF">text</span></li> +<li><span style="color: #0000FF">text</span></li></ul>
\ No newline at end of file diff --git a/tests/text_processing/tickets_data/PHPBB3-14790.txt b/tests/text_processing/tickets_data/PHPBB3-14790.txt new file mode 100644 index 0000000000..1cd83d97d8 --- /dev/null +++ b/tests/text_processing/tickets_data/PHPBB3-14790.txt @@ -0,0 +1,4 @@ +[color=#0000FF][list][*]text +[*]text +[*]text +[*]text[/list][/color]
\ No newline at end of file diff --git a/tests/text_processing/tickets_data/PHPBB3-15008.before.php b/tests/text_processing/tickets_data/PHPBB3-15008.before.php new file mode 100644 index 0000000000..a3243e74cd --- /dev/null +++ b/tests/text_processing/tickets_data/PHPBB3-15008.before.php @@ -0,0 +1,18 @@ +<?php +/** +* +* This file is part of the phpBB Forum Software package. +* +* @copyright (c) phpBB Limited <https://www.phpbb.com> +* @license GNU General Public License, version 2 (GPL-2.0) +* +* For full copyright and license information, please see +* the docs/CREDITS.txt file. +* +*/ + +function before_assert_phpbb3_15008($vars) +{ +	extract($vars); +	$parser->disable_smilies(); +} diff --git a/tests/text_processing/tickets_data/PHPBB3-15008.html b/tests/text_processing/tickets_data/PHPBB3-15008.html new file mode 100644 index 0000000000..7642eb63ee --- /dev/null +++ b/tests/text_processing/tickets_data/PHPBB3-15008.html @@ -0,0 +1 @@ +No smilies :) or shortnames :strawberry:
\ No newline at end of file diff --git a/tests/text_processing/tickets_data/PHPBB3-15008.txt b/tests/text_processing/tickets_data/PHPBB3-15008.txt new file mode 100644 index 0000000000..7642eb63ee --- /dev/null +++ b/tests/text_processing/tickets_data/PHPBB3-15008.txt @@ -0,0 +1 @@ +No smilies :) or shortnames :strawberry:
\ No newline at end of file diff --git a/tests/text_processing/tickets_data/PHPBB3-15016.html b/tests/text_processing/tickets_data/PHPBB3-15016.html new file mode 100644 index 0000000000..47b66ad771 --- /dev/null +++ b/tests/text_processing/tickets_data/PHPBB3-15016.html @@ -0,0 +1 @@ +<img class="smilies" src="phpBB/images/smilies/icon_lol.gif" width="15" height="17" alt=")--(" title=")--("> <img class="smilies" src="phpBB/images/smilies/icon_lol.gif" width="15" height="17" alt=")-(" title=")-("> <img class="smilies" src="phpBB/images/smilies/icon_lol.gif" width="15" height="17" alt=")--" title=")--">
\ No newline at end of file diff --git a/tests/text_processing/tickets_data/PHPBB3-15016.txt b/tests/text_processing/tickets_data/PHPBB3-15016.txt new file mode 100644 index 0000000000..081d9e3dc9 --- /dev/null +++ b/tests/text_processing/tickets_data/PHPBB3-15016.txt @@ -0,0 +1 @@ +)--( )-( )--
\ No newline at end of file diff --git a/tests/text_processing/tickets_data/PHPBB3-15016.xml b/tests/text_processing/tickets_data/PHPBB3-15016.xml new file mode 100644 index 0000000000..644481861e --- /dev/null +++ b/tests/text_processing/tickets_data/PHPBB3-15016.xml @@ -0,0 +1,43 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<dataset> +	<table name="phpbb_smilies"> +		<column>smiley_id</column> +		<column>code</column> +		<column>emotion</column> +		<column>smiley_url</column> +		<column>smiley_width</column> +		<column>smiley_height</column> +		<column>smiley_order</column> +		<column>display_on_posting</column> +		<row> +			<value>1</value> +			<value>)--(</value> +			<value>)--(</value> +			<value>icon_lol.gif</value> +			<value>15</value> +			<value>17</value> +			<value>22</value> +			<value>1</value> +		</row> +		<row> +			<value>2</value> +			<value>)--</value> +			<value>)--</value> +			<value>icon_lol.gif</value> +			<value>15</value> +			<value>17</value> +			<value>22</value> +			<value>1</value> +		</row> +		<row> +			<value>3</value> +			<value>)-(</value> +			<value>)-(</value> +			<value>icon_lol.gif</value> +			<value>15</value> +			<value>17</value> +			<value>22</value> +			<value>1</value> +		</row> +	</table> +</dataset> diff --git a/tests/text_processing/tickets_data/PHPBB3-7187.html b/tests/text_processing/tickets_data/PHPBB3-7187.html index 9138779d29..a37cdf038e 100644 --- a/tests/text_processing/tickets_data/PHPBB3-7187.html +++ b/tests/text_processing/tickets_data/PHPBB3-7187.html @@ -1 +1 @@ -<blockquote class="uncited"><div><img class="smilies" src="phpBB/images/smilies/icon_e_geek.gif" alt=":geek:" title="Geek"> <img class="smilies" src="phpBB/images/smilies/icon_e_ugeek.gif" alt=":ugeek:" title="Uber Geek"></div></blockquote>
\ No newline at end of file +<blockquote class="uncited"><div><img class="smilies" src="phpBB/images/smilies/icon_e_geek.gif" width="17" height="17" alt=":geek:" title="Geek"> <img class="smilies" src="phpBB/images/smilies/icon_e_ugeek.gif" width="17" height="18" alt=":ugeek:" title="Uber Geek"></div></blockquote>
\ No newline at end of file diff --git a/tests/text_processing/tickets_data/PHPBB3-7275.html b/tests/text_processing/tickets_data/PHPBB3-7275.html index 12502833fd..470aebb5d0 100644 --- a/tests/text_processing/tickets_data/PHPBB3-7275.html +++ b/tests/text_processing/tickets_data/PHPBB3-7275.html @@ -1 +1 @@ -<div align="center"><img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" alt=":)" title="Smile"></div>
\ No newline at end of file +<div align="center"><img class="smilies" src="phpBB/images/smilies/icon_e_smile.gif" width="15" height="17" alt=":)" title="Smile"></div>
\ No newline at end of file diff --git a/tests/ui/permission_roles_test.php b/tests/ui/permission_roles_test.php index 3501124fc1..de54cc788d 100644 --- a/tests/ui/permission_roles_test.php +++ b/tests/ui/permission_roles_test.php @@ -25,19 +25,19 @@ class ui_permission_roles_test extends phpbb_ui_test_case  		$this->visit('adm/index.php?i=acp_permissions&mode=setting_forum_local&sid=' . $this->sid);  		// Select forums -		$elements = self::find_element('cssSelector', 'select#forum') +		$elements = $this->find_element('cssSelector', 'select#forum')  			->findElements(\Facebook\WebDriver\WebDriverBy::tagName('option'));  		foreach ($elements as $element)  		{  			$element->click();  		} -		self::find_element('cssSelector', 'form#select_victim') +		$this->find_element('cssSelector', 'form#select_victim')  			->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('input[type=submit]'))  			->click();  		// Select administrators and guests -		$groups_form = self::find_element('cssSelector', 'form#groups'); +		$groups_form = $this->find_element('cssSelector', 'form#groups');  		$elements = $groups_form  			->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('select'))  			->findElements(\Facebook\WebDriver\WebDriverBy::tagName('option')); @@ -51,7 +51,7 @@ class ui_permission_roles_test extends phpbb_ui_test_case  		}  		$groups_form->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('input[name=submit_edit_options]'))->click(); -		$first_fieldset = self::find_element('cssSelector', '#perm11'); +		$first_fieldset = $this->find_element('cssSelector', '#perm11');  		$this->assertEquals('none', $first_fieldset->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('div.dropdown'))->getCSSValue('display'));  		$first_fieldset  			->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('span.dropdown-toggle')) @@ -74,14 +74,14 @@ class ui_permission_roles_test extends phpbb_ui_test_case  		$this->assertEquals($this->lang('ROLE_FORUM_LIMITED'), $first_fieldset->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('span.dropdown-toggle'))->getText());  		// Check that admin settings didn't get changed -		$second_fieldset = self::find_element('cssSelector', '#perm10'); +		$second_fieldset = $this->find_element('cssSelector', '#perm10');  		$this->assertEquals('none', $second_fieldset->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('div.dropdown'))->getCSSValue('display'));  		// Full access = 14  		$this->assertEquals(14, $second_fieldset->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('input[type=hidden]'))->getAttribute('value'));  		$this->assertEquals($this->lang('ROLE_FORUM_FULL'), $second_fieldset->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('span.dropdown-toggle'))->getText());  		// Check that category settings were not modified -		$category_fieldset = self::find_element('cssSelector', '#perm00'); +		$category_fieldset = $this->find_element('cssSelector', '#perm00');  		$this->assertEquals('none', $category_fieldset->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('div.dropdown'))->getCSSValue('display'));  		// No settings  		$this->assertEquals('', $category_fieldset->findElement(\Facebook\WebDriver\WebDriverBy::cssSelector('input[type=hidden]'))->getAttribute('value')); diff --git a/tests/ui/quick_links_test.php b/tests/ui/quick_links_test.php index 582aeafcae..171ef3ca53 100644 --- a/tests/ui/quick_links_test.php +++ b/tests/ui/quick_links_test.php @@ -19,8 +19,8 @@ class quick_links_test extends phpbb_ui_test_case  	public function test_quick_links()  	{  		$this->visit('index.php'); -		$this->assertEmpty(self::find_element('className', 'dropdown')->getText()); -		self::find_element('className', 'dropdown-toggle')->click(); -		$this->assertNotNull(self::find_element('className', 'dropdown')->getText()); +		$this->assertEmpty($this->find_element('className', 'dropdown')->getText()); +		$this->find_element('className', 'dropdown-toggle')->click(); +		$this->assertNotNull($this->find_element('className', 'dropdown')->getText());  	}  } diff --git a/tests/version/version_fetch_test.php b/tests/version/version_fetch_test.php index 6ecc9b7223..c44bd5514a 100644 --- a/tests/version/version_fetch_test.php +++ b/tests/version/version_fetch_test.php @@ -28,15 +28,12 @@ class phpbb_version_helper_fetch_test extends phpbb_test_case  			->disableOriginalConstructor()  			->getMock(); -		$lang_loader = new \phpbb\language\language_file_loader($phpbb_root_path, $phpEx); -  		$this->version_helper = new \phpbb\version_helper(  			$this->cache,  			new \phpbb\config\config(array(  				'version'	=> '3.1.0',  			)), -			new \phpbb\file_downloader(), -			new \phpbb\user(new \phpbb\language\language($lang_loader), '\phpbb\datetime') +			new \phpbb\file_downloader()  		);  	} diff --git a/tests/version/version_helper_remote_test.php b/tests/version/version_helper_remote_test.php index 724c4c970c..fa383d487f 100644 --- a/tests/version/version_helper_remote_test.php +++ b/tests/version/version_helper_remote_test.php @@ -42,8 +42,7 @@ class version_helper_remote_test extends \phpbb_test_case  		$this->version_helper = new \phpbb\version_helper(  			$this->cache,  			$config, -			$this->file_downloader, -			new \phpbb\user(new \phpbb\language\language($lang_loader), '\phpbb\datetime') +			$this->file_downloader  		);  		$this->user = new \phpbb\user(new \phpbb\language\language($lang_loader), '\phpbb\datetime');  		$this->user->add_lang('acp/common'); @@ -161,8 +160,8 @@ class version_helper_remote_test extends \phpbb_test_case  		{  			try {  				$return = $this->version_helper->get_versions(); -			} catch (\RuntimeException $e) { -				$this->assertEquals((string)$e->getMessage(), $this->user->lang('VERSIONCHECK_FAIL')); +			} catch (\phpbb\exception\runtime_exception $e) { +				$this->assertEquals((string)$e->getMessage(), 'VERSIONCHECK_FAIL');  			}  		}  		else diff --git a/tests/version/version_test.php b/tests/version/version_test.php index 05577f6a18..abe51ef539 100644 --- a/tests/version/version_test.php +++ b/tests/version/version_test.php @@ -25,15 +25,12 @@ class phpbb_version_helper_test extends phpbb_test_case  			->disableOriginalConstructor()  			->getMock(); -		$lang_loader = new \phpbb\language\language_file_loader($phpbb_root_path, $phpEx); -  		$this->version_helper = new \phpbb\version_helper(  			$this->cache,  			new \phpbb\config\config(array(  				'version'	=> '3.1.0',  			)), -			new \phpbb\file_downloader(), -			new \phpbb\user(new \phpbb\language\language($lang_loader), '\phpbb\datetime') +			new \phpbb\file_downloader()  		);  	} @@ -344,4 +341,209 @@ class phpbb_version_helper_test extends phpbb_test_case  		$this->assertSame($expected, $version_helper->get_latest_on_current_branch());  	} + +	public function get_update_on_branch_data() +	{ +		return array( +			array( +				'1.0.0', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +					), +				), +				array( +					'current'		=> '1.0.1', +				), +			), +			array( +				'1.0.1', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +					), +				), +				array(), +			), +			array( +				'1.0.1-a1', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1-a2', +					), +					'1.1'	=> array( +						'current'		=> '1.1.0', +					), +				), +				array( +					'current'		=> '1.0.1-a2', +				), +			), +			array( +				'1.1.0', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +					), +				), +				array( +					'current'		=> '1.1.1', +				), +			), +			array( +				'1.1.1', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +					), +				), +				array(), +			), +			array( +				'1.1.0-a1', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +					), +					'1.1'	=> array( +						'current'		=> '1.1.0-a2', +					), +				), +				array( +					'current'		=> '1.1.0-a2', +				), +			), +			array( +				'1.1.0', +				array(), +				array(), +			), +			// Latest safe release is 1.0.1 +			array( +				'1.0.0', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +						'security'		=> '1.0.1', +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +					), +				), +				array( +					'current'		=> '1.0.1', +					'security'		=> '1.0.1', +				), +			), +			// Latest safe release is 1.0.0 +			array( +				'1.0.0', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +						'security'		=> '1.0.0', +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +					), +				), +				array( +					'current'		=> '1.0.1', +					'security'		=> '1.0.0', +				), +			), +			// Latest safe release is 1.1.0 +			array( +				'1.0.0', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +						'security'		=> '1.1.0', +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +					), +				), +				array( +					'current'		=> '1.1.1', +				), +			), +			// Latest 1.0 release is EOL +			array( +				'1.0.0', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +						'eol'			=> true, +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +					), +				), +				array( +					'current'		=> '1.1.1', +				), +			), +			// All are EOL -- somewhat undefined behavior +			array( +				'1.0.0', +				array( +					'1.0'	=> array( +						'current'		=> '1.0.1', +						'eol'			=> true, +					), +					'1.1'	=> array( +						'current'		=> '1.1.1', +						'eol'			=> true, +					), +				), +				array(), +			), +		); +	} + +	/** +	 * @dataProvider get_update_on_branch_data +	 */ +	public function test_get_update_on_branch($current_version, $versions, $expected) +	{ +		global $phpbb_root_path, $phpEx; + +		$lang_loader = new \phpbb\language\language_file_loader($phpbb_root_path, $phpEx); +		$lang = new \phpbb\language\language($lang_loader); + +		$version_helper = $this +			->getMockBuilder('\phpbb\version_helper') +			->setMethods(array( +				'get_versions_matching_stability', +			)) +			->setConstructorArgs(array( +				$this->cache, +				new \phpbb\config\config(array( +					'version'	=> $current_version, +				)), +				new \phpbb\file_downloader(), +				new \phpbb\user($lang, '\phpbb\datetime'), +			)) +			->getMock() +		; + +		$version_helper->expects($this->any()) +			->method('get_versions_matching_stability') +			->will($this->returnValue($versions)); + +		$this->assertSame($expected, $version_helper->get_update_on_branch()); +	}  } | 
