diff options
author | Johannes Tuikkala <johannes@vaadin.com> | 2015-09-17 08:41:45 +0300 |
---|---|---|
committer | Vaadin Code Review <review@vaadin.com> | 2015-09-18 13:21:11 +0000 |
commit | 467c00af32548861c7bb44fc5e3e00fa9829b9a2 (patch) | |
tree | b3e4c36bfe5ea77bfff82308012870008ecf2200 /uitest/src | |
parent | e71f6cfd817ffddb7c9cc4a7855d248a859d837f (diff) | |
download | vaadin-framework-467c00af32548861c7bb44fc5e3e00fa9829b9a2.tar.gz vaadin-framework-467c00af32548861c7bb44fc5e3e00fa9829b9a2.zip |
Converting TB2 tests for ticket #17947
Change-Id: I3357e736a024da0a5f8096f51840964b19f822a4
Diffstat (limited to 'uitest/src')
16 files changed, 1126 insertions, 121 deletions
diff --git a/uitest/src/com/vaadin/tests/components/table/Footer.java b/uitest/src/com/vaadin/tests/components/table/Footer.java index cf6c3b6185..5d2d68898c 100644 --- a/uitest/src/com/vaadin/tests/components/table/Footer.java +++ b/uitest/src/com/vaadin/tests/components/table/Footer.java @@ -5,7 +5,8 @@ import com.vaadin.data.Item; import com.vaadin.data.Property; import com.vaadin.data.Property.ValueChangeEvent; import com.vaadin.data.util.IndexedContainer; -import com.vaadin.tests.components.TestBase; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; import com.vaadin.ui.Button; import com.vaadin.ui.Button.ClickEvent; import com.vaadin.ui.CheckBox; @@ -14,11 +15,10 @@ import com.vaadin.ui.Table; import com.vaadin.ui.TextField; import com.vaadin.ui.VerticalLayout; -@SuppressWarnings("serial") -public class Footer extends TestBase { +public class Footer extends AbstractTestUI { @Override - protected void setup() { + protected void setup(VaadinRequest request) { HorizontalLayout layout = new HorizontalLayout(); layout.setSpacing(true); @@ -49,7 +49,7 @@ public class Footer extends TestBase { final CheckBox visible = new CheckBox("Footers Visible", true); visible.setImmediate(true); - visible.addListener(new Property.ValueChangeListener() { + visible.addValueChangeListener(new Property.ValueChangeListener() { @Override public void valueChange(ValueChangeEvent event) { table.setFooterVisible(visible.getValue()); @@ -110,7 +110,7 @@ public class Footer extends TestBase { } @Override - protected String getDescription() { + public String getDescription() { return "Table with footer"; } diff --git a/uitest/src/com/vaadin/tests/components/table/FooterClick.java b/uitest/src/com/vaadin/tests/components/table/FooterClick.java index 992b521b60..8d6a32c9bb 100644 --- a/uitest/src/com/vaadin/tests/components/table/FooterClick.java +++ b/uitest/src/com/vaadin/tests/components/table/FooterClick.java @@ -5,24 +5,21 @@ import com.vaadin.data.Item; import com.vaadin.data.Property; import com.vaadin.data.Property.ValueChangeEvent; import com.vaadin.data.util.IndexedContainer; -import com.vaadin.tests.components.TestBase; -import com.vaadin.tests.util.Log; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUIWithLog; import com.vaadin.ui.CheckBox; import com.vaadin.ui.Table; import com.vaadin.ui.Table.FooterClickEvent; import com.vaadin.ui.TextField; -@SuppressWarnings("serial") -public class FooterClick extends TestBase { +public class FooterClick extends AbstractTestUIWithLog { private final String COLUMN1_PROPERTY_ID = "col1"; private final String COLUMN2_PROPERTY_ID = "col2"; private final String COLUMN3_PROPERTY_ID = "col3"; - private Log log = new Log(5); - @Override - protected void setup() { + protected void setup(VaadinRequest request) { final Table table = new Table(); table.setId("table"); table.setContainerDataSource(createContainer()); @@ -33,7 +30,6 @@ public class FooterClick extends TestBase { table.setColumnReorderingAllowed(true); table.setColumnFooter(COLUMN1_PROPERTY_ID, "fuu"); - // table.setColumnFooter(COLUMN2_PROPERTY_ID, "bar"); table.setColumnFooter(COLUMN3_PROPERTY_ID, "fuubar"); final TextField columnField = new TextField( @@ -41,31 +37,33 @@ public class FooterClick extends TestBase { columnField.setId("ClickedColumn"); // Add a footer click listener - table.addListener(new Table.FooterClickListener() { + table.addFooterClickListener(new Table.FooterClickListener() { @Override public void footerClick(FooterClickEvent event) { columnField.setValue(String.valueOf(event.getPropertyId())); - log.log("Clicked on footer: " + event.getPropertyId()); + log("Clicked on footer: " + event.getPropertyId()); } }); CheckBox immediateCheckbox = new CheckBox("Immediate"); immediateCheckbox.setImmediate(true); immediateCheckbox.setValue(table.isImmediate()); - immediateCheckbox.addListener(new Property.ValueChangeListener() { + immediateCheckbox + .addValueChangeListener(new Property.ValueChangeListener() { - @Override - public void valueChange(ValueChangeEvent event) { - table.setImmediate((Boolean) event.getProperty().getValue()); - } - }); + @Override + public void valueChange(ValueChangeEvent event) { + table.setImmediate((Boolean) event.getProperty() + .getValue()); + } + }); CheckBox columnReorderingCheckbox = new CheckBox( "Column reordering allowed"); columnReorderingCheckbox.setImmediate(true); columnReorderingCheckbox.setValue(table.isColumnReorderingAllowed()); columnReorderingCheckbox - .addListener(new Property.ValueChangeListener() { + .addValueChangeListener(new Property.ValueChangeListener() { @Override public void valueChange(ValueChangeEvent event) { @@ -76,15 +74,12 @@ public class FooterClick extends TestBase { addComponent(immediateCheckbox); addComponent(columnReorderingCheckbox); - - addComponent(log); - addComponent(table); addComponent(columnField); } @Override - protected String getDescription() { + public String getDescription() { return "Tests the footer click handler"; } diff --git a/uitest/src/com/vaadin/tests/components/table/FooterClickTest.java b/uitest/src/com/vaadin/tests/components/table/FooterClickTest.java new file mode 100644 index 0000000000..2e4df1c116 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/FooterClickTest.java @@ -0,0 +1,116 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.table; + +import static org.hamcrest.MatcherAssert.assertThat; +import static org.junit.Assert.assertEquals; + +import java.io.IOException; +import java.util.Arrays; + +import org.junit.Test; + +import com.vaadin.testbench.TestBenchElement; +import com.vaadin.testbench.elements.CheckBoxElement; +import com.vaadin.testbench.elements.TableElement; +import com.vaadin.testbench.elements.TextFieldElement; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * Tests Table Footer ClickListener + * + * @since + * @author Vaadin Ltd + */ +public class FooterClickTest extends MultiBrowserTest { + + @Test + public void testFooter() throws IOException { + openTestURL(); + + TableElement table = $(TableElement.class).first(); + TestBenchElement footer0 = table.getFooterCell(0); + footer0.click(); + + TextFieldElement tf = $(TextFieldElement.class).id("ClickedColumn"); + assertEquals("col1", tf.getValue()); + + assertAnyLogText("1. Clicked on footer: col1"); + + table = $(TableElement.class).first(); + TestBenchElement footer1 = table.getFooterCell(1); + footer1.click(); + + tf = $(TextFieldElement.class).id("ClickedColumn"); + assertEquals("col2", tf.getValue()); + + assertAnyLogText("2. Clicked on footer: col2"); + + table = $(TableElement.class).first(); + TestBenchElement footer2 = table.getFooterCell(2); + footer2.click(); + + tf = $(TextFieldElement.class).id("ClickedColumn"); + assertEquals("col3", tf.getValue()); + + assertAnyLogText("3. Clicked on footer: col3"); + + CheckBoxElement cb = $(CheckBoxElement.class).first(); + cb.click(); + + table = $(TableElement.class).first(); + footer0 = table.getFooterCell(0); + footer0.click(); + + tf = $(TextFieldElement.class).id("ClickedColumn"); + assertEquals("col1", tf.getValue()); + + assertAnyLogText("4. Clicked on footer: col1"); + + table = $(TableElement.class).first(); + footer1 = table.getFooterCell(1); + footer1.click(); + + tf = $(TextFieldElement.class).id("ClickedColumn"); + assertEquals("col2", tf.getValue()); + + assertAnyLogText("5. Clicked on footer: col2"); + + table = $(TableElement.class).first(); + footer2 = table.getFooterCell(2); + footer2.click(); + + tf = $(TextFieldElement.class).id("ClickedColumn"); + assertEquals("col3", tf.getValue()); + + assertAnyLogText("6. Clicked on footer: col3"); + } + + private void assertAnyLogText(String... texts) { + assertThat(String.format( + "Correct log text was not found, expected any of %s", + Arrays.asList(texts)), logContainsAnyText(texts)); + } + + private boolean logContainsAnyText(String... texts) { + for (String text : texts) { + if (logContainsText(text)) { + return true; + } + } + return false; + } +} diff --git a/uitest/src/com/vaadin/tests/components/table/FooterTest.java b/uitest/src/com/vaadin/tests/components/table/FooterTest.java new file mode 100644 index 0000000000..19cce02d32 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/FooterTest.java @@ -0,0 +1,206 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.table; + +import static org.junit.Assert.assertEquals; + +import java.io.IOException; + +import org.junit.Test; +import org.openqa.selenium.By; +import org.openqa.selenium.WebDriver; +import org.openqa.selenium.support.ui.ExpectedCondition; + +import com.vaadin.testbench.TestBenchElement; +import com.vaadin.testbench.elements.ButtonElement; +import com.vaadin.testbench.elements.CheckBoxElement; +import com.vaadin.testbench.elements.TableElement; +import com.vaadin.testbench.elements.TextFieldElement; +import com.vaadin.testbench.parallel.BrowserUtil; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * Tests Table Footer + * + * @since + * @author Vaadin Ltd + */ +public class FooterTest extends MultiBrowserTest { + + @Test + public void testFooter() throws IOException { + openTestURL(); + + waitForElementPresent(By.className("v-table")); + + compareScreen("initial"); + + TableElement table = $(TableElement.class).first(); + + TestBenchElement footer0 = table.getFooterCell(0); + TestBenchElement footer1 = table.getFooterCell(1); + TestBenchElement footer2 = table.getFooterCell(2); + + assertEquals("Footer1", footer0.getText()); + assertEquals("Footer2", footer1.getText()); + assertEquals("Footer3", footer2.getText()); + + CheckBoxElement checkBox = $(CheckBoxElement.class).first(); + checkBox.click(); + + if (!BrowserUtil.isIE8(getDesiredCapabilities())) { + // excluded IE8 since its screenshots varies from run-to-run + compareScreen("no-footer"); + } + + checkBox.click(); + + if (!BrowserUtil.isIE8(getDesiredCapabilities())) { + // excluded IE8 since its screenshots varies from run-to-run + compareScreen("footer-col1-col2-col3-a"); + } + + table = $(TableElement.class).first(); + + footer0 = table.getFooterCell(0); + footer1 = table.getFooterCell(1); + footer2 = table.getFooterCell(2); + + assertEquals("Footer1", footer0.getText()); + assertEquals("Footer2", footer1.getText()); + assertEquals("Footer3", footer2.getText()); + + // open table column selector menu + table.findElement(By.className("v-table-column-selector")).click(); + // hide col2 + findElements(By.className("gwt-MenuItem")).get(1).click(); + + if (!BrowserUtil.isIE8(getDesiredCapabilities())) { + // excluded IE8 since its screenshots varies from run-to-run + compareScreen("footer-col1-col3"); + } + + // open table column selector menu + table.findElement(By.className("v-table-column-selector")).click(); + // show col2 + findElements(By.className("gwt-MenuItem")).get(1).click(); + + if (!BrowserUtil.isIE8(getDesiredCapabilities())) { + // excluded IE8 since its screenshots varies from run-to-run + compareScreen("footer-col1-col2-col3-b"); + } + + TextFieldElement tf = $(TextFieldElement.class).first(); + tf.clear(); + tf.sendKeys("fuu"); + ButtonElement button = $(ButtonElement.class).first(); + button.click(); + table = $(TableElement.class).first(); + footer0 = table.getFooterCell(0); + assertEquals("fuu", footer0.getText()); + + tf = $(TextFieldElement.class).get(1); + tf.clear(); + tf.sendKeys("bar"); + button = $(ButtonElement.class).get(1); + button.click(); + table = $(TableElement.class).first(); + footer1 = table.getFooterCell(1); + assertEquals("bar", footer1.getText()); + + tf = $(TextFieldElement.class).get(2); + tf.clear(); + tf.sendKeys(""); + button = $(ButtonElement.class).get(2); + button.click(); + table = $(TableElement.class).first(); + footer2 = table.getFooterCell(2); + assertEquals("", footer2.getText().trim()); + + TextFieldElement tf1 = $(TextFieldElement.class).first(); + tf1.clear(); + tf1.sendKeys("Footer1"); + + TextFieldElement tf2 = $(TextFieldElement.class).get(1); + tf2.clear(); + tf2.sendKeys("Footer2"); + + TextFieldElement tf3 = $(TextFieldElement.class).get(2); + tf3.clear(); + tf3.sendKeys("Footer3"); + + waitUntiltextFieldIsChangedTo(tf1, "Footer1"); + waitUntiltextFieldIsChangedTo(tf2, "Footer2"); + waitUntiltextFieldIsChangedTo(tf3, "Footer3"); + + button = $(ButtonElement.class).first(); + button.click(); + button = $(ButtonElement.class).get(1); + button.click(); + button = $(ButtonElement.class).get(2); + button.click(); + + waitUntilFooterCellIsChangedTo(0, "Footer1"); + waitUntilFooterCellIsChangedTo(1, "Footer2"); + waitUntilFooterCellIsChangedTo(2, "Footer3"); + + table = $(TableElement.class).first(); + footer0 = table.getFooterCell(0); + assertEquals("Footer1", footer0.getText()); + + if (!BrowserUtil.isIE8(getDesiredCapabilities())) { + // excluded IE8 since its screenshots varies from run-to-run + compareScreen("footer-col1-col2-col3-c"); + } + } + + private void waitUntiltextFieldIsChangedTo(final TextFieldElement tf, + final String text) { + waitUntil(new ExpectedCondition<Boolean>() { + @Override + public Boolean apply(WebDriver input) { + return text.equals(tf.getValue()); + } + + @Override + public String toString() { + // Timed out after 10 seconds waiting for ... + return String.format("textfields value was '%s'", + "" + tf.getText()); + } + }); + } + + private void waitUntilFooterCellIsChangedTo(final int cell, + final String footer) { + final TestBenchElement footerCell = $(TableElement.class).first() + .getFooterCell(cell); + + waitUntil(new ExpectedCondition<Boolean>() { + @Override + public Boolean apply(WebDriver input) { + return footer.equals(footerCell.getText()); + } + + @Override + public String toString() { + // Timed out after 10 seconds waiting for ... + return String.format("footer cell %s's text was'%s'", + "" + cell, footerCell.getText()); + } + }); + } +} diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderClick.java b/uitest/src/com/vaadin/tests/components/table/HeaderClick.java index b335e34d84..2bb48a2b40 100644 --- a/uitest/src/com/vaadin/tests/components/table/HeaderClick.java +++ b/uitest/src/com/vaadin/tests/components/table/HeaderClick.java @@ -5,17 +5,17 @@ import com.vaadin.data.Item; import com.vaadin.data.Property; import com.vaadin.data.Property.ValueChangeEvent; import com.vaadin.data.util.IndexedContainer; -import com.vaadin.tests.components.TestBase; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; import com.vaadin.ui.CheckBox; import com.vaadin.ui.Table; import com.vaadin.ui.Table.HeaderClickEvent; import com.vaadin.ui.TextField; -@SuppressWarnings("serial") -public class HeaderClick extends TestBase { +public class HeaderClick extends AbstractTestUI { @Override - protected void setup() { + protected void setup(VaadinRequest request) { final Table table = new Table(); table.setColumnReorderingAllowed(true); table.setContainerDataSource(createContainer()); @@ -27,7 +27,7 @@ public class HeaderClick extends TestBase { "ProperyId of clicked column"); // Add a header click listener - table.addListener(new Table.HeaderClickListener() { + table.addHeaderClickListener(new Table.HeaderClickListener() { @Override public void headerClick(HeaderClickEvent event) { columnField.setValue(String.valueOf(event.getPropertyId())); @@ -37,31 +37,35 @@ public class HeaderClick extends TestBase { CheckBox immediateCheckbox = new CheckBox("Immediate"); immediateCheckbox.setImmediate(true); immediateCheckbox.setValue(table.isImmediate()); - immediateCheckbox.addListener(new Property.ValueChangeListener() { + immediateCheckbox + .addValueChangeListener(new Property.ValueChangeListener() { - @Override - public void valueChange(ValueChangeEvent event) { - table.setImmediate((Boolean) event.getProperty().getValue()); - } - }); + @Override + public void valueChange(ValueChangeEvent event) { + table.setImmediate((Boolean) event.getProperty() + .getValue()); + } + }); CheckBox sortEnabledCheckbox = new CheckBox("Sortable"); sortEnabledCheckbox.setImmediate(true); sortEnabledCheckbox.setValue(table.isSortEnabled()); - sortEnabledCheckbox.addListener(new Property.ValueChangeListener() { + sortEnabledCheckbox + .addValueChangeListener(new Property.ValueChangeListener() { - @Override - public void valueChange(ValueChangeEvent event) { - table.setSortDisabled(!(Boolean) event.getProperty().getValue()); - } - }); + @Override + public void valueChange(ValueChangeEvent event) { + table.setSortEnabled((Boolean) event.getProperty() + .getValue()); + } + }); CheckBox columnReorderingCheckbox = new CheckBox( "Column reordering allowed"); columnReorderingCheckbox.setImmediate(true); columnReorderingCheckbox.setValue(table.isColumnReorderingAllowed()); columnReorderingCheckbox - .addListener(new Property.ValueChangeListener() { + .addValueChangeListener(new Property.ValueChangeListener() { @Override public void valueChange(ValueChangeEvent event) { @@ -79,7 +83,7 @@ public class HeaderClick extends TestBase { } @Override - protected String getDescription() { + public String getDescription() { return "Tests the header click listener"; } diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderClickTest.java b/uitest/src/com/vaadin/tests/components/table/HeaderClickTest.java new file mode 100644 index 0000000000..2ad069540d --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/HeaderClickTest.java @@ -0,0 +1,142 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.table; + +import static org.junit.Assert.assertEquals; + +import java.io.IOException; + +import org.junit.Test; + +import com.vaadin.testbench.TestBenchElement; +import com.vaadin.testbench.elements.CheckBoxElement; +import com.vaadin.testbench.elements.TableElement; +import com.vaadin.testbench.elements.TextFieldElement; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * Tests Table Footer ClickListener + * + * @since + * @author Vaadin Ltd + */ +public class HeaderClickTest extends MultiBrowserTest { + + @Test + public void testFooter() throws IOException { + openTestURL(); + + TableElement table = $(TableElement.class).first(); + TestBenchElement header0 = table.getHeaderCell(0); + header0.click(); + + TextFieldElement tf = $(TextFieldElement.class).first(); + assertEquals("col1", tf.getValue()); + + table = $(TableElement.class).first(); + TestBenchElement header1 = table.getHeaderCell(1); + header1.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col2", tf.getValue()); + + table = $(TableElement.class).first(); + TestBenchElement header2 = table.getHeaderCell(2); + header2.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col3", tf.getValue()); + + CheckBoxElement cb = $(CheckBoxElement.class).first(); + cb.click(); + + table = $(TableElement.class).first(); + header0 = table.getHeaderCell(0); + header0.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col1", tf.getValue()); + + table = $(TableElement.class).first(); + header1 = table.getHeaderCell(1); + header1.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col2", tf.getValue()); + + table = $(TableElement.class).first(); + header2 = table.getHeaderCell(2); + header2.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col3", tf.getValue()); + + cb = $(CheckBoxElement.class).get(1); + cb.click(); + + table = $(TableElement.class).first(); + header0 = table.getHeaderCell(0); + header0.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col1", tf.getValue()); + + table = $(TableElement.class).first(); + header1 = table.getHeaderCell(1); + header1.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col2", tf.getValue()); + + table = $(TableElement.class).first(); + header2 = table.getHeaderCell(2); + header2.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col3", tf.getValue()); + + cb = $(CheckBoxElement.class).get(2); + cb.click(); + + table = $(TableElement.class).first(); + header0 = table.getHeaderCell(0); + header0.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col1", tf.getValue()); + + table = $(TableElement.class).first(); + header1 = table.getHeaderCell(1); + header1.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col2", tf.getValue()); + + table = $(TableElement.class).first(); + header2 = table.getHeaderCell(2); + header2.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col3", tf.getValue()); + + cb = $(CheckBoxElement.class).get(2); + cb.click(); + + tf = $(TextFieldElement.class).first(); + assertEquals("col3", tf.getValue()); + + } +} diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddle.java b/uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddle.java index ec82b36575..09b3dde32c 100644 --- a/uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddle.java +++ b/uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddle.java @@ -5,8 +5,8 @@ import com.vaadin.data.Item; import com.vaadin.data.Property.ValueChangeEvent; import com.vaadin.data.Property.ValueChangeListener; import com.vaadin.data.util.IndexedContainer; -import com.vaadin.tests.components.TestBase; -import com.vaadin.tests.util.Log; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUIWithLog; import com.vaadin.ui.CheckBox; import com.vaadin.ui.Table; import com.vaadin.ui.Table.FooterClickEvent; @@ -14,12 +14,10 @@ import com.vaadin.ui.Table.FooterClickListener; import com.vaadin.ui.Table.HeaderClickEvent; import com.vaadin.ui.Table.HeaderClickListener; -public class HeaderFooterClickLeftRightMiddle extends TestBase { - - private Log log = new Log(10); +public class HeaderFooterClickLeftRightMiddle extends AbstractTestUIWithLog { @Override - protected void setup() { + protected void setup(VaadinRequest request) { final Table table = new Table(); table.setColumnReorderingAllowed(true); table.setContainerDataSource(createContainer()); @@ -31,7 +29,7 @@ public class HeaderFooterClickLeftRightMiddle extends TestBase { CheckBox immediateCheckbox = new CheckBox("Immediate"); immediateCheckbox.setImmediate(true); immediateCheckbox.setValue(table.isImmediate()); - immediateCheckbox.addListener(new ValueChangeListener() { + immediateCheckbox.addValueChangeListener(new ValueChangeListener() { @Override public void valueChange(ValueChangeEvent event) { @@ -42,64 +40,68 @@ public class HeaderFooterClickLeftRightMiddle extends TestBase { CheckBox headerClickListenerCheckbox = new CheckBox( "Header click listener"); headerClickListenerCheckbox.setImmediate(true); - headerClickListenerCheckbox.addListener(new ValueChangeListener() { - - private HeaderClickListener headerClickListener = new HeaderClickListener() { - - @Override - public void headerClick(HeaderClickEvent event) { - String type = event.isDoubleClick() ? "Double click" - : "Click"; - log.log(type + " on header " - + event.getPropertyId().toString() + " using " - + event.getButtonName()); - } - - }; - - @Override - public void valueChange(ValueChangeEvent event) { - if (table.getListeners(HeaderClickEvent.class).isEmpty()) { - table.addListener(headerClickListener); - } else { - table.removeListener(headerClickListener); - } - } - }); + headerClickListenerCheckbox + .addValueChangeListener(new ValueChangeListener() { + + private HeaderClickListener headerClickListener = new HeaderClickListener() { + + @Override + public void headerClick(HeaderClickEvent event) { + String type = event.isDoubleClick() ? "Double click" + : "Click"; + log(type + " on header " + + event.getPropertyId().toString() + + " using " + event.getButtonName()); + } + + }; + + @Override + public void valueChange(ValueChangeEvent event) { + if (table.getListeners(HeaderClickEvent.class) + .isEmpty()) { + table.addHeaderClickListener(headerClickListener); + } else { + table.removeHeaderClickListener(headerClickListener); + } + } + }); headerClickListenerCheckbox.setValue(true); CheckBox footerClickListenerCheckbox = new CheckBox( "Footer click listener"); footerClickListenerCheckbox.setImmediate(true); - footerClickListenerCheckbox.addListener(new ValueChangeListener() { - - private FooterClickListener footerClickListener = new FooterClickListener() { - - @Override - public void footerClick(FooterClickEvent event) { - String type = event.isDoubleClick() ? "Double click" - : "Click"; - log.log(type + " on footer " - + event.getPropertyId().toString() + " using " - + event.getButtonName()); - } - }; - - @Override - public void valueChange(ValueChangeEvent event) { - if (table.getListeners(FooterClickEvent.class).isEmpty()) { - table.addListener(footerClickListener); - } else { - table.removeListener(footerClickListener); - } - } - }); + footerClickListenerCheckbox + .addValueChangeListener(new ValueChangeListener() { + + private FooterClickListener footerClickListener = new FooterClickListener() { + + @Override + public void footerClick(FooterClickEvent event) { + String type = event.isDoubleClick() ? "Double click" + : "Click"; + log(type + " on footer " + + event.getPropertyId().toString() + + " using " + event.getButtonName()); + } + }; + + @Override + public void valueChange(ValueChangeEvent event) { + if (table.getListeners(FooterClickEvent.class) + .isEmpty()) { + table.addFooterClickListener(footerClickListener); + } else { + table.removeFooterClickListener(footerClickListener); + } + } + }); footerClickListenerCheckbox.setValue(true); CheckBox sortEnabledCheckbox = new CheckBox("Sortable"); sortEnabledCheckbox.setImmediate(true); sortEnabledCheckbox.setValue(table.isSortEnabled()); - sortEnabledCheckbox.addListener(new ValueChangeListener() { + sortEnabledCheckbox.addValueChangeListener(new ValueChangeListener() { @Override public void valueChange(ValueChangeEvent event) { table.setSortEnabled((Boolean) event.getProperty().getValue()); @@ -110,14 +112,15 @@ public class HeaderFooterClickLeftRightMiddle extends TestBase { "Column reordering allowed"); columnReorderingCheckbox.setImmediate(true); columnReorderingCheckbox.setValue(table.isColumnReorderingAllowed()); - columnReorderingCheckbox.addListener(new ValueChangeListener() { + columnReorderingCheckbox + .addValueChangeListener(new ValueChangeListener() { - @Override - public void valueChange(ValueChangeEvent event) { - table.setColumnReorderingAllowed((Boolean) event.getProperty() - .getValue()); - } - }); + @Override + public void valueChange(ValueChangeEvent event) { + table.setColumnReorderingAllowed((Boolean) event + .getProperty().getValue()); + } + }); addComponent(immediateCheckbox); addComponent(headerClickListenerCheckbox); @@ -125,12 +128,11 @@ public class HeaderFooterClickLeftRightMiddle extends TestBase { addComponent(sortEnabledCheckbox); addComponent(columnReorderingCheckbox); addComponent(table); - addComponent(log); } @Override - protected String getDescription() { + public String getDescription() { return "Tests the header click listener"; } diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddleTest.java b/uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddleTest.java new file mode 100644 index 0000000000..8d7c632b95 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddleTest.java @@ -0,0 +1,82 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.table; + +import static org.hamcrest.MatcherAssert.assertThat; + +import java.io.IOException; +import java.util.Arrays; + +import org.junit.Test; +import org.openqa.selenium.By; + +import com.vaadin.testbench.elements.TableElement; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * Tests Table Footer ClickListener + * + * @since + * @author Vaadin Ltd + */ +public class HeaderFooterClickLeftRightMiddleTest extends MultiBrowserTest { + + @Test + public void testFooter() throws IOException { + openTestURL(); + + waitForElementPresent(By.className("v-table")); + + TableElement table = $(TableElement.class).first(); + + table.getHeaderCell(0).click(); + assertAnyLogText("1. Click on header col1 using left"); + + table.getHeaderCell(0).contextClick(); + assertAnyLogText("2. Click on header col1 using right"); + + table.getHeaderCell(0).doubleClick(); + assertAnyLogText("4. Double click on header col1 using left", + "5. Double click on header col1 using left"); + + table.getFooterCell(1).click(); + assertAnyLogText("5. Click on footer col2 using left", + "6. Click on footer col2 using left"); + + table.getFooterCell(1).contextClick(); + assertAnyLogText("6. Click on footer col2 using right", + "7. Click on footer col2 using right"); + + table.getFooterCell(1).doubleClick(); + assertAnyLogText("8. Double click on footer col2 using left", + "10. Double click on footer col2 using left"); + } + + private void assertAnyLogText(String... texts) { + assertThat(String.format( + "Correct log text was not found, expected any of %s", + Arrays.asList(texts)), logContainsAnyText(texts)); + } + + private boolean logContainsAnyText(String... texts) { + for (String text : texts) { + if (logContainsText(text)) { + return true; + } + } + return false; + } +} diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderPositionWhenSorting.java b/uitest/src/com/vaadin/tests/components/table/HeaderPositionWhenSorting.java new file mode 100644 index 0000000000..6376ad7df0 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/HeaderPositionWhenSorting.java @@ -0,0 +1,158 @@ +package com.vaadin.tests.components.table; + +import com.vaadin.data.Item; +import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Property.ValueChangeListener; +import com.vaadin.event.Action; +import com.vaadin.event.ItemClickEvent; +import com.vaadin.event.ItemClickEvent.ItemClickListener; +import com.vaadin.server.ExternalResource; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.Component; +import com.vaadin.ui.Link; +import com.vaadin.ui.Notification; +import com.vaadin.ui.Table; + +public class HeaderPositionWhenSorting extends AbstractTestUI implements + Action.Handler, ItemClickListener { + + private Table table; + private boolean actionHandlerHasActions = false; + + @Override + protected void setup(VaadinRequest request) { + CheckBox cb = new CheckBox("Item click listener"); + cb.setImmediate(true); + cb.addValueChangeListener(new ValueChangeListener() { + + @Override + public void valueChange(ValueChangeEvent event) { + if (((Boolean) event.getProperty().getValue())) { + table.addItemClickListener(HeaderPositionWhenSorting.this); + } else { + table.removeItemClickListener(HeaderPositionWhenSorting.this); + } + + } + }); + addComponent(cb); + + CheckBox cbActionHandler = new CheckBox("Action handler"); + cbActionHandler.setImmediate(true); + cbActionHandler.addValueChangeListener(new ValueChangeListener() { + + @Override + public void valueChange(ValueChangeEvent event) { + if (((Boolean) event.getProperty().getValue())) { + table.addActionHandler(HeaderPositionWhenSorting.this); + } else { + table.removeActionHandler(HeaderPositionWhenSorting.this); + } + + } + }); + addComponent(cbActionHandler); + + CheckBox cbActionHasActions = new CheckBox("Action handler has actions"); + cbActionHasActions.setImmediate(true); + cbActionHasActions.addValueChangeListener(new ValueChangeListener() { + + @Override + public void valueChange(ValueChangeEvent event) { + actionHandlerHasActions = ((Boolean) event.getProperty() + .getValue()); + + // Workaround to ensure actions are repainted + removeComponent(table); + addComponent(table); + + } + }); + addComponent(cbActionHasActions); + + createTable(); + addComponent(table); + + } + + private void createTable() { + // Have a table with a numeric column + table = new Table("A table"); + table.addContainerProperty("Name", String.class, null); + table.addContainerProperty("Died At Age", Integer.class, null); + + // Add a generated column with a link to Google + table.addGeneratedColumn("Search", new Table.ColumnGenerator() { + @Override + public Component generateCell(Table source, Object itemId, + Object columnId) { + Item item = source.getItem(itemId); + String name = (String) item.getItemProperty("Name").getValue(); + return new Link("Google for " + name, new ExternalResource( + "http://www.google.co.uk/search?q=" + name)); + } + }); + + // Insert some data + Object people[][] = { { "Galileo", 77 }, { "Monnier", 83 }, + { "Vaisala", 79 }, { "Oterma", 86 } }; + + for (int i = 0; i < people.length; i++) { + table.addItem(people[i], i); + } + + // Calculate the average of the numeric column + double avgAge = 0; + for (int i = 0; i < people.length; i++) { + avgAge += (Integer) people[i][1]; + } + avgAge /= people.length; + + // Set the footers + table.setFooterVisible(true); + table.setColumnFooter("Name", "Average"); + table.setColumnFooter("Died At Age", String.valueOf(avgAge)); + + // Adjust the table height a bit + table.setPageLength(table.size() + 2); + + for (int i = 0; i < people.length; i++) { + Object[] person = people[i]; + String name = (String) person[0]; + addComponent(new Link("Google for " + name, new ExternalResource( + "http://www.google.co.uk/search?q=" + name))); + } + + } + + @Override + public String getDescription() { + return "Table should only prevent the browser context menu when the right click is used for some Table specific operation. In practice these are either action handlers/context menu or item click listeners (right click). Note that item click listeners affects rows only, not the body."; + } + + @Override + protected Integer getTicketNumber() { + return 5924; + } + + @Override + public void itemClick(ItemClickEvent event) { + Notification.show("Click using " + event.getButtonName()); + } + + @Override + public Action[] getActions(Object target, Object sender) { + if (!actionHandlerHasActions) { + return null; + } + + return new Action[] { new Action("test") }; + } + + @Override + public void handleAction(Action action, Object sender, Object target) { + Notification.show("Action: " + action.getCaption()); + } +} diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderPositionWhenSortingTest.java b/uitest/src/com/vaadin/tests/components/table/HeaderPositionWhenSortingTest.java new file mode 100644 index 0000000000..26847a692d --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/HeaderPositionWhenSortingTest.java @@ -0,0 +1,57 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.table; + +import java.io.IOException; + +import org.junit.Test; + +import com.vaadin.testbench.TestBenchElement; +import com.vaadin.testbench.elements.TableElement; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * Tests Table Footer ClickListener + * + * @since + * @author Vaadin Ltd + */ +public class HeaderPositionWhenSortingTest extends MultiBrowserTest { + + @Test + public void testFooter() throws IOException { + openTestURL(); + + TableElement table = $(TableElement.class).first(); + TestBenchElement header1 = table.getHeaderCell(1); + header1.click(); + + compareScreen("sort-asc-died-at-age"); + + header1.click(); + + compareScreen("sort-desc-died-at-age"); + + TestBenchElement header0 = table.getHeaderCell(0); + header0.click(); + + compareScreen("sort-asc-name"); + + header0.click(); + + compareScreen("sort-desc-name"); + } +} diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderSyncOnScroll.java b/uitest/src/com/vaadin/tests/components/table/HeaderSyncOnScroll.java new file mode 100644 index 0000000000..5fe4d4c733 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/HeaderSyncOnScroll.java @@ -0,0 +1,80 @@ +package com.vaadin.tests.components.table; + +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.HorizontalLayout; +import com.vaadin.ui.Table; + +public class HeaderSyncOnScroll extends AbstractTestUI { + + private Table table; + + @Override + public String getDescription() { + return "Header's should be in sync when scrolling"; + } + + @Override + protected Integer getTicketNumber() { + return 17947; + } + + @Override + protected void setup(VaadinRequest request) { + table = new Table(); + table.setWidth("400px"); + table.setHeight("300px"); + table.setPageLength(40); + + table.setFooterVisible(true); + for (int i = 1; i < 11; i++) { + String propertyId = "Property " + i; + table.addContainerProperty(propertyId, String.class, null); + if ((i - 1) % 2 == 0) { + table.setColumnFooter(propertyId, "FOOTER " + i); + } + } + + for (int i = 0; i < 80; i++) { + table.addItem(new String[] { "item " + i + "1", "item " + i + "2", + "item " + i + "3", "item " + i + "4", "item " + i + "5", + "item " + i + "6", "item " + i + "7", "item " + i + "8", + "item " + i + "9", "item " + i + "10" }, i); + } + + addComponent(table); + + HorizontalLayout buttonsLo = new HorizontalLayout(); + addComponent(buttonsLo); + + Button setTableWidth100 = new Button("table.setWidth(100%)", + new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + table.setWidth("100%"); + } + }); + + Button setParent500px = new Button("layout.setWidth(500px)", + new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + table.getParent().setWidth("500px"); + } + }); + + Button setParent100 = new Button("layout.setWidth(100%)", + new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + table.getParent().setWidth("100%"); + } + }); + + buttonsLo.addComponents(setTableWidth100, setParent500px, setParent100); + + } +} diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderSyncOnScrollTest.java b/uitest/src/com/vaadin/tests/components/table/HeaderSyncOnScrollTest.java new file mode 100644 index 0000000000..c9307f0849 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/HeaderSyncOnScrollTest.java @@ -0,0 +1,54 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.table; + +import java.io.IOException; + +import org.junit.Test; + +import com.vaadin.testbench.elements.ButtonElement; +import com.vaadin.testbench.elements.TableElement; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * Tests Table Footer ClickListener + * + * @since + * @author Vaadin Ltd + */ +public class HeaderSyncOnScrollTest extends MultiBrowserTest { + + @Test + public void testFooter() throws IOException { + openTestURL(); + + $(ButtonElement.class).first().click(); + + compareScreen("100pct-no-scrollbar"); + + $(ButtonElement.class).get(1).click(); + + TableElement first = $(TableElement.class).first(); + first.scrollLeft(200); + + compareScreen("300px-scrolled-right"); + + $(ButtonElement.class).get(2).click(); + + compareScreen("100pct-no-scrollbar-second"); + } + +} diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRows.java b/uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRows.java index 6dafdd3dd5..b89582bb7e 100644 --- a/uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRows.java +++ b/uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRows.java @@ -2,14 +2,16 @@ package com.vaadin.tests.components.table; import com.vaadin.data.Property.ValueChangeEvent; import com.vaadin.data.Property.ValueChangeListener; -import com.vaadin.tests.components.TestBase; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; import com.vaadin.ui.CheckBox; import com.vaadin.ui.Table; +import com.vaadin.ui.Table.ColumnHeaderMode; -public class HeaderUpdateWhenNoRows extends TestBase { +public class HeaderUpdateWhenNoRows extends AbstractTestUI { @Override - protected void setup() { + protected void setup(VaadinRequest request) { final Table table = new Table("Test table"); table.addContainerProperty("Name", String.class, null, "Name", null, null); @@ -18,14 +20,14 @@ public class HeaderUpdateWhenNoRows extends TestBase { table.setImmediate(true); final CheckBox showHeaders = new CheckBox("Show headers"); - showHeaders.addListener(new ValueChangeListener() { + showHeaders.addValueChangeListener(new ValueChangeListener() { @Override public void valueChange(ValueChangeEvent event) { if (showHeaders.getValue()) { - table.setColumnHeaderMode(Table.COLUMN_HEADER_MODE_EXPLICIT_DEFAULTS_ID); + table.setColumnHeaderMode(ColumnHeaderMode.EXPLICIT_DEFAULTS_ID); } else { - table.setColumnHeaderMode(Table.COLUMN_HEADER_MODE_HIDDEN); + table.setColumnHeaderMode(ColumnHeaderMode.HIDDEN); } } }); @@ -38,7 +40,7 @@ public class HeaderUpdateWhenNoRows extends TestBase { } @Override - protected String getDescription() { + public String getDescription() { return "The header should be updated when toggling column header mode"; } diff --git a/uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRowsTest.java b/uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRowsTest.java new file mode 100644 index 0000000000..7a3813599d --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRowsTest.java @@ -0,0 +1,54 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.table; + +import java.io.IOException; + +import org.junit.Test; + +import com.vaadin.testbench.TestBenchElement; +import com.vaadin.testbench.elements.CheckBoxElement; +import com.vaadin.testbench.elements.TableElement; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * Tests Table Footer ClickListener + * + * @since + * @author Vaadin Ltd + */ +public class HeaderUpdateWhenNoRowsTest extends MultiBrowserTest { + + @Test + public void testFooter() throws IOException { + openTestURL(); + + TableElement table = $(TableElement.class).first(); + TestBenchElement header0 = table.getHeaderCell(0); + header0.click(); + + compareScreen("headerVisible"); + + $(CheckBoxElement.class).first().click(); + + compareScreen("headerHidden"); + + $(CheckBoxElement.class).first().click(); + + compareScreen("headerVisible2"); + + } +} diff --git a/uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdate.java b/uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdate.java index 98cd4e0aaa..b24c560bfe 100644 --- a/uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdate.java +++ b/uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdate.java @@ -1,19 +1,20 @@ package com.vaadin.tests.components.table; -import com.vaadin.tests.components.TestBase; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; import com.vaadin.ui.Button; import com.vaadin.ui.Button.ClickEvent; import com.vaadin.ui.Button.ClickListener; import com.vaadin.ui.Table; -public class TableVisibleColumnsUpdate extends TestBase { +public class TableVisibleColumnsUpdate extends AbstractTestUI { private String[] cols1 = new String[] { "p1", "p2", "p3" }; private String[] cols2 = new String[] { "p1", "p4", "p3" }; private Table table; @Override - protected String getDescription() { + public String getDescription() { return "Columns should change between p1,p2,p3 and p1,p4,p3"; } @@ -23,7 +24,7 @@ public class TableVisibleColumnsUpdate extends TestBase { } @Override - protected void setup() { + protected void setup(VaadinRequest request) { table = new Table(); table.setWidth("400px"); table.setHeight("100px"); diff --git a/uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdateTest.java b/uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdateTest.java new file mode 100644 index 0000000000..060b79f65f --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdateTest.java @@ -0,0 +1,52 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.table; + +import java.io.IOException; + +import org.junit.Test; + +import com.vaadin.testbench.elements.ButtonElement; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * Tests Table Footer ClickListener + * + * @since + * @author Vaadin Ltd + */ +public class TableVisibleColumnsUpdateTest extends MultiBrowserTest { + + @Test + public void testFooter() throws IOException { + openTestURL(); + + compareScreen("first"); + + $(ButtonElement.class).first().click(); + + compareScreen("second"); + + $(ButtonElement.class).first().click(); + + compareScreen("first2"); + + $(ButtonElement.class).first().click(); + + compareScreen("second2"); + + } +} |