diff options
author | Henri Sara <henri.sara@gmail.com> | 2017-08-11 10:29:07 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-08-11 10:29:07 +0300 |
commit | e9316021b415e59120a186a649604bf8ecffc513 (patch) | |
tree | 23420905cc2171a1370e3172d8b6c333ca7a6cdb /uitest/src/test | |
parent | 66e68f1ef25804dabfb4b0e4cdd7d59c66522927 (diff) | |
download | vaadin-framework-e9316021b415e59120a186a649604bf8ecffc513.tar.gz vaadin-framework-e9316021b415e59120a186a649604bf8ecffc513.zip |
Ensure wrong Action is not executed after detaching a component (#9806)
Due to action key generation on ActionManager a wrong action
may be executed if the component that fired the wanted action
is already detached.
This patch makes action keys globally unique, simplifying the
approach of #8495 but reusing its tests.
Fixes #5864
Diffstat (limited to 'uitest/src/test')
-rw-r--r-- | uitest/src/test/java/com/vaadin/tests/actions/ActionsOnDetachedComponentsTest.java | 90 | ||||
-rw-r--r-- | uitest/src/test/java/com/vaadin/tests/components/ui/WindowAndUIShortcutsTest.java | 2 |
2 files changed, 92 insertions, 0 deletions
diff --git a/uitest/src/test/java/com/vaadin/tests/actions/ActionsOnDetachedComponentsTest.java b/uitest/src/test/java/com/vaadin/tests/actions/ActionsOnDetachedComponentsTest.java new file mode 100644 index 0000000000..9410dfecba --- /dev/null +++ b/uitest/src/test/java/com/vaadin/tests/actions/ActionsOnDetachedComponentsTest.java @@ -0,0 +1,90 @@ +/* + * Copyright 2000-2016 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.actions; + +import static org.hamcrest.CoreMatchers.endsWith; +import static org.hamcrest.CoreMatchers.not; +import static org.junit.Assert.assertThat; + +import java.util.List; + +import org.junit.Before; +import org.junit.Test; +import org.openqa.selenium.WebElement; +import org.openqa.selenium.interactions.Actions; +import org.openqa.selenium.remote.DesiredCapabilities; + +import com.vaadin.testbench.By; +import com.vaadin.testbench.elements.TableElement; +import com.vaadin.testbench.parallel.BrowserUtil; +import com.vaadin.tests.tb3.MultiBrowserTest; + +/** + * @author Vaadin Ltd + */ +public class ActionsOnDetachedComponentsTest extends MultiBrowserTest { + + @Before + public void init() { + openTestURL(); + if (BrowserUtil.isFirefox(getDesiredCapabilities())) { + // focus the page to make shortcuts go to the right place + getDriver().findElement(By.className("v-app")).click(); + } + } + + @Override + public List<DesiredCapabilities> getBrowsersToTest() { + return getBrowsersSupportingContextMenu(); + } + + @Test + public void shortcutActionOnDetachedComponentShouldNotBeHandled() + throws InterruptedException { + + Actions k = new Actions(driver); + k.sendKeys("a").perform(); + k.sendKeys("a").perform(); + sleep(500); + + assertElementNotPresent(By.id("layer-A")); + assertElementPresent(By.id("layer-B")); + assertThat(getLogRow(0), endsWith("btn-A")); + assertThat(getLogRow(1), not(endsWith("btn-B"))); + + } + + @Test + public void actionOnDetachedComponentShouldNotBeHandled() + throws InterruptedException { + TableElement table = $(TableElement.class).first(); + table.getRow(0).contextClick(); + // Find the opened menu + WebElement menu = findElement(By.className("v-contextmenu")); + WebElement menuitem = menu + .findElement(By.xpath("//*[text() = 'Table action']")); + + Actions doubleClick = new Actions(getDriver()); + doubleClick.doubleClick(menuitem).build().perform(); + + assertElementNotPresent(By.id("layer-A")); + assertElementPresent(By.id("layer-B")); + assertThat(getLogRow(0), endsWith("tableAction")); + assertThat(getLogRow(1), not(endsWith("tableAction"))); + + } + +} diff --git a/uitest/src/test/java/com/vaadin/tests/components/ui/WindowAndUIShortcutsTest.java b/uitest/src/test/java/com/vaadin/tests/components/ui/WindowAndUIShortcutsTest.java index 7c14ae0864..715025bf5e 100644 --- a/uitest/src/test/java/com/vaadin/tests/components/ui/WindowAndUIShortcutsTest.java +++ b/uitest/src/test/java/com/vaadin/tests/components/ui/WindowAndUIShortcutsTest.java @@ -35,6 +35,8 @@ public class WindowAndUIShortcutsTest extends SingleBrowserTest { $(ButtonElement.class).caption("Open dialog window").first().click(); WindowElement window = $(WindowElement.class).first(); + // for PhantomJS to have the focus in the right place + window.click(); window.$(TextFieldElement.class).first().sendKeys(Keys.ESCAPE); // Window should have been closed |