「before_change_value_of/after_change_value_of」を実行することで要素の値が変更される直前/直後の処理を実施することが出来ます。
イベント処理をするためにまず初めにすることは、イベント捕捉クラスを定義することです。ここで、イベント捕捉クラスをMyListenerクラスと命名します。MyListenerクラスは、AbstractEventListenerクラスを継承して作成されたサブクラスです。AbstractEventListenerクラスの関数はダミー実装がされているためMyListenerクラスでイベントに対応した各関数をオーバーライドする必要があります。ここでは、「before_change_value_of/after_change_value_of」の関数の内容をオーバーライドしています。
それでは、実際にイベント発生させていきます。イベントを発生させる前に、Firefoxのインスタンスドライバに対してイベント捕捉クラスのインスタンスを渡します。そしてそのインスタンスドライバに対して、ページ遷移(GoogleTopページ)をした後、検索テキストボックスの要素を取得しています。
この段階では、「before_change_value_of/after_change_value_of」の関数が自動で呼び出される条件は満たしていません。これらの関数が自動で呼び出されるトリガーとなる操作(イベントが発生する操作)は、キー入力またはキー入力された値がクリアされた時です。そのため、「Test finished!!!」とキー入力されたときに初めてイベントが発生し、キー入力前後の検索テキストボックスの入力値がコンソール出力されます。
※イベント処理についてはこちら
説明
◆メソッド ・before_change_value_of(element, driver) ・after_change_value_of(element, driver) ◆使用形態 ・上記メソッドはあらかじめAbstractEventListenerクラスを継承して オーバーライドしておく。 ◆備考 ・このイベントはsend_keys,clearメソッドの実行にて発生する。 ◆関連項目 ・ブラウザの『戻る』または『進む』に対して直前/直後の処理を実施する ・URLが遷移する直前/直後の処理を実施する
サンプル
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') #Googleの検索テキストボックスの要素をname属性名から取得 element = driver.find_element(:name, 'q') #検索テキストボックスにキー入力する element.send_keys('Test finished!!')
class MyListener < Selenium::WebDriver::Support::AbstractEventListener #イベント捕捉クラス(MyListenerクラス)を定義する #MyListenerクラスはAbstractEventListenerクラスのサブクラス #AbstractEventListenerクラスでは関数がダミー実装されており、MyListenerクラスで関数をオーバーライドしていく def initialize(log) @log = log end #キー入力直前の検索テキストボックスの値を標準出力する def before_change_value_of(element, driver) @log.info("before_change_value_of: #{element.attribute("value")}") end #キー入力直後の検索テキストボックスの値を標準出力する def after_change_value_of(element, driver) @log.info("after_change_value_of: #{element.attribute("value")}") end end
実行結果
I, [2018-03-21T14:15:30.675905 #12964] INFO -- : before_change_value_of: I, [2018-03-21T14:15:30.736905 #12964] INFO -- : after_change_value_of: Test finished!!