Compare commits

..

2 Commits

Author SHA1 Message Date
Steve Boyd
a380d7f758
Merge b052f45a802a5fc40cc8d5bb3d8557284d101894 into 6bb9a0b33d4ceab145a7effc2e4ce16d6eedc877 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);
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);
if (!is_null($this->minLength) && $len < $this->minLength) {
$message = _t(

View File

@ -30,7 +30,7 @@ class DBDecimal extends DBField
/**
* 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->decimalSize = is_int($decimalSize) ? $decimalSize : 2;
@ -113,23 +113,23 @@ class DBDecimal extends DBField
public function nullValue(): int
{
return 0.0;
return 0;
}
public function prepValueForDB(mixed $value): array|float|int|null
{
if ($value === true) {
return 1.0;
return 1;
}
if (empty($value) || !is_numeric($value)) {
return 0.0;
return 0;
}
if (abs((float) $value - (int) $value) < PHP_FLOAT_EPSILON) {
return (int) $value;
return (int)$value;
}
return (float) $value;
return (float)$value;
}
}

View File

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