2016-12-27 9 views
1

그래서 나는 유창하고 명확한 대기 시간을 이해하지만 과거에는 암묵적인 진술을 결코 사용할 수 없었습니다. 나는 explicits를 사용하여 그것들을 다루지는 않았지만 꽤 간단했던 테스트를 만들었지 만 Thread.sleep에서만 작동 할 것이고 나는 그 방법을 절대 싫어하고 그것을 전혀 피하려고 노력한다. 그래서 암시 적 대기 함수를 다시 시도했습니다 ... 실패합니다. 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 빌드 정보 : 버전 : '알 수 없음', 개정 : '1969d75', 시간 : 2016-10-18 09:43:45 -0700 ' 시스템 정보 : 호스트 :'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, 회전 가능 = false, databaseEnabled = true , handlesAlerts = true, version = 12602.2.14.0.5, cleanSession = true, platform = MAC, nativeEvents = true, webStorageEnabled = true, browserName = 사파리, javascriptEnabled = true, cssSelectorsEnabled = true}] 세션 ID : DADE0351-039B-4C06-BC65-05FB90E08202 *** 요소 정보 : {use = css selector, value = span.arrow.bottom} at sun.reflect.NativeConstructorAccessorImpl.newInstance0 (기본 방법) at sun java.lang.reflect.Constructor.newInstance (Constructor.java:423) 에서 sun.reflect.DelegatingConstructorAccessorImpl.newInstance (DelegatingConstructorAccessorImpl.java:45) 에서 .reflect.NativeConstructorAccessorImpl.newInstance (NativeConstructorAccessorImpl.java:62)에서 조직 org.openqa.selenium.remote.RemoteWebDriver.execute에서 .openqa.selenium.remote.ErrorHandler.createThrowable (ErrorHandler.java:216) org.openqa.selenium.remote.ErrorHandler.throwIfResponseFailed (ErrorHandler.java:168)에서 (RemoteWebDriver.java:635) org.openqa.selenium.remote.RemoteWebDriver.findElement (RemoteWebDriver.java:368) at org.openqa.selenium.remote.RemoteWebDriver.findElementByCssSelector (RemoteWebDriver.java:465) at org.openqa.selenium.By $ ByCssSelector sun.reflect.NativeMethodAccessorImpl에서 myPackages.statusTest.before (statusTest.java:53) 에서 org.openqa.selenium.remote.RemoteWebDriver.findElement (RemoteWebDriver.java:360) 에서 .findElement (By.java:430) java.lang.reflect.Method.invoke에서 sun.reflect.DelegatingMethodAccessorImpl.invoke (DelegatingMethodAccessorImpl.java:43) 에서 sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java:62) 에서 .invoke0 (기본 방법) (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.자바 : org.junit.runners.BlockJUnit4ClassRunner에서 org.junit.runners.BlockJUnit4ClassRunner.runChild (BlockJUnit4ClassRunner.java:78) 에서 org.junit.runners.ParentRunner.runLeaf (ParentRunner.java:325) 24) . 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. (RemoteTestRunner.java:459) at RemoteTestRunner.java:382) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main (RemoteTestRunner.java:192)

답변

1

밀리 초 대신 암시 적 대기 시간에 TimeUnit.SECONDS를 사용하십시오. 코드를 간략히 살펴보면 암시 적 대기 시간이 100 밀리 초이고 명시 적 대기 시간에 할당 된 3 초와 비교할 때 매우 명목상입니다.

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

참고 : 단위 명시 대기에 대한 초입니다. TIMEUNIT 밀리 초 단위로해야하는 경우

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

1000MS의 =의 1 초

당신은 암시 적 대기에서 3000ms를 사용한다.

+0

WebDriverWait을 3 초 동안 사용하면 WebDriverWait에 따라 약 13 초 정도 걸리거나 이해할 수 있습니다. 그래서 어쨌든 나는 3 초가되도록 내 코드를 변경했고 여전히 작동하지 않았다. 동일한 추적 스택 – Potion

+0

암시 적 대기 및 명시 적 대기를 함께 사용할 필요가 없습니다. 암시 적 및 명시 적 대기는 더 이상 추가되지 않습니다! 암시 적 대기가 선언되면 브라우저는 예외를 throw하기 전에 x 초 동안 대기합니다. – prithvi394

+0

암시 적 대기 상태에서도 원래 코드를 사용해야 만합니다. – Potion