summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAhmed Ashour <asashour@yahoo.com>2017-10-20 14:17:32 +0200
committerPéter Török <31210544+torok-peter@users.noreply.github.com>2017-10-20 15:17:32 +0300
commitb394dec430792e6514992f651d1f512bdf32b914 (patch)
tree4acf6bffd5d9cf0b7f6cdcf0c163cee5c472d69b
parentf706837fbfdafef24839184c487e975afaa7cfc3 (diff)
downloadvaadin-framework-b394dec430792e6514992f651d1f512bdf32b914.tar.gz
vaadin-framework-b394dec430792e6514992f651d1f512bdf32b914.zip
Grid.removeColumn() not to fail silently (Fixes #8056) (#10215)
* Grid.removeColumn() not to fail silently (Fixes #8056) * Compilation with JDK * Fix removeColumnByColumn_alreadyRemoved test * Use ExpectedException
-rw-r--r--server/src/main/java/com/vaadin/ui/Grid.java46
-rw-r--r--server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java96
2 files changed, 105 insertions, 37 deletions
diff --git a/server/src/main/java/com/vaadin/ui/Grid.java b/server/src/main/java/com/vaadin/ui/Grid.java
index de8f66ee58..50361528a7 100644
--- a/server/src/main/java/com/vaadin/ui/Grid.java
+++ b/server/src/main/java/com/vaadin/ui/Grid.java
@@ -976,10 +976,9 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
private static int compareMaybeComparables(Object a, Object b) {
if (hasCommonComparableBaseType(a, b)) {
return compareComparables(a, b);
- } else {
- return compareComparables(Objects.toString(a, ""),
- Objects.toString(b, ""));
}
+ return compareComparables(Objects.toString(a, ""),
+ Objects.toString(b, ""));
}
private static boolean hasCommonComparableBaseType(Object a, Object b) {
@@ -1005,7 +1004,7 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
return false;
}
- @SuppressWarnings("unchecked")
+ @SuppressWarnings({ "unchecked", "rawtypes" })
private static int compareComparables(Object a, Object b) {
return ((Comparator) Comparator
.nullsLast(Comparator.naturalOrder())).compare(a, b);
@@ -1019,20 +1018,19 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
if (valueA instanceof Comparable
&& valueA.getClass().isInstance(valueB)) {
return ((Comparable<Number>) valueA).compareTo(valueB);
- } else if (valueA.equals(valueB)) {
+ }
+ if (valueA.equals(valueB)) {
return 0;
- } else {
- // Fall back to comparing based on potentially truncated values
- int compare = Long.compare(valueA.longValue(),
- valueB.longValue());
- if (compare == 0) {
- // This might still produce 0 even though the values are not
- // equals, but there's nothing more we can do about that
- compare = Double.compare(valueA.doubleValue(),
- valueB.doubleValue());
- }
- return compare;
}
+ // Fall back to comparing based on potentially truncated values
+ int compare = Long.compare(valueA.longValue(), valueB.longValue());
+ if (compare == 0) {
+ // This might still produce 0 even though the values are not
+ // equals, but there's nothing more we can do about that
+ compare = Double.compare(valueA.doubleValue(),
+ valueB.doubleValue());
+ }
+ return compare;
}
@SuppressWarnings("unchecked")
@@ -2720,6 +2718,9 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
*
* @param column
* the column to remove
+ *
+ * @throws IllegalArgumentException
+ * if the column is not a valid one
*/
public void removeColumn(Column<T, ?> column) {
if (columnSet.remove(column)) {
@@ -2737,6 +2738,9 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
if (displayIndex < getFrozenColumnCount()) {
setFrozenColumnCount(getFrozenColumnCount() - 1);
}
+ } else {
+ throw new IllegalArgumentException("Column with id "
+ + column.getId() + " cannot be removed from the grid");
}
}
@@ -2934,10 +2938,12 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
if (rows <= 0.0d) {
throw new IllegalArgumentException(
"More than zero rows must be shown.");
- } else if (Double.isInfinite(rows)) {
+ }
+ if (Double.isInfinite(rows)) {
throw new IllegalArgumentException(
"Grid doesn't support infinite heights");
- } else if (Double.isNaN(rows)) {
+ }
+ if (Double.isNaN(rows)) {
throw new IllegalArgumentException("NaN is not a valid row count");
}
getState().heightMode = HeightMode.ROW;
@@ -3761,7 +3767,6 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
} else {
addExtension(selectionModel);
}
-
}
/**
@@ -4267,7 +4272,8 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
SelectionMode selectionMode = getSelectionMode();
if (SelectionMode.SINGLE.equals(selectionMode)) {
return asSingleSelect().isReadOnly();
- } else if (SelectionMode.MULTI.equals(selectionMode)) {
+ }
+ if (SelectionMode.MULTI.equals(selectionMode)) {
return asMultiSelect().isReadOnly();
}
return false;
diff --git a/server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java b/server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java
index cb0459dc90..d27c7c5260 100644
--- a/server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java
+++ b/server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java
@@ -29,7 +29,9 @@ import java.util.stream.Stream;
import org.easymock.Capture;
import org.junit.Before;
+import org.junit.Rule;
import org.junit.Test;
+import org.junit.rules.ExpectedException;
import com.vaadin.data.Binder.Binding;
import com.vaadin.data.ValidationException;
@@ -62,6 +64,9 @@ public class GridTest {
private Column<String, Object> objectColumn;
private Column<String, String> randomColumn;
+ @Rule
+ public ExpectedException thrown = ExpectedException.none();
+
@Before
public void setUp() {
grid = new Grid<>();
@@ -76,9 +81,9 @@ public class GridTest {
@Test
public void testCreateGridWithDataCommunicator() {
- DataCommunicator specificDataCommunicator = new DataCommunicator<>();
+ DataCommunicator<String> specificDataCommunicator = new DataCommunicator<>();
- TestGrid<String> grid = new TestGrid(String.class,
+ TestGrid<String> grid = new TestGrid<>(String.class,
specificDataCommunicator);
assertEquals(specificDataCommunicator, grid.getDataCommunicator());
@@ -96,17 +101,25 @@ public class GridTest {
HeightMode.CSS, grid.getHeightMode());
}
- @Test(expected = IllegalArgumentException.class)
+ @Test
public void testFrozenColumnCountTooBig() {
+ thrown.expect(IllegalArgumentException.class);
+ thrown.expectMessage(
+ "count must be between -1 and the current number of columns (4): 5");
+
grid.setFrozenColumnCount(5);
}
- @Test(expected = IllegalArgumentException.class)
+ @Test
public void testFrozenColumnCountTooSmall() {
+ thrown.expect(IllegalArgumentException.class);
+ thrown.expectMessage(
+ "count must be between -1 and the current number of columns (4): -2");
+
grid.setFrozenColumnCount(-2);
}
- @Test()
+ @Test
public void testSetFrozenColumnCount() {
for (int i = -1; i < 2; ++i) {
grid.setFrozenColumnCount(i);
@@ -122,8 +135,11 @@ public class GridTest {
grid.getHeaderRow(0).getCell("foo").getText());
}
- @Test(expected = IllegalArgumentException.class)
+ @Test
public void testGridMultipleColumnsWithSameIdentifier() {
+ thrown.expect(IllegalArgumentException.class);
+ thrown.expectMessage("Duplicate ID for columns");
+
grid.addColumn(t -> t).setId("foo");
}
@@ -211,8 +227,12 @@ public class GridTest {
assertEquals(0, event.getAllSelectedItems().size());
}
- @Test(expected = UnsupportedOperationException.class)
+ @Test
public void testAddSelectionListener_noSelectionMode() {
+ thrown.expect(UnsupportedOperationException.class);
+ thrown.expectMessage(
+ "This selection model doesn't allow selection, cannot add selection listeners to it");
+
grid.setSelectionMode(SelectionMode.NONE);
grid.addSelectionListener(event -> fail("never ever happens (tm)"));
@@ -351,8 +371,13 @@ public class GridTest {
assertEquals("Ipsum", person.getName());
}
- @Test(expected = IllegalStateException.class)
+ @Test
public void oneArgSetEditor_nonBeanGrid() {
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage(
+ "A Grid created without a bean type class literal or a custom property set"
+ + " doesn't support finding properties by name.");
+
Grid<Person> grid = new Grid<>();
Column<Person, String> nameCol = grid.addColumn(Person::getName)
.setId("name");
@@ -360,8 +385,11 @@ public class GridTest {
nameCol.setEditorComponent(new TextField());
}
- @Test(expected = IllegalStateException.class)
+ @Test
public void addExistingColumnById_throws() {
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage("There is already a column for name");
+
Grid<Person> grid = new Grid<>(Person.class);
grid.addColumn("name");
}
@@ -389,16 +417,22 @@ public class GridTest {
@Test
public void removeColumnByColumn_alreadyRemoved() {
+ thrown.expect(IllegalArgumentException.class);
+ thrown.expectMessage(
+ "Column with id foo cannot be removed from the grid");
+
grid.removeColumn(fooColumn);
- // Questionable that this doesn't throw, but that's a separate ticket...
grid.removeColumn(fooColumn);
assertEquals(Arrays.asList(lengthColumn, objectColumn, randomColumn),
grid.getColumns());
}
- @Test(expected = IllegalStateException.class)
+ @Test
public void removeColumnById_alreadyRemoved() {
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage("There is no column with the id foo");
+
grid.removeColumn("foo");
grid.removeColumn("foo");
}
@@ -473,8 +507,13 @@ public class GridTest {
assertEquals("foo", columns.get(1).getId());
}
- @Test(expected = IllegalStateException.class)
+ @Test
public void setColumns_addColumn_notBeangrid() {
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage(
+ "A Grid created without a bean type class literal or a custom property set"
+ + " doesn't support finding properties by name.");
+
// Not possible to add a column in a grid that cannot add columns based
// on a string
grid.setColumns("notHere");
@@ -503,8 +542,12 @@ public class GridTest {
objectColumn), grid.getColumns());
}
- @Test(expected = IllegalStateException.class)
+ @Test
public void setColumnOrder_byColumn_removedColumn() {
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage("setColumnOrder should not be called "
+ + "with columns that are not in the grid.");
+
grid.removeColumn(randomColumn);
grid.setColumnOrder(randomColumn, lengthColumn);
}
@@ -517,8 +560,11 @@ public class GridTest {
objectColumn), grid.getColumns());
}
- @Test(expected = IllegalStateException.class)
+ @Test
public void setColumnOrder_byString_removedColumn() {
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage("There is no column with the id randomColumnId");
+
grid.removeColumn("randomColumnId");
grid.setColumnOrder("randomColumnId", "length");
}
@@ -584,8 +630,13 @@ public class GridTest {
assertEquals(formattedValue, "2,017");
}
- @Test(expected = IllegalArgumentException.class)
+ @Test
public void addBeanColumn_invalidRenderer() {
+ thrown.expect(IllegalArgumentException.class);
+ thrown.expectMessage("NumberRenderer");
+ thrown.expectMessage(
+ " cannot be used with a property of type java.lang.String");
+
Grid<Person> grid = new Grid<>(Person.class);
grid.removeColumn("name");
@@ -652,9 +703,8 @@ public class GridTest {
}
private static Method findDataGeneratorGetterMethod() {
- Method getter;
try {
- getter = Column.class.getDeclaredMethod("getDataGenerator",
+ Method getter = Column.class.getDeclaredMethod("getDataGenerator",
new Class<?>[] {});
getter.setAccessible(true);
return getter;
@@ -663,4 +713,16 @@ public class GridTest {
"Cannot get DataGenerator from Column");
}
}
+
+ @Test
+ public void removeColumnToThrowForInvalidColumn() {
+ thrown.expect(IllegalArgumentException.class);
+ thrown.expectMessage(
+ "Column with id null cannot be removed from the grid");
+
+ Grid<Person> grid1 = new Grid<>();
+ Grid<Person> grid2 = new Grid<>();
+ Column<Person, ?> column1 = grid1.addColumn(ValueProvider.identity());
+ grid2.removeColumn(column1);
+ }
}