「setScriptTimeout」を実行することで、javascript実行が終了するまでの待ち時間を設定することが出来ます。
下記サンプルでは、指定したドライバに対して「setScriptTimeout」を実行しています。「setScriptTimeout」の引数に数値(秒数)を指定することで、指定した待ち時間の間、javascript実行が終了するまで待機します。 仮にjavascript実行時間が「setScriptTimeout」の引数に指定した待ち時間を超えた場合は、TimeoutExceptionが発生してしまいます。
説明
◆メソッド ・WebDriver.Timeouts setScriptTimeout(long time, java.util.concurrent.TimeUnit unit) ◆使用形態 ・driver.manage().timeouts().setScriptTimeout(time,TimeUnit)) ◆備考 ・非同期スクリプトの待ち時間を設定する ・設定した待ち時間を越えてjavascriptが動作していた場合ScriptTimeoutExceptionが発生する ◆関連項目 ・HTTP 200が返ってくるまでの待ち時間を設定する ・指定したドライバの要素が見つかるまでの待ち時間を設定する
サンプル
import java.time.Duration;
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
public class WebTest{
public static void main(String[] args){
//Chrome制御のためChromeDriverのパスを指定
System.setProperty("webdriver.chrome.driver",
"D:\\AutoTest\\chromedriver.exe");
//Chromeを起動する
WebDriver driver = new ChromeDriver();
//Javascript実行が終了するまで最大5秒間待つように指定
Duration waitTime = Duration.ofSeconds(5);
driver.manage().timeouts().scriptTimeout(waitTime);
//現在時刻を取得
long start = System.currentTimeMillis();
//指定時間待機する非同期スクリプト(ここでは3秒待機)
((JavascriptExecutor) driver).executeAsyncScript
("window.setTimeout(arguments[arguments.length - 1], 3000);");
//再度現在時刻を取得し差分の時間を表示する
System.out.print("経過時間: "+ (System.currentTimeMillis() - start));
}
}※selenium version 4.1.4で動作確認をしています(ブラウザのUIや属性値などが変更された場合、実行結果が異なる可能性があります)
実行結果
経過時間: 3073
