diff options
author | Anastasia Smirnova <anasmi@utu.fi> | 2018-09-07 11:39:48 +0300 |
---|---|---|
committer | Ilia Motornyi <elmot@vaadin.com> | 2018-09-07 11:39:48 +0300 |
commit | 77a921791a318c60d25f5bb19823d8c2850732b0 (patch) | |
tree | 0b9333626ae5b92b59700063f2d1d3aac5455888 | |
parent | a3769ed12ee1456575ef491d59031c36243495b3 (diff) | |
download | vaadin-framework-77a921791a318c60d25f5bb19823d8c2850732b0.tar.gz vaadin-framework-77a921791a318c60d25f5bb19823d8c2850732b0.zip |
Ensure that HeaderRow is not null in Grid (#11165)
Ensure that HeaderRow is not null in Grid
Fixes #10485
3 files changed, 54 insertions, 0 deletions
diff --git a/client/src/main/java/com/vaadin/client/widgets/Grid.java b/client/src/main/java/com/vaadin/client/widgets/Grid.java index fd32ca8243..e382d2a4f1 100755 --- a/client/src/main/java/com/vaadin/client/widgets/Grid.java +++ b/client/src/main/java/com/vaadin/client/widgets/Grid.java @@ -3411,6 +3411,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, // Make SelectAllCheckbox visible getSelectionColumn().ifPresent(col -> { + if (getDefaultHeaderRow() == null) + return; HeaderCell headerCell = getDefaultHeaderRow().getCell(col); if (headerCell.getType().equals(GridStaticCellType.WIDGET)) { // SelectAllCheckbox is present already diff --git a/uitest/src/main/java/com/vaadin/tests/components/grid/GridColumnWidthWithoutHeader.java b/uitest/src/main/java/com/vaadin/tests/components/grid/GridColumnWidthWithoutHeader.java new file mode 100644 index 0000000000..b7d54aa9b1 --- /dev/null +++ b/uitest/src/main/java/com/vaadin/tests/components/grid/GridColumnWidthWithoutHeader.java @@ -0,0 +1,22 @@ +package com.vaadin.tests.components.grid; + +import com.vaadin.data.ValueProvider; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.Grid; + +public class GridColumnWidthWithoutHeader extends AbstractTestUI { + @Override + protected void setup(VaadinRequest request) { + Grid<String> grid = new Grid<>(); + grid.addColumn(ValueProvider.identity()).setExpandRatio(1) + .setMinimumWidth(250); + grid.addColumn(String::valueOf).setWidth(150); + grid.setItems("a", "b"); + grid.setSelectionMode(Grid.SelectionMode.MULTI); + grid.setSizeFull(); + + grid.removeHeaderRow(0); + addComponent(grid); + } +} diff --git a/uitest/src/test/java/com/vaadin/tests/components/grid/GridColumnWidthWithoutHeaderTest.java b/uitest/src/test/java/com/vaadin/tests/components/grid/GridColumnWidthWithoutHeaderTest.java new file mode 100644 index 0000000000..c9208e3226 --- /dev/null +++ b/uitest/src/test/java/com/vaadin/tests/components/grid/GridColumnWidthWithoutHeaderTest.java @@ -0,0 +1,30 @@ +package com.vaadin.tests.components.grid; + +import com.vaadin.testbench.elements.GridElement; +import com.vaadin.tests.tb3.SingleBrowserTest; +import org.junit.Test; + +import static org.junit.Assert.assertTrue; + +public class GridColumnWidthWithoutHeaderTest extends SingleBrowserTest { + public static final int THRESHOLD = 3; + + @Test + public void testWidthWithoutHeader() { + openTestURL(); + + GridElement grid = $(GridElement.class).first(); + int columnsWidth = getColWidthsRounded(grid); + assertTrue(Math + .abs(columnsWidth - grid.getSize().getWidth()) <= THRESHOLD); + } + + private int getColWidthsRounded(GridElement grid) { + GridElement.GridRowElement firstRow = grid.getRow(0); + int width = 0; + for (int i = 0; i < 3; i++) { + width = width + firstRow.getCell(i).getSize().getWidth(); + } + return width; + } +} |