summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2015-10-01 21:05:29 +0300
committerTeemu Suo-Anttila <teemusa@vaadin.com>2015-10-19 13:23:42 +0300
commit32894becb285c53a92227462101968ae5b85e694 (patch)
tree24a07df9e9386e50285d71a5f9d3e1d6a0d9b633
parentaf30540ddac9798eec5e326b1e72c56dacd7dd21 (diff)
downloadvaadin-framework-32894becb285c53a92227462101968ae5b85e694.tar.gz
vaadin-framework-32894becb285c53a92227462101968ae5b85e694.zip
Do not use getters/setters when mapping designer fields (#17388)
Change-Id: Id64193a109667286127038eb1c9dfd47697247be
-rw-r--r--server/src/com/vaadin/ui/declarative/FieldBinder.java23
-rw-r--r--server/tests/src/com/vaadin/tests/design/FieldNameWhichConflictsWithGettersTest.java82
-rw-r--r--server/tests/src/com/vaadin/tests/design/MyVerticalLayout.html4
3 files changed, 98 insertions, 11 deletions
diff --git a/server/src/com/vaadin/ui/declarative/FieldBinder.java b/server/src/com/vaadin/ui/declarative/FieldBinder.java
index 577e9f5515..3766458175 100644
--- a/server/src/com/vaadin/ui/declarative/FieldBinder.java
+++ b/server/src/com/vaadin/ui/declarative/FieldBinder.java
@@ -18,7 +18,6 @@ package com.vaadin.ui.declarative;
import java.beans.IntrospectionException;
import java.io.Serializable;
import java.lang.reflect.Field;
-import java.lang.reflect.InvocationTargetException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
@@ -28,7 +27,6 @@ import java.util.Map;
import java.util.logging.Logger;
import com.vaadin.ui.Component;
-import com.vaadin.util.ReflectTools;
/**
* Binder utility that binds member fields of a design class instance to given
@@ -84,7 +82,7 @@ public class FieldBinder implements Serializable {
List<String> unboundFields = new ArrayList<String>();
for (Field f : fieldMap.values()) {
try {
- Object value = ReflectTools.getJavaFieldValue(bindTarget, f);
+ Object value = getFieldValue(bindTarget, f);
if (value == null) {
unboundFields.add(f.getName());
}
@@ -92,8 +90,6 @@ public class FieldBinder implements Serializable {
throw new FieldBindingException("Could not get field value", e);
} catch (IllegalAccessException e) {
throw new FieldBindingException("Could not get field value", e);
- } catch (InvocationTargetException e) {
- throw new FieldBindingException("Could not get field value", e);
}
}
if (unboundFields.size() > 0) {
@@ -192,15 +188,14 @@ public class FieldBinder implements Serializable {
return false;
}
// validate that the field is not set
- Object fieldValue = ReflectTools.getJavaFieldValue(bindTarget,
- field);
+ Object fieldValue = getFieldValue(bindTarget, field);
if (fieldValue != null) {
getLogger().fine(
"The field \"" + fieldName
+ "\" was already mapped. Ignoring.");
} else {
// set the field value
- ReflectTools.setJavaFieldValue(bindTarget, field, instance);
+ field.set(bindTarget, instance);
}
return true;
} catch (IllegalAccessException e) {
@@ -209,12 +204,18 @@ public class FieldBinder implements Serializable {
} catch (IllegalArgumentException e) {
throw new FieldBindingException("Field binding failed for "
+ identifier, e);
- } catch (InvocationTargetException e) {
- throw new FieldBindingException("Field binding failed for "
- + identifier, e);
}
}
+ private Object getFieldValue(Object object, Field field)
+ throws IllegalArgumentException, IllegalAccessException {
+ if (!field.isAccessible()) {
+ field.setAccessible(true);
+ }
+
+ return field.get(object);
+ }
+
/**
* Converts the given identifier to a valid field name by stripping away
* illegal character and setting the first letter of the name to lower case.
diff --git a/server/tests/src/com/vaadin/tests/design/FieldNameWhichConflictsWithGettersTest.java b/server/tests/src/com/vaadin/tests/design/FieldNameWhichConflictsWithGettersTest.java
new file mode 100644
index 0000000000..e5e2eb3fce
--- /dev/null
+++ b/server/tests/src/com/vaadin/tests/design/FieldNameWhichConflictsWithGettersTest.java
@@ -0,0 +1,82 @@
+/*
+ * Copyright 2000-2014 Vaadin Ltd.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
+ * use this file except in compliance with the License. You may obtain a copy of
+ * the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations under
+ * the License.
+ */
+package com.vaadin.tests.design;
+
+import java.io.ByteArrayOutputStream;
+import java.io.IOException;
+
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+import org.jsoup.nodes.Element;
+import org.junit.Assert;
+import org.junit.Test;
+
+import com.vaadin.annotations.DesignRoot;
+import com.vaadin.ui.Label;
+import com.vaadin.ui.TextField;
+import com.vaadin.ui.VerticalLayout;
+import com.vaadin.ui.declarative.Design;
+import com.vaadin.ui.declarative.DesignContext;
+
+public class FieldNameWhichConflictsWithGettersTest {
+
+ @DesignRoot("MyVerticalLayout.html")
+ public static class MyVerticalLayout extends VerticalLayout {
+ private Label caption;
+ private TextField description;
+
+ public MyVerticalLayout() {
+ Design.read(this);
+ }
+ }
+
+ @Test
+ public void readWithConflictingFields() {
+ MyVerticalLayout v = new MyVerticalLayout();
+ Assert.assertNotNull(v.caption);
+ Assert.assertNotNull(v.description);
+ }
+
+ @Test
+ public void writeWithConflictingFields() throws IOException {
+ VerticalLayout v = new VerticalLayout();
+ Label l = new Label();
+ l.setId("caption");
+ TextField tf = new TextField();
+ v.addComponents(l, tf);
+
+ ByteArrayOutputStream baos = new ByteArrayOutputStream();
+
+ DesignContext context = new DesignContext();
+ context.setComponentLocalId(tf, "description");
+ context.setRootComponent(v);
+
+ Design.write(context, baos);
+ String str = baos.toString("UTF-8");
+
+ Document doc = Jsoup.parse(str);
+ Element body = doc.body();
+ Element captionElement = body.getElementById("caption");
+ Assert.assertNotNull(captionElement);
+ Assert.assertEquals("v-label", captionElement.tagName());
+
+ Element descriptionElement = captionElement.nextElementSibling();
+ Assert.assertNotNull(descriptionElement);
+ Assert.assertEquals("v-text-field", descriptionElement.tagName());
+ Assert.assertEquals("description", descriptionElement.attr("_id"));
+
+ }
+}
diff --git a/server/tests/src/com/vaadin/tests/design/MyVerticalLayout.html b/server/tests/src/com/vaadin/tests/design/MyVerticalLayout.html
new file mode 100644
index 0000000000..f6f4d98259
--- /dev/null
+++ b/server/tests/src/com/vaadin/tests/design/MyVerticalLayout.html
@@ -0,0 +1,4 @@
+<v-vertical-layout>
+ <v-label _id="caption" />
+ <v-text-field id="description" />
+</v-vertical-layout> \ No newline at end of file