From 1571143b96271b6c41a4f54dab7421cf3e7e085c Mon Sep 17 00:00:00 2001 From: Sauli Tähkäpää Date: Mon, 31 Mar 2014 10:44:44 +0300 Subject: Added a button hitting method to AbstractTB3Test. Refactored LayoutTesterApplicationTest. Refactored SliderDisableTest. Change-Id: I038fedb9d234656b85359ce7fb778b001e6f4402 --- .../tests/components/slider/SliderDisableTest.java | 15 +++++----- .../layouttester/LayoutTesterApplicationTest.java | 32 ++++++--------------- .../src/com/vaadin/tests/tb3/AbstractTB3Test.java | 8 ++++++ .../com/vaadin/tests/tb3/ScreenshotTB3Test.java | 33 ++++++++++++---------- 4 files changed, 43 insertions(+), 45 deletions(-) diff --git a/uitest/src/com/vaadin/tests/components/slider/SliderDisableTest.java b/uitest/src/com/vaadin/tests/components/slider/SliderDisableTest.java index f8fed28fac..923d0f46ab 100644 --- a/uitest/src/com/vaadin/tests/components/slider/SliderDisableTest.java +++ b/uitest/src/com/vaadin/tests/components/slider/SliderDisableTest.java @@ -17,6 +17,7 @@ package com.vaadin.tests.components.slider; import static org.hamcrest.CoreMatchers.containsString; import static org.hamcrest.CoreMatchers.is; +import static org.hamcrest.CoreMatchers.not; import static org.hamcrest.MatcherAssert.assertThat; import java.io.IOException; @@ -33,16 +34,16 @@ public class SliderDisableTest extends MultiBrowserTest { public void disableSlider() throws IOException { openTestURL(); - assertSliderHandlePositionIs(38); + String originalPosition = getSliderHandlePosition(); - // Move slider handle from 38px to 150px moveSlider(112); + String expectedPosition = getSliderHandlePosition(); + assertThat(expectedPosition, is(not(originalPosition))); - assertSliderHandlePositionIs(150); - driver.findElement(By.id("disableButton")).click(); + hitButton("disableButton"); assertSliderIsDisabled(); - assertSliderHandlePositionIs(150); + assertThat(getSliderHandlePosition(), is(expectedPosition)); } private void assertSliderIsDisabled() { @@ -56,9 +57,9 @@ public class SliderDisableTest extends MultiBrowserTest { testBench().waitForVaadin(); } - private void assertSliderHandlePositionIs(int position) { + private String getSliderHandlePosition() { WebElement handle = driver.findElement(By.className("v-slider-handle")); - assertThat(handle.getCssValue("margin-left"), is(position + "px")); + return handle.getCssValue("margin-left"); } } \ No newline at end of file diff --git a/uitest/src/com/vaadin/tests/layouts/layouttester/LayoutTesterApplicationTest.java b/uitest/src/com/vaadin/tests/layouts/layouttester/LayoutTesterApplicationTest.java index 8996e62503..6ba5109ce7 100644 --- a/uitest/src/com/vaadin/tests/layouts/layouttester/LayoutTesterApplicationTest.java +++ b/uitest/src/com/vaadin/tests/layouts/layouttester/LayoutTesterApplicationTest.java @@ -22,11 +22,10 @@ import java.util.Set; import org.junit.Test; import org.openqa.selenium.By; -import org.openqa.selenium.JavascriptExecutor; -import org.openqa.selenium.WebElement; import org.openqa.selenium.remote.DesiredCapabilities; import org.openqa.selenium.support.ui.Select; +import com.thoughtworks.selenium.webdriven.WebDriverBackedSelenium; import com.vaadin.tests.tb3.MultiBrowserTest; import com.vaadin.ui.GridLayout; import com.vaadin.ui.HorizontalLayout; @@ -39,6 +38,7 @@ public class LayoutTesterApplicationTest extends MultiBrowserTest { DesiredCapabilities cap = new DesiredCapabilities( super.getDesiredCapabilities()); cap.setCapability("nativeEvents", false); + return cap; } @@ -86,7 +86,6 @@ public class LayoutTesterApplicationTest extends MultiBrowserTest { new Select(vaadinElementById("layoutSelect").findElement( By.xpath("select"))) .selectByVisibleText(layoutClass.toString()); - focusElementWithId("nextButton"); for (String subTest : LayoutTesterApplication.layoutGetters) { compareScreen(subTest); @@ -96,22 +95,12 @@ public class LayoutTesterApplicationTest extends MultiBrowserTest { clickAndCompareScreen(subTest, "testButton" + i); } } - getNextButton().click(); + + hitButton("nextButton"); } } - /** - * @param elementId - * the id of the element to focus - */ - private void focusElementWithId(String elementId) { - // This should really be in TestBench - ((JavascriptExecutor) getDriver()) - .executeScript("document.getElementById('" + elementId - + "').focus()"); - } - /** * Clicks the button with the given id and compares the result to a * screenshot named 'screenshotPrefix'-buttonCaption. @@ -122,15 +111,16 @@ public class LayoutTesterApplicationTest extends MultiBrowserTest { */ private void clickAndCompareScreen(String screenshotPrefix, String buttonId) throws Exception { - WebElement button = vaadinElementById(buttonId); - button.click(); + hitButton(buttonId); + if (needsDelayToStabilize(screenshotPrefix)) { // Table does some extra layout phase and TestBench does not always // take this into account, grabbing screenshots before the layout // phase is done (see #12866). - sleep(200); + sleep(350); } - compareScreen(screenshotPrefix + "-" + sanitize(button.getText())); + compareScreen(screenshotPrefix + "-" + + sanitize(driver.findElement(By.id(buttonId)).getText())); } private boolean needsDelayToStabilize(String screenshotPrefix) { @@ -140,8 +130,4 @@ public class LayoutTesterApplicationTest extends MultiBrowserTest { private String sanitize(String text) { return text.replace("%", "pct").replaceAll("[^a-zA-Z0-9]", "-"); } - - private WebElement getNextButton() { - return vaadinElementById(LayoutTesterApplication.NEXT_BUTTON_ID); - } } diff --git a/uitest/src/com/vaadin/tests/tb3/AbstractTB3Test.java b/uitest/src/com/vaadin/tests/tb3/AbstractTB3Test.java index 55a2b80918..ba5c81e846 100644 --- a/uitest/src/com/vaadin/tests/tb3/AbstractTB3Test.java +++ b/uitest/src/com/vaadin/tests/tb3/AbstractTB3Test.java @@ -42,6 +42,7 @@ import org.openqa.selenium.support.ui.ExpectedCondition; import org.openqa.selenium.support.ui.ExpectedConditions; import org.openqa.selenium.support.ui.WebDriverWait; +import com.thoughtworks.selenium.webdriven.WebDriverBackedSelenium; import com.vaadin.server.LegacyApplication; import com.vaadin.server.UIProvider; import com.vaadin.testbench.TestBench; @@ -928,4 +929,11 @@ public abstract class AbstractTB3Test extends TestBenchTestCase { return ((HasInputDevices) getDriver()).getKeyboard(); } + public void hitButton(String id) { + WebDriverBackedSelenium selenium = new WebDriverBackedSelenium(driver, + driver.getCurrentUrl()); + + selenium.keyPress("id=" + id, "\\13"); + } + } diff --git a/uitest/src/com/vaadin/tests/tb3/ScreenshotTB3Test.java b/uitest/src/com/vaadin/tests/tb3/ScreenshotTB3Test.java index a51421d3d5..9f966d7973 100644 --- a/uitest/src/com/vaadin/tests/tb3/ScreenshotTB3Test.java +++ b/uitest/src/com/vaadin/tests/tb3/ScreenshotTB3Test.java @@ -101,22 +101,21 @@ public abstract class ScreenshotTB3Test extends AbstractTB3Test { File mainReference = getScreenshotReferenceFile(identifier); - List alternativeFiles = findReferenceAlternatives(mainReference); - List failedReferenceAlternatives = new ArrayList(); + List referenceFiles = findReferenceAndAlternatives(mainReference); + List failedReferenceFiles = new ArrayList(); - for (File file : alternativeFiles) { - if (testBench(driver).compareScreen(file)) { + for (File referenceFile : referenceFiles) { + if (testBench(driver).compareScreen(referenceFile)) { + // There might be failure files because of retries in TestBench. + deleteFailureFiles(referenceFile); break; } else { - failedReferenceAlternatives.add(file); + failedReferenceFiles.add(referenceFile); } } File referenceToKeep = null; - if (failedReferenceAlternatives.size() != alternativeFiles.size()) { - // Matched one comparison but not all, remove all error images + - // HTML files - } else { + if (failedReferenceFiles.size() == referenceFiles.size()) { // Ensure we use the correct browser version (e.g. if running IE11 // and only an IE 10 reference was available, then mainReference // will be for IE 10, not 11) @@ -143,18 +142,22 @@ public abstract class ScreenshotTB3Test extends AbstractTB3Test { // Remove all PNG/HTML files we no longer need (failed alternative // references or all error files (PNG/HTML) if comparison succeeded) - for (File failedAlternative : failedReferenceAlternatives) { + for (File failedAlternative : failedReferenceFiles) { File failurePng = getErrorFileFromReference(failedAlternative); if (failedAlternative != referenceToKeep) { // Delete png + HTML - File failureHtml = htmlFromPng(failurePng); - - failurePng.delete(); - failureHtml.delete(); + deleteFailureFiles(failurePng); } } } + private void deleteFailureFiles(File failurePng) { + File failureHtml = htmlFromPng(failurePng); + + failurePng.delete(); + failureHtml.delete(); + } + /** * Returns a new File which points to a .html file instead of the given .png * file @@ -189,7 +192,7 @@ public abstract class ScreenshotTB3Test extends AbstractTB3Test { * @return all references which should be considered when comparing with the * given files, including the given reference */ - private List findReferenceAlternatives(File reference) { + private List findReferenceAndAlternatives(File reference) { List files = new ArrayList(); files.add(reference); -- cgit v1.2.3