2016-12-27 43 views
1

所以我理解流利和明确的等待,但我永远无法得到隐含的陈述去工作。我设法不使用表达式来处理它们,但是我设计了一个相当简单的测试,但它只适用于Thread.sleep,并且我绝对HATE该方法,并且不惜一切代价避免它。所以我试图再次隐式等待函数...失败。我的代码Thread.sleep有效,但不是隐式等待?

的用了Thread.Sleep下面的代码按预期工作,是伟大的

package myPackages; 

import java.util.concurrent.TimeUnit; 

// Unit test testing the Main User Drop Down Menu 
// This tests the following: 
//  - changing status to Online, Away, Busy, Invisible via Left menu 
//  - Going to Settings 
//  - Logging out 

import org.junit.AfterClass; 
import org.junit.Assert; 
import org.junit.Before; 
import org.junit.BeforeClass; 
import org.junit.Test; 
import org.openqa.selenium.By; 
import org.openqa.selenium.WebDriver; 
import org.openqa.selenium.safari.SafariDriver; 
import org.openqa.selenium.support.ui.ExpectedConditions; 
import org.openqa.selenium.support.ui.WebDriverWait; 

public class statusTest { 

    private static WebDriver driver = new SafariDriver(); 

    public static String HOME_URL = "http://localhost:3000"; 
    public static String currentUserStatus; 

    private static By usernameOrEmailFieldLocator = By.id("emailOrUsername"); 
    private static By passwordFieldLocator = By.id("pass"); 
    private static By loginButtonLocator = By.cssSelector("button.button.primary.login"); 

    private static By openMenuLocator = By.cssSelector("span.arrow.bottom"); 

    private static By onlineButtonLocator = By.cssSelector("button.status.online"); 
    private static By awayButtonLocator = By.cssSelector("button.status.away"); 
    private static By busyButtonLocator = By.cssSelector("button.status.busy"); 
    private static By invisibleButtonLocator = By.cssSelector("button.status.offline"); 
    private static By userStatus = By.className("thumb"); 


    @BeforeClass 
    public static void beforeClass() { 
    driver.get(HOME_URL); 
    driver.findElement(usernameOrEmailFieldLocator).sendKeys("adrian"); 
    driver.findElement(passwordFieldLocator).sendKeys("adrian"); 
    driver.findElement(loginButtonLocator).click(); 
    } 

    @Before 
    public void before() throws Exception { 
    Thread.sleep(100); 
    new WebDriverWait(driver, 3).until(ExpectedConditions.presenceOfElementLocated(openMenuLocator)).click(); 
    Thread.sleep(100); 
    new WebDriverWait(driver, 3).until(ExpectedConditions.presenceOfElementLocated(onlineButtonLocator)).click(); 
    } 

    @AfterClass 
    public static void doEnd() { 
    driver.quit(); 
    } 

    private static void changeStatusTo(By statusLocator) throws Exception { 
    Thread.sleep(100); 
    new WebDriverWait(driver, 3).until(ExpectedConditions.presenceOfElementLocated(statusLocator)).click(); 
    Thread.sleep(100); 
    currentUserStatus = driver.findElement(userStatus).getAttribute("data-status"); 
    } 

    @Test 
    public void setAway() throws Exception { 
    changeStatusTo(awayButtonLocator); 
    Assert.assertEquals("away", currentUserStatus); 
    } 

    @Test 
    public void setOnline() throws Exception { 
    changeStatusTo(onlineButtonLocator); 
    Assert.assertEquals("online", currentUserStatus); 
    } 

    @Test 
    public void setBusy() throws Exception { 
    changeStatusTo(busyButtonLocator); 
    Assert.assertEquals("busy", currentUserStatus); 
    } 

    @Test 
    public void setInvisible() throws Exception { 
    changeStatusTo(invisibleButtonLocator); 
    Assert.assertEquals("invisible", currentUserStatus); 
    } 

} 

但当我结束了试图使用隐式(如下图)这是行不通的。我确保在声明驱动程序后立即声明一次(本例中为@beforeclass)。在Before类中测试会失败。我包括在最底部此页面上的跟踪堆栈:

package myPackages; 

import java.util.concurrent.TimeUnit; 

import org.junit.AfterClass; 
import org.junit.Assert; 
import org.junit.Before; 
import org.junit.BeforeClass; 
import org.junit.Test; 
import org.openqa.selenium.By; 
import org.openqa.selenium.WebDriver; 
import org.openqa.selenium.safari.SafariDriver; 
import org.openqa.selenium.support.ui.ExpectedConditions; 
import org.openqa.selenium.support.ui.WebDriverWait; 

public class statusTest { 

    private static WebDriver driver = new SafariDriver(); 

    public static String HOME_URL = "http://localhost:3000"; 
    public static String currentUserStatus; 

    private static By usernameOrEmailFieldLocator = By.id("emailOrUsername"); 
    private static By passwordFieldLocator = By.id("pass"); 
    private static By loginButtonLocator = By.cssSelector("button.button.primary.login"); 

    private static By openMenuLocator = By.cssSelector("span.arrow.bottom"); 

    private static By onlineButtonLocator = By.cssSelector("button.status.online"); 
    private static By awayButtonLocator = By.cssSelector("button.status.away"); 
    private static By busyButtonLocator = By.cssSelector("button.status.busy"); 
    private static By invisibleButtonLocator = By.cssSelector("button.status.offline"); 
    private static By userStatus = By.className("thumb"); 


    @BeforeClass 
    public static void beforeClass(){ 
     driver.manage().timeouts().implicitlyWait(100, TimeUnit.MILLISECONDS); 
     driver.get(HOME_URL); 
     driver.findElement(usernameOrEmailFieldLocator).sendKeys("adrian"); 
     driver.findElement(passwordFieldLocator).sendKeys("adrian"); 
     driver.findElement(loginButtonLocator).click(); 
    } 

    @Before 
    public void before() throws Exception { 
     driver.findElement(openMenuLocator).click(); 
     driver.findElement(onlineButtonLocator).click(); 
    } 

    @AfterClass 
    public static void doEnd() { 
     driver.quit(); 
    } 

    private static void changeStatusTo(By statusLocator) { 
     driver.findElement(statusLocator).click(); 
     currentUserStatus = driver.findElement(userStatus).getAttribute("data-status"); 

    } 

    @Test 
    public void setAway() { 
     changeStatusTo(awayButtonLocator); 
     Assert.assertEquals("away", currentUserStatus); 
    } 

    @Test 
    public void setOnline() { 
     changeStatusTo(onlineButtonLocator); 
     Assert.assertEquals("online", currentUserStatus); 
    } 

    @Test 
    public void setBusy() { 
     changeStatusTo(busyButtonLocator); 
     Assert.assertEquals("busy", currentUserStatus); 
    } 

    @Test 
    public void setInvisible() { 
     changeStatusTo(invisibleButtonLocator); 
     Assert.assertEquals("invisible", currentUserStatus); 
    } 

} 

org.openqa.selenium.NoSuchElementException:一个元素找不到使用给定的搜索参数的网页上。 (警告:服务器未提供任何堆栈跟踪信息) 命令持续时间或超时:999毫秒 有关此错误的文档,请访问:http://seleniumhq.org/exceptions/no_such_element.html 构建信息:版本:'unknown',修订版本:'1969d75',时间:' 2016-10-18 09:43:45 -0700' 系统信息:host:'Adrians-iMac.local',ip:'10 .0.2.15',os.name:'Mac OS X',os.arch:' x86_64',os.version:'10 .12.1',java.version:'1.8.0_111' 驱动程序信息:org.openqa.selenium.safari.SafariDriver 功能[{applicationCacheEnabled = true,rotated = false,databaseEnabled = true ,handlesAlerts = true,version = 12602.2.14.0.5,cleanSession = true,platform = MAC,nativeEvents = true,locationContextEnabled = false,webStorageEnabled = true,browserName = safari,javascriptEnabled = true,cssSelectorsEnabled = true}] 会话ID:DADE0351-039B-4C06-BC65-05FB90E08202 ***元素信息:{Using = css selector,value = span.arrow.bottom} at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun .reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) 在sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 在java.lang.reflect.Constructor.newInstance(Constructor.java:423) 在有机.openqa.selenium.remote.ErrorHandler.createThrowable(ErrorHandler.java:216) 在org.openqa.selenium.remote.ErrorHandler.throwIfResponseFailed(ErrorHandler.java:168) 在org.openqa.selenium.remote.RemoteWebDriver.execute (RemoteWebDriver.java:635) 在org.openqa.selenium.remote.RemoteWebDriver.findElement(RemoteWebDriver.java:368) 在org.openqa.selenium.remote.RemoteWebDriver.findElementByCssSelector(RemoteWebDriver.java:465) 在org.openqa.selenium.By $ ByCssSelector .findElement(By.java:430) 在org.openqa.selenium.remote.RemoteWebDriver.findElement(RemoteWebDriver.java:360) 在myPackages.statusTest.before(statusTest.java:53) 在sun.reflect.NativeMethodAccessorImpl .invoke0(本机方法) 在sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 在java.lang.reflect.Method.invoke( Method.java:498) at org.junit.runners.model.Framewo rkMethod $ 1.runReflectiveCall(FrameworkMethod.java:50) at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java :47) at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores。的java:24) 在org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) 在org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) 在org.junit.runners.BlockJUnit4ClassRunner。 rungild(BlockJUnit4ClassRunner.java:57) at org.junit.runners.ParentRunner $ 3.run(ParentRunner.java:290) at org.junit.runners.ParentRunner $ 1.schedule(ParentRunner.java:71) at org。 junit.runners.ParentRunner.runChildren(ParentRunner.java:288) at org.junit.runners.ParentRunner.access $ 000(ParentRunner.java:58) at org.junit.runners.ParentRunner $ 2.evaluate(ParentRunner.java: 268) at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) at org.juni t.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) at org.junit.runners.ParentRunner.run(ParentRunner.java:363) at org.eclipse.jdt.internal.junit4.runner。 JUnit4TestReference.run(JUnit4TestReference.java:86) at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner。 runTests(RemoteTestRunner.java:459) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:678) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run( (RemoteTestRunner.java:192)

回答

1

在隐式等待中使用TimeUnit.SECONDS而不是毫秒。快速浏览你的代码表明你已经使用了100毫秒的隐式等待,这是非常标称的,而在明确的等待中分配了3秒。

driver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);//waits for 3 seconds 

注意:显式等待的单位是秒。

new WebDriverWait(driver, 10) //will wait for 10 seconds 

1000毫秒= 1秒

您应该使用3000ms内隐等待如果TIMEUNIT必须以毫秒为单位。

+0

据我所知,如果我使用3秒的隐式WebDriverWait为10秒,那么它会运行约13秒,取决于WebDriverWait的正确性?所以无论如何我改变了我的代码是3秒,它似乎仍然没有工作。相同的跟踪堆栈 – Potion

+0

您不需要使用隐式等待和显式等待。此外,隐式和显式等待不会加起来!一旦声明了隐式等待,浏览器将在抛出异常之前等待x秒。 – prithvi394

+0

所以我甚至不应该隐式等待,只使用我的原始代码? – Potion