aboutsummaryrefslogtreecommitdiffstats
path: root/server/src/test
diff options
context:
space:
mode:
authorTatu Lund <tatu@vaadin.com>2021-10-27 20:14:29 +0300
committerGitHub <noreply@github.com>2021-10-27 20:14:29 +0300
commit5cbc384fb2514546e4fc1f55b4516b381d2ae194 (patch)
treedec52fe906ed1bafcaf07d20e7ea5c47490b8333 /server/src/test
parentfbbb689925274e0af49df14c5ac05a12759fae31 (diff)
downloadvaadin-framework-5cbc384fb2514546e4fc1f55b4516b381d2ae194.tar.gz
vaadin-framework-5cbc384fb2514546e4fc1f55b4516b381d2ae194.zip
fix: avoid ConcurrentModificationException in Binder (#12458)
Diffstat (limited to 'server/src/test')
-rw-r--r--server/src/test/java/com/vaadin/data/BinderTest.java23
1 files changed, 23 insertions, 0 deletions
diff --git a/server/src/test/java/com/vaadin/data/BinderTest.java b/server/src/test/java/com/vaadin/data/BinderTest.java
index 9f20f0b246..999142a440 100644
--- a/server/src/test/java/com/vaadin/data/BinderTest.java
+++ b/server/src/test/java/com/vaadin/data/BinderTest.java
@@ -1542,6 +1542,29 @@ public class BinderTest extends BinderTestBase<Binder<Person>, Person> {
}
@Test
+ public void invalidUsage_modifyFieldsInsideValidator_binderDoesNotThrow() {
+ TextField field = new TextField();
+
+ AtomicBoolean validatorIsExecuted = new AtomicBoolean();
+ binder.forField(field).asRequired().withValidator((val, context) -> {
+ nameField.setValue("foo");
+ ageField.setValue("bar");
+ validatorIsExecuted.set(true);
+ return ValidationResult.ok();
+ }).bind(Person::getEmail, Person::setEmail);
+
+ binder.forField(nameField).bind(Person::getFirstName,
+ Person::setFirstName);
+ binder.forField(ageField).bind(Person::getLastName,
+ Person::setLastName);
+
+ binder.setBean(new Person());
+
+ field.setValue("baz");
+ // mostly self control, the main check is: not exception is thrown
+ assertTrue(validatorIsExecuted.get());
+ }
+
public void setBean_readOnlyBinding_propertyBinding_valueIsNotUpdated() {
Binder<ExampleBean> binder = new Binder<>(ExampleBean.class);