Skip to content

Commit

Permalink
ENH Config to toggle allowing whitespace only in Requiredfields
Browse files Browse the repository at this point in the history
  • Loading branch information
emteknetnz committed Dec 3, 2024
1 parent 4d78f78 commit d20bce5
Show file tree
Hide file tree
Showing 2 changed files with 77 additions and 0 deletions.
8 changes: 8 additions & 0 deletions src/Forms/RequiredFields.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,10 @@
*/
class RequiredFields extends Validator
{
/**
* Whether to allow whitespace only as a valid value for a required fields
*/
private static bool $allow_whitespace_only = true;

/**
* List of required fields
Expand Down Expand Up @@ -122,6 +126,10 @@ public function php($data)
}
} else {
$stringValue = (string) $value;
if (!static::config()->get('allow_whitespace_only')) {
$stringValue = preg_replace('/^\s+/u', '', $stringValue);
$stringValue = preg_replace('/\s+$/u', '', $stringValue);
}
if (is_a($formField, HasOneRelationFieldInterface::class)) {
// test for blank string as well as '0' because older versions of silverstripe/admin FormBuilder
// forms created using redux-form would have a value of null for unsaved records
Expand Down
69 changes: 69 additions & 0 deletions tests/php/Forms/RequiredFieldsTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@
use SilverStripe\Forms\SearchableDropdownField;
use SilverStripe\Forms\TreeDropdownField;
use SilverStripe\Security\Group;
use SilverStripe\Forms\TextField;
use SilverStripe\Forms\FieldList;

class RequiredFieldsTest extends SapphireTest
{
Expand Down Expand Up @@ -322,4 +324,71 @@ public function testHasOneRelationFieldInterfaceValidation(string $className)
// '1' passes required field validation
$this->assertTrue($validator->php(['TestField' => '1']));
}

public static function provideAllowWhitespaceOnly(): array
{
return [
'no-ws' => [
'value' => 'abc',
'expectedTrue' => true,
'expectedFalse' => true,
],
'left-ws' => [
'value' => 'abc',
'expectedTrue' => true,
'expectedFalse' => true,
],
'right-ws' => [
'value' => 'abc',
'expectedTrue' => true,
'expectedFalse' => true,
],
'both-ws' => [
'value' => 'abc',
'expectedTrue' => true,
'expectedFalse' => true,
],
'only-ws' => [
'value' => ' ',
'expectedTrue' => true,
'expectedFalse' => false,
],
'only-ws-nbsp' => [
'value' => "\xc2\xa0",
'expectedTrue' => true,
'expectedFalse' => false,
],
'only-ws-unicode' => [
// zero width no-break space
'value' => "\u{2028}",
'expectedTrue' => true,
'expectedFalse' => false,
],
'no-value' => [
'value' => '',
'expectedTrue' => false,
'expectedFalse' => false,
],
];
}

/**
* @dataProvider provideAllowWhitespaceOnly
*/
public function testAllowWhitespaceOnly(string $value, bool $expectedTrue, bool $expectedFalse): void
{
$validator = new RequiredFields(['TestField']);
$field = new TextField('TestField');
$field->setValue($value);
$form = new Form(null, null, new FieldList([$field]), null, $validator);
$expecteds = [
true => $expectedTrue,
false => $expectedFalse,
];
foreach ($expecteds as $bool => $expected) {
RequiredFields::config()->set('allow_whitespace_only', $bool);
$result = $validator->validate($form);
$this->assertEquals($expected, $result->isValid(), $bool);
}
}
}

0 comments on commit d20bce5

Please sign in to comment.