aboutsummaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorschaerl <luki.schaer@hispeed.ch>2017-11-22 06:26:57 +0100
committercaalador <mikael.grankvist@gmail.com>2017-11-22 07:26:57 +0200
commit3569a33239693461d588dbfd1005730943118702 (patch)
tree3f1842ba0f18e7f7cb6229b74e54ef957e1e2309 /server
parentc6f5c583ada3edefa53a94c9ec72bc8c5721249d (diff)
downloadvaadin-framework-3569a33239693461d588dbfd1005730943118702.tar.gz
vaadin-framework-3569a33239693461d588dbfd1005730943118702.zip
Fix nested bean property name (#10271)
* Changed retrieval of names of nested properties (#10159) The getName() function in NestedBeanPropertyDefinition will return only the top level name, which causes problems when adding a nested property that has the same name as a non-nested (e.g "value" & "sub.value") This change should fix this behaviour by changing the return value of "getName()" of NestedBeanPropertyDefinition and introducing a function "getTopLevelName()" that only returns the last part of the full name for where it's needed
Diffstat (limited to 'server')
-rw-r--r--server/src/main/java/com/vaadin/data/BeanPropertySet.java50
-rw-r--r--server/src/main/java/com/vaadin/data/BeanValidationBinder.java4
-rw-r--r--server/src/main/java/com/vaadin/data/PropertyDefinition.java9
-rw-r--r--server/src/test/java/com/vaadin/data/NestedPropertyNameTest.java48
4 files changed, 72 insertions, 39 deletions
diff --git a/server/src/main/java/com/vaadin/data/BeanPropertySet.java b/server/src/main/java/com/vaadin/data/BeanPropertySet.java
index b302c83709..b877fdf939 100644
--- a/server/src/main/java/com/vaadin/data/BeanPropertySet.java
+++ b/server/src/main/java/com/vaadin/data/BeanPropertySet.java
@@ -170,37 +170,13 @@ public class BeanPropertySet<T> implements PropertySet<T> {
private final PropertyDefinition<T, ?> parent;
- private boolean useLongFormName = false;
-
public NestedBeanPropertyDefinition(BeanPropertySet<T> propertySet,
PropertyDefinition<T, ?> parent,
PropertyDescriptor descriptor) {
super(propertySet, parent.getType(), descriptor);
this.parent = parent;
}
-
- /**
- * Create nested property definition. Allows use of a long form name.
- *
- * @param propertySet
- * property set this property belongs to
- * @param parent
- * parent property for this nested property
- * @param descriptor
- * property descriptor
- * @param useLongFormName
- * use format grandparent.parent.property for name if
- * {@code true}, needed when creating nested definitions
- * recursively like in findNestedDefinitions
- * @since 8.2
- */
- public NestedBeanPropertyDefinition(BeanPropertySet<T> propertySet,
- PropertyDefinition<T, ?> parent, PropertyDescriptor descriptor,
- boolean useLongFormName) {
- this(propertySet, parent, descriptor);
- this.useLongFormName = useLongFormName;
- }
-
+
@Override
public ValueProvider<T, V> getGetter() {
return bean -> {
@@ -229,6 +205,16 @@ public class BeanPropertySet<T> implements PropertySet<T> {
return Optional.of(setter);
}
+ @Override
+ public String getName() {
+ return parent.getName() + "." + super.getName();
+ }
+
+ @Override
+ public String getTopLevelName() {
+ return super.getName();
+ }
+
private Object writeReplace() {
/*
* Instead of serializing this actual property definition, only
@@ -236,8 +222,9 @@ public class BeanPropertySet<T> implements PropertySet<T> {
* property definition from the cache.
*/
return new SerializedPropertyDefinition(getPropertySet().beanType,
- parent.getName() + "." + super.getName());
+ getName());
}
+
/**
* Gets the parent property definition.
@@ -247,15 +234,6 @@ public class BeanPropertySet<T> implements PropertySet<T> {
public PropertyDefinition<T, ?> getParent() {
return parent;
}
-
- @Override
- public String getName() {
- if (useLongFormName) {
- return parent.getName() + "." + super.getName();
- }
- return super.getName();
- }
-
}
/**
@@ -394,7 +372,7 @@ public class BeanPropertySet<T> implements PropertySet<T> {
PropertyDescriptor subDescriptor = BeanUtil
.getPropertyDescriptor(beanType, name);
moreProps.put(name, new NestedBeanPropertyDefinition<>(this,
- parentProperty, subDescriptor, true));
+ parentProperty, subDescriptor));
}
} catch (IntrospectionException e) {
diff --git a/server/src/main/java/com/vaadin/data/BeanValidationBinder.java b/server/src/main/java/com/vaadin/data/BeanValidationBinder.java
index c358d64ae6..630eef15b7 100644
--- a/server/src/main/java/com/vaadin/data/BeanValidationBinder.java
+++ b/server/src/main/java/com/vaadin/data/BeanValidationBinder.java
@@ -96,7 +96,7 @@ public class BeanValidationBinder<BEAN> extends Binder<BEAN> {
PropertyDefinition<BEAN, ?> definition) {
Class<?> actualBeanType = findBeanType(beanType, definition);
BeanValidator validator = new BeanValidator(actualBeanType,
- definition.getName());
+ definition.getTopLevelName());
if (requiredConfigurator != null) {
configureRequired(binding, definition, validator);
}
@@ -132,7 +132,7 @@ public class BeanValidationBinder<BEAN> extends Binder<BEAN> {
BeanDescriptor descriptor = validator.getJavaxBeanValidator()
.getConstraintsForClass(propertyHolderType);
PropertyDescriptor propertyDescriptor = descriptor
- .getConstraintsForProperty(definition.getName());
+ .getConstraintsForProperty(definition.getTopLevelName());
if (propertyDescriptor == null) {
return;
}
diff --git a/server/src/main/java/com/vaadin/data/PropertyDefinition.java b/server/src/main/java/com/vaadin/data/PropertyDefinition.java
index 06252f8a74..68be55a48b 100644
--- a/server/src/main/java/com/vaadin/data/PropertyDefinition.java
+++ b/server/src/main/java/com/vaadin/data/PropertyDefinition.java
@@ -64,13 +64,20 @@ public interface PropertyDefinition<T, V> extends Serializable {
public Class<?> getPropertyHolderType();
/**
- * Gets the name of this property.
+ * Gets the full name of this property.
*
* @return the property name, not <code>null</code>
*/
public String getName();
/**
+ * Gets the top level name of this property
+ *
+ * @return the top level property name, not <code>null</code>
+ */
+ public default String getTopLevelName() {return getName();}
+
+ /**
* Gets the human readable caption to show for this property.
*
* @return the caption to show, not <code>null</code>
diff --git a/server/src/test/java/com/vaadin/data/NestedPropertyNameTest.java b/server/src/test/java/com/vaadin/data/NestedPropertyNameTest.java
new file mode 100644
index 0000000000..070a3de40a
--- /dev/null
+++ b/server/src/test/java/com/vaadin/data/NestedPropertyNameTest.java
@@ -0,0 +1,48 @@
+package com.vaadin.data;
+
+import org.junit.Test;
+
+import com.vaadin.ui.Grid;
+
+public class NestedPropertyNameTest {
+
+ @Test
+ public void nestedProperty_sameNameCanBeAdded() {
+ Grid<Person> grid = new Grid<>(Person.class);
+ grid.addColumn("street.name");
+ }
+
+ private class Person{
+ String name;
+ Street street;
+
+ public String getName() {
+ return name;
+ }
+
+ public void setName(String name) {
+ this.name = name;
+ }
+
+ public Street getStreet() {
+ return street;
+ }
+
+ public void setStreet(Street street) {
+ this.street = street;
+ }
+
+ }
+
+ private class Street{
+ String name;
+
+ public String getName() {
+ return name;
+ }
+
+ public void setName(String name) {
+ this.name = name;
+ }
+ }
+}