「before_execute_script/after_execute_script」を実行することでjavascriptを実行する直前/直後の処理を実施することが出来ます。
イベント処理をするためにまず初めにすることは、イベント捕捉クラスを定義することです。ここで、イベント捕捉クラスをMyListenerクラスと命名します。MyListenerクラスは、AbstractEventListenerクラスを継承して作成されたサブクラスです。AbstractEventListenerクラスの関数はダミー実装がされているためMyListenerクラスでイベントに対応した各関数をオーバーライドする必要があります。ここでは、「before_execute_script/after_execute_script」の関数の内容をオーバーライドしています。
それでは、実際にイベント発生させていきます。イベントを発生させる前に、Firefoxのインスタンスドライバに対してイベント捕捉クラスのインスタンスを渡します。そしてそのインスタンスドライバに対して、ページ遷移(GoogleTopページ)をしています。
この段階では、「before_execute_script/after_execute_script」の関数が自動で呼び出される条件は満たしていません。これらの関数が自動で呼び出されるトリガーとなる操作(イベントが発生する操作)は、javascriptが実行された時です。そのため、下記サンプルを例にすると、Alertが表示されて初めてイベントが発生し、「before_execute_script/after_execute_script」が実行されます。
※イベント処理についてはこちら
説明
◆メソッド ・before_execute_script(script, driver) ・after_execute_script(script, driver) ◆使用形態 ・上記メソッドはあらかじめAbstractEventListenerクラスを継承して オーバーライドしておく。 ◆備考 ・このイベントはexecute_async_script(script)メソッドまたは、 execute_script(script)実行にて発生する ◆関連項目 ・要素がクリックされる直前/直後の処理を実施する ・要素の値が変更される直前/直後の処理を実施する
サンプル
require 'selenium-webdriver' require './MyListener' require 'logger' #loggerを初期化する(標準出力へのログ) logger = Logger.new(STDOUT) #MyListenerクラスのインスタンスを作成 listener = MyListener.new(logger) #FirefoxのインスタンスドライバにMyListenerクラスのインスタンスを渡す driver = Selenium::WebDriver.for(:firefox, :listener => listener) #指定したURLに遷移する driver.get('https://www.google.co.jp') #Javascriptを実行する driver.execute_script("window.alert('Test finished!')")
class MyListener < Selenium::WebDriver::Support::AbstractEventListener #イベント捕捉クラス(MyListenerクラス)を定義する #MyListenerクラスはAbstractEventListenerクラスのサブクラス #AbstractEventListenerクラスでは関数がダミー実装されており、MyListenerクラスで関数をオーバーライドしていく def initialize(log) @log = log end #Javascript実行直前の処理 def before_execute_script(script, driver) @log.info("before_execute_script: Alert is not displayed!") end #Javascript実行直後の処理 def after_execute_script(script, driver) @log.info("after_execute_script: Alert is displayed!") end end
※selenium version 4.1.0で動作確認をしています
実行結果
I, [2018-03-25T14:17:51.452318 #6152] INFO -- : before_execute_script: Alert is not displayed! I, [2018-03-25T14:17:51.493318 #6152] INFO -- : after_execute_script: Alert is displayed!