トップページ > Selenium API(逆引き) > イベント処理について

イベント処理について

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

説明

■イベント処理概要					
	Seleniumではイベントに対するイベント処理を独自に実装することが出来ます。
	URLの移動やブラウザの進む/戻るなど、実際のブラウザ操作でイベントを発生させ、
        そのイベントに対する処理を開発者が記述していきます。
	イベントを発生するクラスをイベント発生クラスといい、そのイベントを捕捉するクラスを
        イベント捕捉クラスといいます。
	まとめると以下のようになります(Selenium Python APIを例とし説明していきます)。

	○イベント発生クラス(URLの移動や、ブラウザの進む/戻るの操作など)

		→EventFiringWebDriverクラス内のメソッドを実行させることによりイベントを
       発生させていく。find_elementやget、titleなど
       WebDriverインターフェースと同じようなメソッドが存在する。

	○イベント捕捉クラス(イベント発生をトリガーとして捕捉クラスのメソッドが処理を開始)

		→AbstractEventListenerクラスの拡張クラスを開発者が作成する。
		 AbstractEventListenerクラスは全ての(イベントに対する)メソッドに
                   ダミー実装がされています。下記にAbstractEventListenerクラス
       のメソッドを一部ご紹介します。

        ・before_navigate_back(driver)
         →ブラウザの「戻る」操作をトリガーとして動作するメソッド。
          「戻る」操作直前の状態で処理が実行される。
        ・after_navigate_back(driver)
         →ブラウザの「戻る」操作をトリガーとして動作するメソッド。
          「戻る」操作直後の状態で処理が実行される。

		 開発者はAbstractEventListenerクラスを継承して新規にクラスを作成し、
		 メソッドをオーバーライドしていきます。
		   ここでは例として、継承した新規クラスのメソッドを、以下のようにオーバーライド
       しています。

                  class MyListener(AbstractEventListener):
                      def before_navigate_back(self, driver):
                          #ブラウザの『戻る』直前の処理
                          print("before_navigate_back:Title is " + driver.title)
                      }
                  }

■イベント処理の実行手順について
	①対象のWebDriverとイベント補足クラスのインスタンスをイベント発生クラスに渡し、
	インスタンスを作成する。
    
		#第1引数:WebDriverのインスタンス
		#第2引数:イベント捕捉クラスのインスタンス
		efw_driver = EventFiringWebDriver(driver, MyListener())

        ②efw_driverを通常のdriverとして用い、テストを記述していく。
         記述したテストの中で、MyListenerクラスのメソッドが呼ばれるような
          イベント動作(URLの移動や、ブラウザの進む/戻るの操作など)をした場合は、
          操作したイベントに対応するMyListenerクラスのメソッドが自動的に呼ばれる。
          下記の例では、URL遷移しているので「beforeNavigateTo」と「afterNavigateTo」が呼び
          出される。これらのメソッドはあらかじめ開発者が実装した処理が行われる。
                
                //GoogleのTopページへ遷移する
               eventFiringDriver.get("https://www.google.com");
                                   ・
                                   ・
                                   ・

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