2016-12-27 10 views
1

私は流暢かつ明示的な待機を理解しましたが、過去に暗黙のステートメントを実行することはできませんでした。私はexplicitsを使ってそれらを扱わないように管理しましたが、かなりシンプルなテストを設計しましたが、Thread.sleepでしか動作しませんでした。私は絶対にそのメソッドを嫌い、それをどうしても避けようとします。だから私は再び暗黙の待機関数を試みた...失敗します。My code 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ミリ秒 ビルド情報:バージョン: '不明'、改訂: '1969d75'、時刻: 2016-10-18 09:43:45 -0700 ' システム情報:ホスト:' Adrians-iMac.local '、ip:'10 .0.2.15'、os.name: 'Mac OS X'、os.arch: 'ドライバの情報:org.openqa.selenium.safari.SafariDriver 機能[{applicationCacheEnabled = true、rotateatable = false、databaseEnabled = true 、handlesAlerts = true、version = 12602.2.14.0.5、cleanSession = true、platform = MAC、nativeEvents = true、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(ネイティブメソッド) at sun ORGでjava.lang.reflect.Constructor.newInstance(Constructor.java:423) で.reflect.NativeConstructorAccessorImpl.newInstance sun.reflect.DelegatingConstructorAccessorImpl.newInstanceで(NativeConstructorAccessorImpl.java:62) (DelegatingConstructorAccessorImpl.java:45) .openqa.selenium.remote.ErrorHandler.createThrowable(ErrorHandler.java:216) at org.openqa.selenium.remote.ErrorHandler.throwIfResponseFailed(ErrorHandler.java:168) at org.openqa.selenium.remote.RemoteWebDriver.execute (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。Javaの:24) org.junit.runners.ParentRunner.runLeafで(org.junit.runners.BlockJUnit4ClassRunnerでorg.junit.runners.BlockJUnit4ClassRunner.runChildでParentRunner.java:325) (BlockJUnit4ClassRunner.java:78) 。 runChild(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。 org.junit.runners.ParentRunner.access $ 000(ParentRunner.java:58) at org.junit.runners.ParentRunner $ 2.evaluate(ParentRunner.java:58) (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:382) at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

答えて

1

ミリ秒ではなく暗黙の待機でTimeUnit.SECONDSを使用します。あなたのコードをすばやく見ると、明示的な待機で割り当てられた3秒に比べて非常に名目的な暗黙の待機で100ミリ秒を使用したことが示されます。

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

注:明示的な待機の単位は秒です。

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

1000ミリ秒の= 1sと

TIMEUNITはミリ秒単位でする必要がある場合は、暗黙の待機中に3000msを使用する必要があります。

+0

WebDriverWaitを3秒間で暗黙的に使用すると、WebDriverWaitが10秒間実行された場合、WebDriverWaitに応じて約13秒かかりますか?だからとにかく私のコードを3秒に変更しましたが、それでも動作していないようです。同じトレーススタック – Potion

+0

暗黙的な待機と明示的な待機を一緒に使用する必要はありません。暗黙的な待機が宣言されると、ブラウザは例外をスローする前にx秒間待機します。 – prithvi394

+0

暗黙の待ちでも元のコードを使うべきではないでしょうか? – Potion

関連する問題