aboutsummaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorTatu Lund <tatu@vaadin.com>2020-04-08 12:17:11 +0300
committerGitHub <noreply@github.com>2020-04-08 12:17:11 +0300
commita486f6480979e93812cb1236e89e41d03f79d448 (patch)
treea271c0dfcbb6ba3be88553ca1ca77baf400b5840 /server
parent368f350c98053f75a317c3430929e9eb0a388f23 (diff)
downloadvaadin-framework-a486f6480979e93812cb1236e89e41d03f79d448.tar.gz
vaadin-framework-a486f6480979e93812cb1236e89e41d03f79d448.zip
Set DateField value only if it passes range check (#11887)
Fixes #11108
Diffstat (limited to 'server')
-rw-r--r--server/src/main/java/com/vaadin/ui/AbstractDateField.java51
-rw-r--r--server/src/test/java/com/vaadin/ui/DateFieldTestCase.java13
2 files changed, 45 insertions, 19 deletions
diff --git a/server/src/main/java/com/vaadin/ui/AbstractDateField.java b/server/src/main/java/com/vaadin/ui/AbstractDateField.java
index c252655e44..9c5d9bb656 100644
--- a/server/src/main/java/com/vaadin/ui/AbstractDateField.java
+++ b/server/src/main/java/com/vaadin/ui/AbstractDateField.java
@@ -297,7 +297,10 @@ public abstract class AbstractDateField<T extends Temporal & TemporalAdjuster &
* validate. If {@code startDate} is set to {@code null}, any value before
* {@code endDate} will be accepted by the range
* <p>
- * Note: Negative, i.e. BC dates are not supported
+ * Note: Negative, i.e. BC dates are not supported.
+ * <p>
+ * Note: It's usually recommended to use only one of the following at the same
+ * time: Range validator with Binder or DateField's setRangeStart check.
*
* @param startDate
* - the allowed range's start date
@@ -359,6 +362,9 @@ public abstract class AbstractDateField<T extends Temporal & TemporalAdjuster &
* date (taking the resolution into account), the component will not
* validate. If {@code endDate} is set to {@code null}, any value after
* {@code startDate} will be accepted by the range.
+ * <p>
+ * Note: It's usually recommended to use only one of the following at the same
+ * time: Range validator with Binder or DateField's setRangeEnd check.
*
* @param endDate
* the allowed range's end date (inclusive, based on the current
@@ -618,27 +624,38 @@ public abstract class AbstractDateField<T extends Temporal & TemporalAdjuster &
*
* @param value
* the new value, may be {@code null}
+ * @throws IllegalArgumentException
+ * if the value is not within range bounds
*/
@Override
public void setValue(T value) {
- currentErrorMessage = null;
- /*
- * First handle special case when the client side component have a date
- * string but value is null (e.g. unparsable date string typed in by the
- * user). No value changes should happen, but we need to do some
- * internal housekeeping.
- */
- if (value == null && !getState(false).parsable) {
+ RangeValidator<T> validator = getRangeValidator();
+ ValidationResult result = validator.apply(value,
+ new ValueContext(this, this));
+
+ if (result.isError()) {
+ throw new IllegalArgumentException(
+ "value is not within acceptable range");
+ } else {
+ currentErrorMessage = null;
/*
- * Side-effects of doSetValue clears possible previous strings and
- * flags about invalid input.
+ * First handle special case when the client side component has a date
+ * string but value is null (e.g. unparsable date string typed in by the
+ * user). No value changes should happen, but we need to do some
+ * internal housekeeping.
*/
- doSetValue(null);
-
- markAsDirty();
- return;
+ if (value == null && !getState(false).parsable) {
+ /*
+ * Side-effects of doSetValue clears possible previous strings and
+ * flags about invalid input.
+ */
+ doSetValue(null);
+
+ markAsDirty();
+ return;
+ }
+ super.setValue(value);
}
- super.setValue(value);
}
/**
@@ -785,8 +802,8 @@ public abstract class AbstractDateField<T extends Temporal & TemporalAdjuster &
@Override
protected void doSetValue(T value) {
- this.value = value;
// Also set the internal dateString
+ this.value = value;
if (value == null) {
value = getEmptyValue();
}
diff --git a/server/src/test/java/com/vaadin/ui/DateFieldTestCase.java b/server/src/test/java/com/vaadin/ui/DateFieldTestCase.java
index f50141df66..026388d623 100644
--- a/server/src/test/java/com/vaadin/ui/DateFieldTestCase.java
+++ b/server/src/test/java/com/vaadin/ui/DateFieldTestCase.java
@@ -10,12 +10,17 @@ import java.time.LocalDate;
import org.junit.Before;
import org.junit.Test;
+import org.junit.Rule;
+import org.junit.rules.ExpectedException;
public class DateFieldTestCase {
private AbstractLocalDateField dateField;
private LocalDate date;
+ @Rule
+ public transient ExpectedException exceptionRule = ExpectedException.none();
+
@Before
public void setup() {
dateField = new AbstractLocalDateField() {
@@ -39,9 +44,11 @@ public class DateFieldTestCase {
@Test
public void belowRangeStartIsNotAcceptedAsValue() {
+ LocalDate currentDate = dateField.getValue();
dateField.setRangeStart(date);
+ exceptionRule.expect(IllegalArgumentException.class);
dateField.setValue(date.minusDays(1));
- assertNotNull(dateField.getComponentError());
+ assertThat(dateField.getValue(), is(currentDate));
}
@Test
@@ -60,8 +67,10 @@ public class DateFieldTestCase {
@Test
public void aboveRangeEndIsNotAcceptedAsValue() {
+ LocalDate currentDate = dateField.getValue();
dateField.setRangeEnd(date);
+ exceptionRule.expect(IllegalArgumentException.class);
dateField.setValue(date.plusDays(1));
- assertNotNull(dateField.getComponentError());
+ assertThat(dateField.getValue(), is(currentDate));
}
}