aboutsummaryrefslogtreecommitdiffstats
path: root/uitest
diff options
context:
space:
mode:
authorTeemu Suo-Anttila <teemusa@vaadin.com>2015-10-13 17:40:31 +0300
committerVaadin Code Review <review@vaadin.com>2015-10-14 13:45:11 +0000
commita2b1860c163a26b92b8e2ca3ae227a27b75ca55c (patch)
treef218ec383ee617eca5b7980d621fa62302769417 /uitest
parent0c54d540e679cce4dad71e0e8e9f3f7bc917cba3 (diff)
downloadvaadin-framework-a2b1860c163a26b92b8e2ca3ae227a27b75ca55c.tar.gz
vaadin-framework-a2b1860c163a26b92b8e2ca3ae227a27b75ca55c.zip
Support Grid context click events in the empty areas of Grid (#19128)
Change-Id: Ia6aebc266c48fb284ebf8f7a89375390555d1bec
Diffstat (limited to 'uitest')
-rw-r--r--uitest/src/com/vaadin/tests/contextclick/AbstractContextClickTest.java8
-rw-r--r--uitest/src/com/vaadin/tests/contextclick/AbstractContextClickUI.java18
-rw-r--r--uitest/src/com/vaadin/tests/contextclick/GridContextClick.java20
-rw-r--r--uitest/src/com/vaadin/tests/contextclick/GridContextClickTest.java16
4 files changed, 53 insertions, 9 deletions
diff --git a/uitest/src/com/vaadin/tests/contextclick/AbstractContextClickTest.java b/uitest/src/com/vaadin/tests/contextclick/AbstractContextClickTest.java
index cff063db5f..272cbfdc0e 100644
--- a/uitest/src/com/vaadin/tests/contextclick/AbstractContextClickTest.java
+++ b/uitest/src/com/vaadin/tests/contextclick/AbstractContextClickTest.java
@@ -79,7 +79,9 @@ public abstract class AbstractContextClickTest extends MultiBrowserTest {
AbstractComponentElement component = $(AbstractComponentElement.class)
.id("testComponent");
- contextClick(component);
+ int x = 20;
+ int y = 20;
+ contextClick(component, x, y);
Point l = component.getLocation();
@@ -91,8 +93,8 @@ public abstract class AbstractContextClickTest extends MultiBrowserTest {
int xCoord = Integer.parseInt(matcher.group(1));
int yCoord = Integer.parseInt(matcher.group(2));
- int xExpected = l.getX() + 10;
- int yExpected = l.getY() + 10;
+ int xExpected = l.getX() + x;
+ int yExpected = l.getY() + y;
Assert.assertTrue(
"X Coordinate differs too much from expected. Expected: "
diff --git a/uitest/src/com/vaadin/tests/contextclick/AbstractContextClickUI.java b/uitest/src/com/vaadin/tests/contextclick/AbstractContextClickUI.java
index 9a0ef31692..e1d741ee88 100644
--- a/uitest/src/com/vaadin/tests/contextclick/AbstractContextClickUI.java
+++ b/uitest/src/com/vaadin/tests/contextclick/AbstractContextClickUI.java
@@ -23,6 +23,7 @@ import com.vaadin.tests.components.AbstractTestUIWithLog;
import com.vaadin.ui.AbstractComponent;
import com.vaadin.ui.Button;
import com.vaadin.ui.Button.ClickEvent;
+import com.vaadin.ui.HorizontalLayout;
@Theme("valo")
public abstract class AbstractContextClickUI<T extends AbstractComponent, E extends ContextClickEvent>
@@ -79,14 +80,21 @@ public abstract class AbstractContextClickUI<T extends AbstractComponent, E exte
testComponent.setId("testComponent");
addComponent(testComponent);
-
- addComponent(new Button("Add/Remove default listener",
- new ListenerHandler(defaultListener)));
- addComponent(new Button("Add/Remove typed listener",
- new ListenerHandler(typedListener)));
+ addComponent(createContextClickControls());
}
protected abstract T createTestComponent();
protected abstract void handleContextClickEvent(E event);
+
+ protected HorizontalLayout createContextClickControls() {
+ HorizontalLayout contextClickControls = new HorizontalLayout();
+ contextClickControls.addComponent(new Button(
+ "Add/Remove default listener", new ListenerHandler(
+ defaultListener)));
+ contextClickControls
+ .addComponent(new Button("Add/Remove typed listener",
+ new ListenerHandler(typedListener)));
+ return contextClickControls;
+ }
}
diff --git a/uitest/src/com/vaadin/tests/contextclick/GridContextClick.java b/uitest/src/com/vaadin/tests/contextclick/GridContextClick.java
index a942a2ab0f..77009a0762 100644
--- a/uitest/src/com/vaadin/tests/contextclick/GridContextClick.java
+++ b/uitest/src/com/vaadin/tests/contextclick/GridContextClick.java
@@ -18,8 +18,11 @@ package com.vaadin.tests.contextclick;
import com.vaadin.data.Item;
import com.vaadin.shared.ui.grid.GridConstants.Section;
import com.vaadin.tests.util.PersonContainer;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.Button.ClickEvent;
import com.vaadin.ui.Grid;
import com.vaadin.ui.Grid.GridContextClickEvent;
+import com.vaadin.ui.HorizontalLayout;
public class GridContextClick extends
AbstractContextClickUI<Grid, GridContextClickEvent> {
@@ -34,7 +37,8 @@ public class GridContextClick extends
"phoneNumber", "address.streetAddress", "address.postalCode",
"address.city");
- grid.setSizeFull();
+ grid.setWidth("100%");
+ grid.setHeight("400px");
return grid;
}
@@ -58,4 +62,18 @@ public class GridContextClick extends
log("ContextClickEvent value: " + value + ", propertyId: " + propertyId
+ ", section: " + event.getSection());
}
+
+ @Override
+ protected HorizontalLayout createContextClickControls() {
+ HorizontalLayout controls = super.createContextClickControls();
+ controls.addComponent(new Button("Remove all content",
+ new Button.ClickListener() {
+
+ @Override
+ public void buttonClick(ClickEvent event) {
+ testComponent.getContainerDataSource().removeAllItems();
+ }
+ }));
+ return controls;
+ }
}
diff --git a/uitest/src/com/vaadin/tests/contextclick/GridContextClickTest.java b/uitest/src/com/vaadin/tests/contextclick/GridContextClickTest.java
index 25847f8bf2..7b97de2be5 100644
--- a/uitest/src/com/vaadin/tests/contextclick/GridContextClickTest.java
+++ b/uitest/src/com/vaadin/tests/contextclick/GridContextClickTest.java
@@ -19,9 +19,11 @@ import static org.junit.Assert.assertEquals;
import org.junit.Test;
+import com.vaadin.testbench.elements.ButtonElement;
import com.vaadin.testbench.elements.GridElement;
public class GridContextClickTest extends AbstractContextClickTest {
+
@Test
public void testBodyContextClickWithTypedListener() {
addOrRemoveTypedListener();
@@ -73,4 +75,18 @@ public class GridContextClickTest extends AbstractContextClickTest {
getLogRow(0));
}
+ @Test
+ public void testContextClickInEmptyGrid() {
+ addOrRemoveTypedListener();
+
+ $(ButtonElement.class).caption("Remove all content").first().click();
+
+ contextClick($(GridElement.class).first(), 100, 100);
+
+ assertEquals(
+ "1. ContextClickEvent value: , propertyId: null, section: BODY",
+ getLogRow(0));
+
+ }
+
}