diff options
| author | Nathaniel Guse <nathaniel.guse@gmail.com> | 2013-07-12 14:12:46 -0500 | 
|---|---|---|
| committer | Nathaniel Guse <nathaniel.guse@gmail.com> | 2013-07-12 14:12:46 -0500 | 
| commit | 8a93a35def8aefb38f97cc9c27b80fd9e773ec01 (patch) | |
| tree | 4e8cc57243ba56fa5df58b641f78efbcc7e25189 | |
| parent | 91672b6d561d2122b509b83bea3f13699c2bab87 (diff) | |
| parent | 01b9f9f9b6f14d602ce57a37f0969707d1f0c41b (diff) | |
| download | forums-8a93a35def8aefb38f97cc9c27b80fd9e773ec01.tar forums-8a93a35def8aefb38f97cc9c27b80fd9e773ec01.tar.gz forums-8a93a35def8aefb38f97cc9c27b80fd9e773ec01.tar.bz2 forums-8a93a35def8aefb38f97cc9c27b80fd9e773ec01.tar.xz forums-8a93a35def8aefb38f97cc9c27b80fd9e773ec01.zip | |
Merge remote-tracking branch 'remotes/Marc/ticket/11548-develop' into develop
# By Marc Alexander
# Via Marc Alexander
* remotes/Marc/ticket/11548-develop:
  [ticket/11548] Fix test errors in groups test on develop
  [ticket/11548] Check upload avatar URL the same way as in phpBB 3.0
| -rw-r--r-- | phpBB/includes/avatar/driver/upload.php | 26 | ||||
| -rw-r--r-- | tests/functional/common_groups_test.php | 15 | 
2 files changed, 34 insertions, 7 deletions
| diff --git a/phpBB/includes/avatar/driver/upload.php b/phpBB/includes/avatar/driver/upload.php index baf51f61c1..685ac4f349 100644 --- a/phpBB/includes/avatar/driver/upload.php +++ b/phpBB/includes/avatar/driver/upload.php @@ -77,6 +77,32 @@ class phpbb_avatar_driver_upload extends phpbb_avatar_driver  		}  		elseif (!empty($this->config['allow_avatar_remote_upload']) && !empty($url))  		{ +			if (!preg_match('#^(http|https|ftp)://#i', $url)) +			{ +				$url = 'http://' . $url; +			} + +			if (!function_exists('validate_data')) +			{ +				require($this->phpbb_root_path . 'includes/functions_user.' . $this->php_ext); +			} + +			$validate_array = validate_data( +				array( +					'url' => $url, +				), +				array( +					'url' => array('string', true, 5, 255), +				) +			); + +			$error = array_merge($error, $validate_array); + +			if (!empty($error)) +			{ +				return false; +			} +  			$file = $upload->remote_upload($url);  		}  		else diff --git a/tests/functional/common_groups_test.php b/tests/functional/common_groups_test.php index f6b447dc90..6c6572af62 100644 --- a/tests/functional/common_groups_test.php +++ b/tests/functional/common_groups_test.php @@ -84,19 +84,19 @@ abstract class phpbb_functional_common_groups_test extends phpbb_functional_test  	public function group_avatar_min_max_data()  	{  		return array( -			array('uploadurl', 'foo', 'TOO_SHORT'), -			array('uploadurl', 'foobar', 'AVATAR_URL_INVALID'), -			array('uploadurl', str_repeat('f', 256), 'TOO_LONG'), -			array('remotelink', 'foo', 'TOO_SHORT'), -			array('remotelink', 'foobar', 'AVATAR_URL_INVALID'), -			array('remotelink', str_repeat('f', 256), 'TOO_LONG'), +			array('avatar_driver_upload', 'avatar_upload_url', 'foo', 'AVATAR_URL_INVALID'), +			array('avatar_driver_upload', 'avatar_upload_url', 'foobar', 'AVATAR_URL_INVALID'), +			array('avatar_driver_upload', 'avatar_upload_url', 'http://www.phpbb.com/' . str_repeat('f', 240) . '.png', 'TOO_LONG'), +			array('avatar_driver_remote', 'avatar_remote_url', 'foo', 'AVATAR_URL_INVALID'), +			array('avatar_driver_remote', 'avatar_remote_url', 'foobar', 'AVATAR_URL_INVALID'), +			array('avatar_driver_remote', 'avatar_remote_url', 'http://www.phpbb.com/' . str_repeat('f', 240) . '.png', 'TOO_LONG'),  		);  	}  	/**  	* @dataProvider group_avatar_min_max_data  	*/ -	public function test_group_avatar_min_max($form_name, $input, $expected) +	public function test_group_avatar_min_max($avatar_type, $form_name, $input, $expected)  	{  		$this->login();  		$this->admin_login(); @@ -105,6 +105,7 @@ abstract class phpbb_functional_common_groups_test extends phpbb_functional_test  		$crawler = self::request('GET', $this->get_url() . '&g=5&sid=' . $this->sid);  		$form = $crawler->selectButton($this->lang('SUBMIT'))->form(); +		$form['avatar_driver']->setValue($avatar_type);  		$form[$form_name]->setValue($input);  		$crawler = self::submit($form);  		$this->assertContains($this->lang($expected), $crawler->text()); | 
