diff options
author | Artur Signell <artur@vaadin.com> | 2016-10-10 22:15:16 +0300 |
---|---|---|
committer | Pekka Hyvönen <pekka@vaadin.com> | 2016-12-09 09:39:00 +0200 |
commit | 4ea2151053469f1092afaeab29587353c001e887 (patch) | |
tree | 46000e95450ed4460e4cd450467da529f8670952 /uitest | |
parent | 76447b941ac64d5f1ad7bbf12555c3b73db23285 (diff) | |
download | vaadin-framework-4ea2151053469f1092afaeab29587353c001e887.tar.gz vaadin-framework-4ea2151053469f1092afaeab29587353c001e887.zip |
Add Grid.refreshRows to allow refreshing individual rows (#16765)
Change-Id: I554d7b6ca60840bab3a032daa4847e7271086e27
Diffstat (limited to 'uitest')
-rw-r--r-- | uitest/src/main/java/com/vaadin/tests/components/grid/GridRefreshRow.java | 112 | ||||
-rw-r--r-- | uitest/src/test/java/com/vaadin/tests/components/grid/GridRefreshRowTest.java | 73 |
2 files changed, 185 insertions, 0 deletions
diff --git a/uitest/src/main/java/com/vaadin/tests/components/grid/GridRefreshRow.java b/uitest/src/main/java/com/vaadin/tests/components/grid/GridRefreshRow.java new file mode 100644 index 0000000000..a22fc6aaea --- /dev/null +++ b/uitest/src/main/java/com/vaadin/tests/components/grid/GridRefreshRow.java @@ -0,0 +1,112 @@ +package com.vaadin.tests.components.grid; + +import com.vaadin.annotations.Theme; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUIWithLog; +import com.vaadin.tests.util.Person; +import com.vaadin.tests.util.PersonContainer; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.Component; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.v7.ui.Grid; +import com.vaadin.v7.ui.Grid.CellReference; +import com.vaadin.v7.ui.Grid.CellStyleGenerator; +import com.vaadin.v7.ui.Grid.RowReference; +import com.vaadin.v7.ui.Grid.RowStyleGenerator; + +@Theme("valo") +public class GridRefreshRow extends AbstractTestUIWithLog { + + private PersonContainer container; + private Grid grid; + + private boolean styles[] = new boolean[] { false, false, false }; + + @Override + protected void setup(VaadinRequest request) { + getPage().getStyles() + .add(".rowstyle td {background-color: lightgreen !important;}"); + getPage().getStyles() + .add("td.cellstyle {background-color: lightblue !important;}"); + container = PersonContainer.createWithTestData(100); + container.addNestedContainerBean("address"); + grid = new Grid(container); + grid.setWidth("800px"); + grid.setRowStyleGenerator(new RowStyleGenerator() { + @Override + public String getStyle(RowReference row) { + int index = container.indexOfId(row.getItemId()); + if (index < 3 && styles[index]) { + return "rowstyle"; + } + + return null; + } + }); + grid.setCellStyleGenerator(new CellStyleGenerator() { + @Override + public String getStyle(CellReference cell) { + int index = container.indexOfId(cell.getItemId()); + if (index < 3 && styles[index] + && "email".equals(cell.getPropertyId())) { + return "cellstyle"; + } + + return null; + } + }); + addComponent(grid); + + addComponents(new HorizontalLayout(update(0), update(1), update(2))); + Button refresh10 = new Button("Refresh 0-9", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + grid.refreshRows(container.getItemIds(0, 9).toArray()); + } + }); + refresh10.setId("refresh10"); + addComponents(new HorizontalLayout(refresh(0), refresh(1), refresh(2), + new Button("Refresh non-existant", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + grid.refreshRows("foobar"); + } + })), refresh10); + addComponents(new HorizontalLayout(style(0), style(1), style(2))); + } + + private Component style(final int i) { + final CheckBox checkBox = new CheckBox("Style for " + i); + checkBox.addValueChangeListener( + event -> styles[i] = checkBox.getValue()); + checkBox.setId("style" + i); + return checkBox; + } + + private Component update(final int i) { + Button button = new Button("Update " + i, new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + Person p = container.getIdByIndex(i); + p.setFirstName("!" + p.getFirstName()); + } + }); + button.setId("update" + i); + return button; + } + + protected Component refresh(final int i) { + Button button = new Button("Refresh row " + i, new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + grid.refreshRows(container.getIdByIndex(i)); + } + }); + button.setId("refresh" + i); + return button; + } + +} diff --git a/uitest/src/test/java/com/vaadin/tests/components/grid/GridRefreshRowTest.java b/uitest/src/test/java/com/vaadin/tests/components/grid/GridRefreshRowTest.java new file mode 100644 index 0000000000..3b1e2b9c88 --- /dev/null +++ b/uitest/src/test/java/com/vaadin/tests/components/grid/GridRefreshRowTest.java @@ -0,0 +1,73 @@ +package com.vaadin.tests.components.grid; + +import org.junit.Assert; +import org.junit.Test; + +import com.vaadin.testbench.elements.ButtonElement; +import com.vaadin.testbench.elements.CheckBoxElement; +import com.vaadin.testbench.elements.GridElement; +import com.vaadin.tests.tb3.SingleBrowserTest; + +public class GridRefreshRowTest extends SingleBrowserTest { + + private GridElement grid; + + @Test + public void refreshRow() { + openTestURL(); + grid = $(GridElement.class).first(); + update(0); + update(1); + update(2); + style(1); + style(2); + + Assert.assertEquals("Lisa", grid.getCell(0, 1).getText()); + Assert.assertEquals("Joshua", grid.getCell(1, 1).getText()); + Assert.assertEquals("Marge", grid.getCell(2, 1).getText()); + + Assert.assertFalse(hasCssClass(grid.getRow(0), "rowstyle")); + Assert.assertFalse(hasCssClass(grid.getRow(1), "rowstyle")); + Assert.assertFalse(hasCssClass(grid.getRow(2), "rowstyle")); + Assert.assertFalse(hasCssClass(grid.getCell(0, 0), "cellstyle")); + Assert.assertFalse(hasCssClass(grid.getCell(1, 0), "cellstyle")); + Assert.assertFalse(hasCssClass(grid.getCell(2, 0), "cellstyle")); + + refresh(1); + Assert.assertEquals("Lisa", grid.getCell(0, 1).getText()); + Assert.assertEquals("!Joshua", grid.getCell(1, 1).getText()); + Assert.assertEquals("Marge", grid.getCell(2, 1).getText()); + + Assert.assertFalse(hasCssClass(grid.getRow(0), "rowstyle")); + Assert.assertTrue(hasCssClass(grid.getRow(1), "rowstyle")); + Assert.assertFalse(hasCssClass(grid.getRow(2), "rowstyle")); + Assert.assertFalse(hasCssClass(grid.getCell(0, 0), "cellstyle")); + Assert.assertTrue(hasCssClass(grid.getCell(1, 0), "cellstyle")); + Assert.assertFalse(hasCssClass(grid.getCell(2, 0), "cellstyle")); + + // Assert refreshing works many times and for many rows at the same time + update(0); + update(1); + update(2); + refresh10First(); + Assert.assertEquals("!!Lisa", grid.getCell(0, 1).getText()); + Assert.assertEquals("!!Joshua", grid.getCell(1, 1).getText()); + Assert.assertEquals("!!Marge", grid.getCell(2, 1).getText()); + } + + private void refresh10First() { + $(ButtonElement.class).id("refresh10").click(); + } + + private void update(int i) { + $(ButtonElement.class).id("update" + i).click(); + } + + private void style(int i) { + $(CheckBoxElement.class).id("style" + i).click(); + } + + private void refresh(int i) { + $(ButtonElement.class).id("refresh" + i).click(); + } +} |