diff options
author | Ahmed Ashour <asashour@yahoo.com> | 2017-10-20 14:17:32 +0200 |
---|---|---|
committer | Péter Török <31210544+torok-peter@users.noreply.github.com> | 2017-10-20 15:17:32 +0300 |
commit | b394dec430792e6514992f651d1f512bdf32b914 (patch) | |
tree | 4acf6bffd5d9cf0b7f6cdcf0c163cee5c472d69b | |
parent | f706837fbfdafef24839184c487e975afaa7cfc3 (diff) | |
download | vaadin-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.java | 46 | ||||
-rw-r--r-- | server/src/test/java/com/vaadin/tests/server/component/grid/GridTest.java | 96 |
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); + } } |