mirror of
https://github.com/phpbb/phpbb.git
synced 2025-05-02 13:47:55 +02:00
[ticket/9040] Count HTML entities as single in custom profile fields
Currently when an user adds a HTML entity to a custom profile field, the length gets incremented by 4 since the code reads > instead of <. However, the length is presentational and not DB storage so it should be treated as a single character even if it takes four lengths in the DB by being stored as a HTML entity. Work around this by decoding html entities before counting. Also, added unit tests for string field type PHPBB3-9040
This commit is contained in:
parent
f9438bcbf7
commit
403ab49716
@ -65,7 +65,7 @@ abstract class type_string_common extends type_base
|
||||
{
|
||||
return $this->user->lang('FIELD_TOO_SHORT', (int) $field_data['field_minlen'], $this->get_field_name($field_data['lang_name']));
|
||||
}
|
||||
else if ($field_data['field_maxlen'] && utf8_strlen($field_value) > $field_data['field_maxlen'])
|
||||
else if ($field_data['field_maxlen'] && utf8_strlen(html_entity_decode($field_value)) > $field_data['field_maxlen'])
|
||||
{
|
||||
return $this->user->lang('FIELD_TOO_LONG', (int) $field_data['field_maxlen'], $this->get_field_name($field_data['lang_name']));
|
||||
}
|
||||
|
117
tests/profile/custom_string_test.php
Normal file
117
tests/profile/custom_string_test.php
Normal file
@ -0,0 +1,117 @@
|
||||
<?php
|
||||
/**
|
||||
*
|
||||
* @package testing
|
||||
* @copyright (c) 2011 phpBB Group
|
||||
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
||||
*
|
||||
*/
|
||||
|
||||
require_once dirname(__FILE__) . '/../../phpBB/includes/utf/utf_tools.php';
|
||||
|
||||
class phpbb_profile_custom_string_test extends phpbb_database_test_case
|
||||
{
|
||||
public function getDataSet()
|
||||
{
|
||||
return $this->createXMLDataSet(dirname(__FILE__) . '/fixtures/profile_fields.xml');
|
||||
}
|
||||
|
||||
static public function string_fields()
|
||||
{
|
||||
return array(
|
||||
// note, there is an offset of 1 between option_id (0-indexed)
|
||||
// in the database and values (1-indexed) to avoid problems with
|
||||
// transmitting 0 in an HTML form
|
||||
// required, value, validation, expected, description
|
||||
array(
|
||||
1,
|
||||
'H3110',
|
||||
'[0-9]+',
|
||||
'FIELD_INVALID_CHARS_NUMBERS_ONLY-field',
|
||||
'Required field should reject characters in a numbers-only field'
|
||||
),
|
||||
array(
|
||||
1,
|
||||
'This string is too long',
|
||||
'.*',
|
||||
'FIELD_TOO_LONG-10-field',
|
||||
'Required field should reject a field too long'
|
||||
),
|
||||
array(
|
||||
0,
|
||||
'<>"&%&><>',
|
||||
'.*',
|
||||
false,
|
||||
'Optional field should accept html entities'
|
||||
),
|
||||
array(
|
||||
1,
|
||||
'ö ä ü ß',
|
||||
'.*',
|
||||
false,
|
||||
'Required field should accept UTF-8 string'
|
||||
),
|
||||
array(
|
||||
1,
|
||||
'This ö ä string has to b',
|
||||
'.*',
|
||||
'FIELD_TOO_LONG-10-field',
|
||||
'Required field should reject an UTF-8 string which is too long'
|
||||
),
|
||||
array(
|
||||
1,
|
||||
'ö äö äö ä',
|
||||
'[\w]+',
|
||||
'FIELD_INVALID_CHARS_ALPHA_ONLY-field',
|
||||
'Required field should reject UTF-8 in alpha only field'
|
||||
),
|
||||
array(
|
||||
1,
|
||||
'Hello',
|
||||
'[\w]+',
|
||||
false,
|
||||
'Required field should accept a characters only field'
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider string_fields
|
||||
*/
|
||||
public function test_string_validate($field_required, $field_value, $field_validation, $expected, $description)
|
||||
{
|
||||
global $db;
|
||||
$db = $this->new_dbal();
|
||||
|
||||
$field_data = array(
|
||||
'field_id' => 1,
|
||||
'lang_id' => 1,
|
||||
'lang_name' => 'field',
|
||||
'field_novalue' => 1,
|
||||
'field_required' => $field_required,
|
||||
'field_maxlen' => 10,
|
||||
'field_validation' => $field_validation,
|
||||
);
|
||||
$user = $this->getMock('\phpbb\user');
|
||||
$user->expects($this->any())
|
||||
->method('lang')
|
||||
->will($this->returnCallback(array($this, 'return_callback_implode')));
|
||||
|
||||
$request = $this->getMock('\phpbb\request\request');
|
||||
$template = $this->getMock('\phpbb\template\template');
|
||||
|
||||
$cp = new \phpbb\profilefields\type\type_string(
|
||||
$request,
|
||||
$template,
|
||||
$user
|
||||
);
|
||||
$result = $cp->validate_profile_field($field_value, $field_data);
|
||||
|
||||
$this->assertEquals($expected, $result, $description);
|
||||
}
|
||||
|
||||
public function return_callback_implode()
|
||||
{
|
||||
return implode('-', func_get_args());
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user