diff options
| author | Marc Alexander <admin@m-a-styles.de> | 2013-07-11 16:08:15 -0400 | 
|---|---|---|
| committer | Marc Alexander <admin@m-a-styles.de> | 2013-07-11 16:15:27 -0400 | 
| commit | 599f83395f90c9a899b0e639ba5acacfb8ae372b (patch) | |
| tree | 052e156a413e732b7abb9d1ceeec8937cb72a7f8 | |
| parent | a9977686275f968a26272fb8bad28f7506f0043b (diff) | |
| download | forums-599f83395f90c9a899b0e639ba5acacfb8ae372b.tar forums-599f83395f90c9a899b0e639ba5acacfb8ae372b.tar.gz forums-599f83395f90c9a899b0e639ba5acacfb8ae372b.tar.bz2 forums-599f83395f90c9a899b0e639ba5acacfb8ae372b.tar.xz forums-599f83395f90c9a899b0e639ba5acacfb8ae372b.zip | |
[ticket/11548] Run array_map on complete error array and not just colour_error
Up to now the array_map() that turns error messages into the localized output
was only ran if the group's color was set. With this patch it'll run the
array_map() on the complete error array if it's not empty.
PHPBB3-11548
| -rw-r--r-- | phpBB/includes/ucp/ucp_groups.php | 3 | ||||
| -rw-r--r-- | tests/functional/ucp_groups_test.php | 50 | 
2 files changed, 52 insertions, 1 deletions
| diff --git a/phpBB/includes/ucp/ucp_groups.php b/phpBB/includes/ucp/ucp_groups.php index 9365913541..663b5bc931 100644 --- a/phpBB/includes/ucp/ucp_groups.php +++ b/phpBB/includes/ucp/ucp_groups.php @@ -599,7 +599,7 @@ class ucp_groups  							if ($colour_error = validate_data($submit_ary, array('colour'	=> array('hex_colour', true))))  							{  								// Replace "error" string with its real, localised form -								$error = array_merge($error, array_map(array(&$user, 'lang'), $colour_error)); +								$error = array_merge($error, $colour_error);  							}  							if (!sizeof($error)) @@ -642,6 +642,7 @@ class ucp_groups  							if (sizeof($error))  							{ +								$error = array_map(array(&$user, 'lang'), $error);  								$group_rank = $submit_ary['rank'];  								$group_desc_data = array( diff --git a/tests/functional/ucp_groups_test.php b/tests/functional/ucp_groups_test.php index 9c6b1edc5e..7c50f7bb24 100644 --- a/tests/functional/ucp_groups_test.php +++ b/tests/functional/ucp_groups_test.php @@ -18,4 +18,54 @@ class phpbb_functional_ucp_groups_test extends phpbb_functional_common_groups_te  	{  		return 'ucp.php?i=groups&mode=manage&action=edit';  	} + +	// Enable all avatars in the ACP +	private function enable_all_avatars() +	{ +		$this->add_lang('acp/board'); + +		$crawler = $this->request('GET', 'adm/index.php?i=board&mode=avatar&sid=' . $this->sid); +		// Check the default entries we should have +		$this->assertContains($this->lang('ALLOW_REMOTE'), $crawler->text()); +		$this->assertContains($this->lang('ALLOW_AVATARS'), $crawler->text()); +		$this->assertContains($this->lang('ALLOW_LOCAL'), $crawler->text()); + +		// Now start setting the needed settings +		$form = $crawler->selectButton($this->lang('SUBMIT'))->form(); +		$form['config[allow_avatar_local]']->select(1); +		$form['config[allow_avatar_remote]']->select(1); +		$form['config[allow_avatar_remote_upload]']->select(1); +		$crawler = $this->client->submit($form); +		$this->assertContains($this->lang('CONFIG_UPDATED'), $crawler->text()); +	} + +	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'), +		); +	} + +	/** +	* @dataProvider group_avatar_min_max_data +	*/ +	public function test_group_avatar_min_max($form_name, $input, $expected) +	{ +		$this->login(); +		$this->admin_login(); +		$this->add_lang(array('ucp', 'acp/groups')); +		$this->enable_all_avatars(); + +		$crawler = $this->request('GET', $this->get_url() . '&g=5&sid=' . $this->sid); +		$this->assert_response_success(); +		$form = $crawler->selectButton($this->lang('SUBMIT'))->form(); +		$form[$form_name]->setValue($input); +		$crawler = $this->client->submit($form); +		$this->assertContains($this->lang($expected), $crawler->text()); +	}  } | 
