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

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

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

「script_timeout」を実行することで、javascript実行が終了するまでの待ち時間を設定することが出来ます。

下記サンプルでは、指定したドライバに対して「script_timeout」を実行しています。「script_timeout」に数値(秒数)を代入することで指定した待ち時間の間、javascript実行が終了するまで待機します。 仮にjavascript実行時間が「script_timeout」に代入した待ち時間を超えた場合は、ScriptTimeOutErrorが発生してしまいます。

説明

◆メソッド
  ・script_timeout
◆使用形態
  ・driver.manage.timeouts.script_timeout = 10
◆備考
  ・待ち時間には秒数を指定
  ・非同期スクリプトの待ち時間を設定する
  ・設定した待ち時間を越えてjavascriptが動作していた場合ScriptTimeOutErrorが発生する
◆関連項目
  ・指定したドライバの要素が見つかるまでの待ち時間を設定する
  ・ページがロードされるまでの待ち時間を設定する

サンプル

require 'selenium-webdriver'
 
# Firefoxを起動
driver = Selenium::WebDriver.for(:firefox)
#Javascript実行が終了するまで最大5秒間待つように指定
driver.manage.timeouts.script_timeout = 5
#現在時刻を取得
startTime = Time.now
#指定時間待機する非同期スクリプト(ここでは3秒待機)
driver.execute_async_script('window.setTimeout(arguments[arguments.length - 1], 3000);')
#3秒後に再び時刻を取得
stopTime = Time.now
#差分の時間を表示する
print(stopTime - startTime)
※selenium version 4.1.0で動作確認をしています

実行結果

3.017024

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: (403) User does not have sufficient permissions for this profile. in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php:110 Stack trace: #0 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php(62): Google_Http_REST::decodeHttpResponse(Object(Google_Http_Request), Object(Google_Client)) #1 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Task/Runner.php(174): Google_Http_REST::doExecute(Object(Google_Client), Object(Google_Http_Request)) #2 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php(46): Google_Task_Runner->run() #3 /home/users/1/monda-muki/web/seleniumqref in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php on line 110