トップページ > Selenium API(逆引き) > 【Java】setScriptTimeout

【Java】setScriptTimeout・・・javascript実行が終了するまでの待ち時間を設定する

【PR】業界トップクラスの「高単価報酬」「低マージン」を実現!レバテックフリーランス

「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

Fatal error: Uncaught Google_Service_Exception: Error calling GET https://www.googleapis.com/analytics/v3/data/ga?ids=ga%3A138132118&start-date=7daysAgo&end-date=yesterday&metrics=ga%3Apageviews&dimensions=ga%3ApageTitle%2C+ga%3ApagePath&sort=-ga%3Apageviews&max-results=1000: (404) <!DOCTYPE html> <html lang=en> <meta charset=utf-8> <meta name=viewport content="initial-scale=1, minimum-scale=1, width=device-width"> <title>Error 404 (Not Found)!!1</title> <style> *{margin:0;padding:0}html,code{font:15px/22px arial,sans-serif}html{background:#fff;color:#222;padding:15px}body{margin:7% auto 0;max-width:390px;min-height:180px;padding:30px 0 15px}* > body{background:url(//www.google.com/images/errors/robot.png) 100% 5px no-repeat;padding-right:205px}p{margin:11px 0 22px;overflow:hidden}ins{color:#777;text-decoration:none}a img{border:0}@media screen and (max-width:772px){body{background:none;margin-top:0;max-width:none;padding-right:0}}#logo{background:url(//www.google.com/images/branding/googlelogo/1x/googlelogo_c in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php on line 110