diff options
author | Shitiz Garg <mail@dragooon.net> | 2014-03-17 15:54:28 +0530 |
---|---|---|
committer | Shitiz Garg <mail@dragooon.net> | 2014-03-17 17:35:30 +0530 |
commit | 403ab49716c8bc7d93fc33bbf810e0814e3de049 (patch) | |
tree | cb175a96bbdca12c79be18e02946db9605e39729 /tests/profile | |
parent | f9438bcbf700b9d237791390c0ec6aca461e8fd7 (diff) | |
download | forums-403ab49716c8bc7d93fc33bbf810e0814e3de049.tar forums-403ab49716c8bc7d93fc33bbf810e0814e3de049.tar.gz forums-403ab49716c8bc7d93fc33bbf810e0814e3de049.tar.bz2 forums-403ab49716c8bc7d93fc33bbf810e0814e3de049.tar.xz forums-403ab49716c8bc7d93fc33bbf810e0814e3de049.zip |
[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
Diffstat (limited to 'tests/profile')
-rw-r--r-- | tests/profile/custom_string_test.php | 117 |
1 files changed, 117 insertions, 0 deletions
diff --git a/tests/profile/custom_string_test.php b/tests/profile/custom_string_test.php new file mode 100644 index 0000000000..38a01f4e5a --- /dev/null +++ b/tests/profile/custom_string_test.php @@ -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()); + } +} |