diff --git a/code/Model/EditableFormField/EditableNumericField.php b/code/Model/EditableFormField/EditableNumericField.php index 9916db9..2fae6e6 100755 --- a/code/Model/EditableFormField/EditableNumericField.php +++ b/code/Model/EditableFormField/EditableNumericField.php @@ -82,4 +82,15 @@ class EditableNumericField extends EditableFormField $field->setAttribute('data-rule-max', $this->MaxValue); } } + + public function validate() + { + $result = parent::validate(); + if ($this->MinValue > $this->MaxValue) { + $result->addError( + _t(__CLASS__ . '.ORDER_WARNING', 'Minimum length should be less than the maximum length.') + ); + } + return $result; + } } diff --git a/tests/Model/EditableFormField/EditableNumericFieldTest.php b/tests/Model/EditableFormField/EditableNumericFieldTest.php index 9b7b8e9..035649c 100644 --- a/tests/Model/EditableFormField/EditableNumericFieldTest.php +++ b/tests/Model/EditableFormField/EditableNumericFieldTest.php @@ -14,4 +14,27 @@ class EditableNumericFieldTest extends SapphireTest $field->Name = 'EditableFormField_123456'; $this->assertEmpty($field->getFormField()->Title()); } + + public function testValidateAddsErrorWhenMinValueIsGreaterThanMaxValue() + { + /** @var EditableNumericField $field */ + $field = EditableNumericField::create(); + $field->MinValue = 10; + $field->MaxValue = 5; + + $result = $field->validate(); + $this->assertFalse($result->isValid(), 'Validation should fail when min is greater than max'); + $this->assertContains('Minimum length should be less than the maximum length', $result->serialize()); + } + + public function testValidate() + { + /** @var EditableNumericField $field */ + $field = EditableNumericField::create(); + $field->MinValue = 5; + $field->MaxValue = 10; + + $result = $field->validate(); + $this->assertTrue($result->isValid()); + } }