Compare commits

..

2 Commits

Author SHA1 Message Date
Steve Boyd
a380d7f758
Merge b052f45a80 into 6bb9a0b33d 2024-10-15 02:48:16 +00:00
Steve Boyd
b052f45a80 NEW Validate DBFields 2024-10-15 15:48:10 +13:00
3 changed files with 18 additions and 13 deletions

View File

@ -43,6 +43,11 @@ class StringFieldValidator extends FieldValidator
$result->addFieldError($this->name, $message, value: $this->value); $result->addFieldError($this->name, $message, value: $this->value);
return $result; return $result;
} }
// TODO this seems non-sensical - should enforce minLength??
// Blank strings are valid, even if there's a minLength requirement
if ($this->value === '') {
return $result;
}
$len = mb_strlen($this->value); $len = mb_strlen($this->value);
if (!is_null($this->minLength) && $len < $this->minLength) { if (!is_null($this->minLength) && $len < $this->minLength) {
$message = _t( $message = _t(

View File

@ -30,7 +30,7 @@ class DBDecimal extends DBField
/** /**
* Create a new Decimal field. * Create a new Decimal field.
*/ */
public function __construct(?string $name = null, ?int $wholeSize = 9, ?int $decimalSize = 2, float|int $defaultValue = 0.0) public function __construct(?string $name = null, ?int $wholeSize = 9, ?int $decimalSize = 2, float|int $defaultValue = 0)
{ {
$this->wholeSize = is_int($wholeSize) ? $wholeSize : 9; $this->wholeSize = is_int($wholeSize) ? $wholeSize : 9;
$this->decimalSize = is_int($decimalSize) ? $decimalSize : 2; $this->decimalSize = is_int($decimalSize) ? $decimalSize : 2;
@ -113,17 +113,17 @@ class DBDecimal extends DBField
public function nullValue(): int public function nullValue(): int
{ {
return 0.0; return 0;
} }
public function prepValueForDB(mixed $value): array|float|int|null public function prepValueForDB(mixed $value): array|float|int|null
{ {
if ($value === true) { if ($value === true) {
return 1.0; return 1;
} }
if (empty($value) || !is_numeric($value)) { if (empty($value) || !is_numeric($value)) {
return 0.0; return 0;
} }
if (abs((float) $value - (int) $value) < PHP_FLOAT_EPSILON) { if (abs((float) $value - (int) $value) < PHP_FLOAT_EPSILON) {

View File

@ -26,6 +26,13 @@ class StringFieldValidatorTest extends SapphireTest
'exception' => false, 'exception' => false,
'expected' => true, 'expected' => true,
], ],
'valid-blank-when-min' => [
'value' => '',
'minLength' => 5,
'maxLength' => null,
'exception' => false,
'expected' => true,
],
'valid-max' => [ 'valid-max' => [
'value' => 'fish', 'value' => 'fish',
'minLength' => 0, 'minLength' => 0,
@ -68,13 +75,6 @@ class StringFieldValidatorTest extends SapphireTest
'exception' => false, 'exception' => false,
'expected' => false, 'expected' => false,
], ],
'invalid-blank-with-min' => [
'value' => '',
'minLength' => 5,
'maxLength' => null,
'exception' => false,
'expected' => false,
],
'invalid-above-min' => [ 'invalid-above-min' => [
'value' => 'fish', 'value' => 'fish',
'minLength' => 0, 'minLength' => 0,