Merge pull request #10931 from tjbwsk/4.13

added missing maxLength validation
This commit is contained in:
Sabina Talipova 2023-08-31 08:45:10 +12:00 committed by GitHub
commit c5be3fc487
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 60 additions and 1 deletions

View File

@ -152,7 +152,6 @@ class TextareaField extends FormField
return $attributes; return $attributes;
} }
/** /**
* {@inheritdoc} * {@inheritdoc}
*/ */
@ -167,6 +166,41 @@ class TextareaField extends FormField
return $parent; return $parent;
} }
/**
* Validate this field
*
* @param Validator $validator
* @return bool
*/
public function validate($validator)
{
if (!is_null($this->maxLength) && mb_strlen($this->value ?? '') > $this->maxLength) {
$name = strip_tags($this->Title() ? $this->Title() : $this->getName());
$validator->validationError(
$this->name,
_t(
'SilverStripe\\Forms\\TextField.VALIDATEMAXLENGTH',
'The value for {name} must not exceed {maxLength} characters in length',
['name' => $name, 'maxLength' => $this->maxLength]
),
"validation"
);
return false;
}
return true;
}
public function getSchemaValidation()
{
$rules = parent::getSchemaValidation();
if ($this->getMaxLength()) {
$rules['max'] = [
'length' => $this->getMaxLength(),
];
}
return $rules;
}
/** /**
* Return value with all values encoded in html entities * Return value with all values encoded in html entities
* *

View File

@ -4,6 +4,7 @@ namespace SilverStripe\Forms\Tests;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\Forms\TextareaField; use SilverStripe\Forms\TextareaField;
use SilverStripe\Forms\RequiredFields;
class TextareaFieldTest extends SapphireTest class TextareaFieldTest extends SapphireTest
{ {
@ -50,6 +51,30 @@ class TextareaFieldTest extends SapphireTest
); );
} }
/**
* Tests the TextareaField Max Length Validation Failure
*/
public function testMaxLengthValidationFail()
{
$field = new TextareaField("Test", "Test");
$field->setMaxLength(5);
$field->setValue("John Doe"); // 8 characters, so should fail
$result = $field->validate(new RequiredFields());
$this->assertFalse($result);
}
/**
* Tests the TextareaField Max Length Validation Success
*/
public function testMaxLengthValidationSuccess()
{
$field = new TextareaField("Test", "Test");
$field->setMaxLength(5);
$field->setValue("John"); // 4 characters, so should pass
$result = $field->validate(new RequiredFields());
$this->assertTrue($result);
}
public function testValueEntities() public function testValueEntities()
{ {
$inputText = "These <b>are</b> some unicodes: äöü"; $inputText = "These <b>are</b> some unicodes: äöü";