Compare commits

..

2 Commits

Author SHA1 Message Date
Steve Boyd
4d5a5a15a2
Merge a8c3aa39b00b95bc6594e481a5fbe861ae49ed88 into 6bb9a0b33d4ceab145a7effc2e4ce16d6eedc877 2024-10-15 05:24:42 +00:00
Steve Boyd
a8c3aa39b0 NEW Validate DBFields 2024-10-15 18:24:34 +13:00
3 changed files with 13 additions and 18 deletions

View File

@ -43,11 +43,6 @@ 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) public function __construct(?string $name = null, ?int $wholeSize = 9, ?int $decimalSize = 2, float|int $defaultValue = 0.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; return 0.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; return 1.0;
} }
if (empty($value) || !is_numeric($value)) { if (empty($value) || !is_numeric($value)) {
return 0; return 0.0;
} }
if (abs((float) $value - (int) $value) < PHP_FLOAT_EPSILON) { if (abs((float) $value - (int) $value) < PHP_FLOAT_EPSILON) {

View File

@ -26,13 +26,6 @@ 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,
@ -75,6 +68,13 @@ 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,