「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