summaryrefslogtreecommitdiffstats
path: root/uitest/src
diff options
context:
space:
mode:
authorJohannes Tuikkala <johannes@vaadin.com>2015-09-17 08:41:45 +0300
committerVaadin Code Review <review@vaadin.com>2015-09-18 13:21:11 +0000
commit467c00af32548861c7bb44fc5e3e00fa9829b9a2 (patch)
treeb3e4c36bfe5ea77bfff82308012870008ecf2200 /uitest/src
parente71f6cfd817ffddb7c9cc4a7855d248a859d837f (diff)
downloadvaadin-framework-467c00af32548861c7bb44fc5e3e00fa9829b9a2.tar.gz
vaadin-framework-467c00af32548861c7bb44fc5e3e00fa9829b9a2.zip
Converting TB2 tests for ticket #17947
Change-Id: I3357e736a024da0a5f8096f51840964b19f822a4
Diffstat (limited to 'uitest/src')
-rw-r--r--uitest/src/com/vaadin/tests/components/table/Footer.java12
-rw-r--r--uitest/src/com/vaadin/tests/components/table/FooterClick.java37
-rw-r--r--uitest/src/com/vaadin/tests/components/table/FooterClickTest.java116
-rw-r--r--uitest/src/com/vaadin/tests/components/table/FooterTest.java206
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderClick.java42
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderClickTest.java142
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddle.java130
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderFooterClickLeftRightMiddleTest.java82
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderPositionWhenSorting.java158
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderPositionWhenSortingTest.java57
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderSyncOnScroll.java80
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderSyncOnScrollTest.java54
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRows.java16
-rw-r--r--uitest/src/com/vaadin/tests/components/table/HeaderUpdateWhenNoRowsTest.java54
-rw-r--r--uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdate.java9
-rw-r--r--uitest/src/com/vaadin/tests/components/table/TableVisibleColumnsUpdateTest.java52
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");
+
+ }
+}