Cisco のアプリケーション監視ソリューション,AppDynamics では世界中に分散したリモートサーバ上で Python スクリプトを定期実行,スクリプトに記述された手順にしたがい仮想ユーザが webブラウザを操作,webアプリケーションに性能上の問題や,障害は発生していないか定期監視を行うことが可能な Browser Synthetic Monitoring
従来,Synthetic モニタリングにおいて実行する Python スクリプトの作成はやや煩雑でしたが,Chrome / Firefox 上で利用可能な拡張機能,Katalon Recorder
本投稿では,Katalon Recorder
今回は以下の環境を用い,外形監視ジョブスクリプトの生成,ローカルテストを実施いたしました。
この手順は必須ではありませんが,リモートサーバ上で Python スクリプトを実行する前に,ローカル PC / Mac / Linux VM / Docker 等で事前テストを行う際に必要となります。
pip3 コマンドを用い,Selenium をインストールします。
pip3 install selenium
Chrome のアドレスバーに次の URL を入力し,バージョンを確認します。
chrome://settings/help
私の環境では 88.0.4324.182 となっていました。
ここで,ChromeDriver – WebDriver for Chrome
今回は 88.0.4324.96 がダウンロード可能でしたので,以下のコマンドで ChromeDriver をインストールします。
sudo pip3 install chromedriver-binary==88.0.4324.96
下記のリンクをクリック,Chrome Web Store より Katalon Recorder 拡張機能をインストールします。
Katalon Recorder (Selenium tests generator)
以下の手順で外形監視監視ジョブを Katalon Recorder により記録します。
Katalon Recorder の上部メニューの右,{} Export をクリックし,
Format Python (AppDynamics)
を選択します。 下部の Cipy to Clipboard でクリップボードにコピーすることができます。
以下のような Python スクリプトが生成されました。
# -*- coding: utf-8 -*- # sell_supercar.py from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.common.keys import Keys from selenium.webdriver.support.ui import Select from selenium.common.exceptions import NoSuchElementException from selenium.common.exceptions import NoAlertPresentException import unittest, time, re class AppDynamicsJob(unittest.TestCase): def setUp(self): self.driver = webdriver.Firefox() self.driver.implicitly_wait(30) self.base_url = "https://www.google.com/" self.verificationErrors = [] self.accept_next_alert = True def test_app_dynamics_job(self): driver = self.driver driver.get("http://34.215.115.155:8080/Supercar-Trader/home.do") driver.find_element_by_xpath("//a[5]/img").click() driver.find_element_by_id("carModel").click() driver.find_element_by_id("carModel").clear() driver.find_element_by_id("carModel").send_keys("DB9") driver.find_element_by_id("carEngine").clear() driver.find_element_by_id("carEngine").send_keys("V8") driver.find_element_by_id("carColor").clear() driver.find_element_by_id("carColor").send_keys("Green") driver.find_element_by_id("carYear").clear() driver.find_element_by_id("carYear").send_keys("2021") driver.find_element_by_id("carPrice").clear() driver.find_element_by_id("carPrice").send_keys("200000") driver.find_element_by_id("commit").click() def is_element_present(self, how, what): try: self.driver.find_element(by=how, value=what) except NoSuchElementException as e: return False return True def is_alert_present(self): try: self.driver.switch_to_alert() except NoAlertPresentException as e: return False return True def close_alert_and_get_its_text(self): try: alert = self.driver.switch_to_alert() alert_text = alert.text if self.accept_next_alert: alert.accept() else: alert.dismiss() return alert_text finally: self.accept_next_alert = True def tearDown(self): # To know more about the difference between verify and assert, # visit https://www.seleniumhq.org/docs/06_test_design_considerations.jsp#validating-results self.assertEqual([], self.verificationErrors) if __name__ == "__main__": unittest.main()
ここで,以下の行で Firefox ドライバーを利用するコードとなっていますが,今回は ChromeDriver を用いてローカルテストを行いますので,
self.driver = webdriver.Firefox()
以下のように変更します。
self.driver = webdriver.Chrome()
変更後の Python スクリプトを実行し,以下のような結果となれば,ローカルテストは正常に完了しています。
$ python3 sell_supercar.py . ---------------------------------------------------------------------- Ran 1 test in 10.784s OK
AppDynamics コントローラ上で,以下の手順で生成した Python スクリプトを設定します。
ジョブ設定ダイアログの 2-8 の項目を適宜設定し,Save でジョブ設定を完了します。
ジョブ作成が完了すると,監視スケジュールにもよりますが,自動的に監視が開始され,しばらく経つと Jobs に以下のようなジョブ実行ステータスが表示されます。
また,ジョブをクリックしますと,各外形監視ジョブ・セッションのリストに遷移します。
各セッションのステータスが Success (緑) になっており,外形監視ジョブが正常に実行できていることが確認できます。
今回は Chrome ブラウザ上で Katalon Recorder 拡張機能を用い,AppDynamics Browser Synthetic Monitoring 用 Python スクリプトを生成しました。従来と比較して非常に簡単に外形監視ジョブスクリプトが作成できるようになったと言えます。