diff options
Diffstat (limited to 'uitest')
-rw-r--r-- | uitest/src/com/vaadin/tests/components/grid/GridDetailsDetach.java | 23 | ||||
-rw-r--r-- | uitest/src/com/vaadin/tests/components/grid/GridDetailsDetachTest.java | 32 |
2 files changed, 49 insertions, 6 deletions
diff --git a/uitest/src/com/vaadin/tests/components/grid/GridDetailsDetach.java b/uitest/src/com/vaadin/tests/components/grid/GridDetailsDetach.java index c25ad287b7..1032378a2d 100644 --- a/uitest/src/com/vaadin/tests/components/grid/GridDetailsDetach.java +++ b/uitest/src/com/vaadin/tests/components/grid/GridDetailsDetach.java @@ -35,7 +35,7 @@ public class GridDetailsDetach extends AbstractTestUI { @Override protected void setup(VaadinRequest request) { - final VerticalLayout layout = new VerticalLayout(); + VerticalLayout layout = new VerticalLayout(); layout.setSizeFull(); Button button = new Button("Test"); @@ -43,19 +43,30 @@ public class GridDetailsDetach extends AbstractTestUI { layout.setExpandRatio(button, 0f); currentGrid = generateGrid(); - layout.addComponent(currentGrid); - layout.setExpandRatio(currentGrid, 1f); + final VerticalLayout gridContainer = new VerticalLayout(); + gridContainer.addComponent(currentGrid); button.addClickListener(new Button.ClickListener() { @Override public void buttonClick(ClickEvent event) { - Grid newGrid = generateGrid(); - layout.replaceComponent(currentGrid, newGrid); - currentGrid = newGrid; + gridContainer.replaceComponent(currentGrid, new Label("Foo")); } }); + layout.addComponent(new Button("Reattach Grid", + new Button.ClickListener() { + + @Override + public void buttonClick(ClickEvent event) { + gridContainer.removeAllComponents(); + gridContainer.addComponent(currentGrid); + } + })); + + layout.addComponent(gridContainer); + layout.setExpandRatio(gridContainer, 1f); + addComponent(layout); } diff --git a/uitest/src/com/vaadin/tests/components/grid/GridDetailsDetachTest.java b/uitest/src/com/vaadin/tests/components/grid/GridDetailsDetachTest.java index f9071dd3da..fc79fd1b68 100644 --- a/uitest/src/com/vaadin/tests/components/grid/GridDetailsDetachTest.java +++ b/uitest/src/com/vaadin/tests/components/grid/GridDetailsDetachTest.java @@ -15,7 +15,12 @@ */ package com.vaadin.tests.components.grid; +import java.util.List; + +import org.junit.Assert; import org.junit.Test; +import org.openqa.selenium.By; +import org.openqa.selenium.WebElement; import com.vaadin.testbench.elements.ButtonElement; import com.vaadin.testbench.elements.GridElement; @@ -31,11 +36,38 @@ public class GridDetailsDetachTest extends MultiBrowserTest { openTestURL(); $(GridElement.class).first().getCell(3, 0).click(); + $(GridElement.class).first().getCell(5, 0).click(); + + assertNoErrorNotifications(); + + $(ButtonElement.class).first().click(); + + assertNoErrorNotifications(); + } + + @Test + public void testDetachAndReattachGridWithDetailsOpen() { + setDebug(true); + openTestURL(); + + $(GridElement.class).first().getCell(3, 0).click(); + $(GridElement.class).first().getCell(5, 0).click(); assertNoErrorNotifications(); $(ButtonElement.class).first().click(); assertNoErrorNotifications(); + + $(ButtonElement.class).get(1).click(); + + assertNoErrorNotifications(); + + List<WebElement> spacers = findElements(By.className("v-grid-spacer")); + Assert.assertEquals("Not enough spacers in DOM", 2, spacers.size()); + Assert.assertEquals("Spacer content not visible", + "Extra data for Bean 3", spacers.get(0).getText()); + Assert.assertEquals("Spacer content not visible", + "Extra data for Bean 5", spacers.get(1).getText()); } } |