From a75117689e09e507c88bc6faa4144e56b041498b Mon Sep 17 00:00:00 2001 From: Petter Holmström Date: Mon, 4 Sep 2017 16:40:38 +0300 Subject: Force re-measurement of CheckBoxGroup and RadioButtonGroup (#9901) The related tests have a workaround for another (Chrome specific) GridLayout bug #9921. Those workarounds should be removed once that issue is fixed. Fixes #9148 --- .../checkboxgroup/CheckBoxGroupInGridLayout.java | 26 ++++++++++++++++++ .../RadioButtonGroupInGridLayout.java | 26 ++++++++++++++++++ .../CheckBoxGroupInGridLayoutTest.java | 32 ++++++++++++++++++++++ .../RadioButtonGroupInGridLayoutTest.java | 32 ++++++++++++++++++++++ 4 files changed, 116 insertions(+) create mode 100644 uitest/src/main/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupInGridLayout.java create mode 100644 uitest/src/main/java/com/vaadin/tests/components/radiobuttongroup/RadioButtonGroupInGridLayout.java create mode 100644 uitest/src/test/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupInGridLayoutTest.java create mode 100644 uitest/src/test/java/com/vaadin/tests/components/radiobuttongroup/RadioButtonGroupInGridLayoutTest.java (limited to 'uitest') diff --git a/uitest/src/main/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupInGridLayout.java b/uitest/src/main/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupInGridLayout.java new file mode 100644 index 0000000000..7a50255000 --- /dev/null +++ b/uitest/src/main/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupInGridLayout.java @@ -0,0 +1,26 @@ +package com.vaadin.tests.components.checkboxgroup; + +import com.vaadin.data.provider.DataProvider; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.CheckBoxGroup; +import com.vaadin.ui.GridLayout; +import com.vaadin.ui.TextField; +import com.vaadin.ui.themes.ValoTheme; + +public class CheckBoxGroupInGridLayout extends AbstractTestUI { + + @Override + protected void setup(VaadinRequest request) { + CheckBoxGroup cbGroup = new CheckBoxGroup<>(null, DataProvider.ofItems("A", "B", "C")); + cbGroup.addStyleName(ValoTheme.OPTIONGROUP_HORIZONTAL); + + GridLayout gridLayout = new GridLayout(2, 1); + gridLayout.addComponent(cbGroup, 0, 0); + gridLayout.setSpacing(true); + + gridLayout.addComponent(new TextField(), 1, 0); + + addComponent(gridLayout); + } +} diff --git a/uitest/src/main/java/com/vaadin/tests/components/radiobuttongroup/RadioButtonGroupInGridLayout.java b/uitest/src/main/java/com/vaadin/tests/components/radiobuttongroup/RadioButtonGroupInGridLayout.java new file mode 100644 index 0000000000..dcd0ab08f2 --- /dev/null +++ b/uitest/src/main/java/com/vaadin/tests/components/radiobuttongroup/RadioButtonGroupInGridLayout.java @@ -0,0 +1,26 @@ +package com.vaadin.tests.components.radiobuttongroup; + +import com.vaadin.data.provider.DataProvider; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.GridLayout; +import com.vaadin.ui.RadioButtonGroup; +import com.vaadin.ui.TextField; +import com.vaadin.ui.themes.ValoTheme; + +public class RadioButtonGroupInGridLayout extends AbstractTestUI { + + @Override + protected void setup(VaadinRequest request) { + RadioButtonGroup cbGroup = new RadioButtonGroup<>(null, DataProvider.ofItems("A", "B", "C")); + cbGroup.addStyleName(ValoTheme.OPTIONGROUP_HORIZONTAL); + + GridLayout gridLayout = new GridLayout(2, 1); + gridLayout.addComponent(cbGroup, 0, 0); + gridLayout.setSpacing(true); + + gridLayout.addComponent(new TextField(), 1, 0); + + addComponent(gridLayout); + } +} diff --git a/uitest/src/test/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupInGridLayoutTest.java b/uitest/src/test/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupInGridLayoutTest.java new file mode 100644 index 0000000000..0aade000fd --- /dev/null +++ b/uitest/src/test/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupInGridLayoutTest.java @@ -0,0 +1,32 @@ +package com.vaadin.tests.components.checkboxgroup; + +import org.junit.Assert; +import org.junit.Test; + +import com.vaadin.testbench.elements.CheckBoxGroupElement; +import com.vaadin.testbench.elements.GridLayoutElement; +import com.vaadin.testbench.parallel.BrowserUtil; +import com.vaadin.tests.tb3.MultiBrowserTest; + +public class CheckBoxGroupInGridLayoutTest extends MultiBrowserTest { + + @Test + public void slotSizeRemainsUnchangedAfterSelectingItem() { + openTestURL(); + GridLayoutElement gridLayout = $(GridLayoutElement.class).first(); + int before = gridLayout.getSize().getWidth(); + + CheckBoxGroupElement checkBoxGroup = $(CheckBoxGroupElement.class) + .first(); + checkBoxGroup.setValue("A"); + int after = gridLayout.getSize().getWidth(); + + boolean ok = (before == after); + // also accept broken layout for unrelated bug #9921 until it is fixed + if (!ok && BrowserUtil.isChrome(getDesiredCapabilities())) { + ok = (before == after + 4); + } + + Assert.assertTrue("GridLayout size changed when selecting a value", ok); + } +} diff --git a/uitest/src/test/java/com/vaadin/tests/components/radiobuttongroup/RadioButtonGroupInGridLayoutTest.java b/uitest/src/test/java/com/vaadin/tests/components/radiobuttongroup/RadioButtonGroupInGridLayoutTest.java new file mode 100644 index 0000000000..5d7aa373f4 --- /dev/null +++ b/uitest/src/test/java/com/vaadin/tests/components/radiobuttongroup/RadioButtonGroupInGridLayoutTest.java @@ -0,0 +1,32 @@ +package com.vaadin.tests.components.radiobuttongroup; + +import org.junit.Assert; +import org.junit.Test; + +import com.vaadin.testbench.elements.GridLayoutElement; +import com.vaadin.testbench.elements.RadioButtonGroupElement; +import com.vaadin.testbench.parallel.BrowserUtil; +import com.vaadin.tests.tb3.MultiBrowserTest; + +public class RadioButtonGroupInGridLayoutTest extends MultiBrowserTest { + + @Test + public void slotSizeRemainsUnchangedAfterSelectingItem() { + openTestURL(); + GridLayoutElement gridLayout = $(GridLayoutElement.class).first(); + int before = gridLayout.getSize().getWidth(); + + RadioButtonGroupElement radioButtonGroup = $( + RadioButtonGroupElement.class).first(); + radioButtonGroup.setValue("A"); + int after = gridLayout.getSize().getWidth(); + + boolean ok = (before == after); + // also accept broken layout for unrelated bug #9921 until it is fixed + if (!ok && BrowserUtil.isChrome(getDesiredCapabilities())) { + ok = (before == after + 4); + } + + Assert.assertTrue("GridLayout size changed when selecting a value", ok); + } +} -- cgit v1.2.3