Selenium は、 Webアプリケーションテストするためのポータブルフレームワークである。 Selenium は、テストスクリプト言語(Selenium IDE)を学ぶ必要なしに、機能テストを作成するための再生ツールを提供する。また、C#GroovyJavaPerlPHPPythonRubyScala 等の一般的なプログラミング言語でテストを作成するためのテストドメイン固有言語(Selenese)も提供する。その後、テストはほとんどの最新のWebブラウザに対して実行できる。Selenium は、WindowsLinux、およびmacOSで動作する。これは、Apache License 2.0 の下でリリースされたオープンソースソフトウェアである。

Selenium
最新版
4.1.4 / 2022年5月5日 (2年前) (2022-05-05)[1]
リポジトリ ウィキデータを編集
プログラミング
言語
Java
対応OS クロスプラットフォーム
種別 ソフトウェアテスト ウェブアプリケーションのためのソフトウェアフレームワーク
ライセンス Apache License 2.0
公式サイト selenium.dev ウィキデータを編集
テンプレートを表示

歴史 編集

Selenium は、2004年にJason Huggins によってThoughtWorks の内部ツールとして開発された。 Huggins は後に、ThoughtWorks の他のプログラマテスタが参加し、Paul Hammant がチームに加わり、後に「Selenium Remote Control」(RC)となる2番目の操作モードの開発を進めた。ツールはその年オープンソース化された。

2005年、Dan Fabulich とNelson Sproul は、(Pat Lightbodyの助力を得て)Selenium-RC を最も有名なものに変える一連のパッチを受け入れることを申し出た。同じ会議で、プロジェクトとしてのSelenium の運営は委員会として継続され、Huggins とHammant がThoughtWorks の代表となった。

2007年、Huggins はGoogle に加わった。Jennifer Bevan のような他の人と共に、彼はSelenium RC の開発と安定化を続けた。同時に、ThoughtWorks のSimon Stewart は、WebDriver と呼ばれる優れたブラウザ自動化ツールを開発した。2009年、Google Test Automation Conference での開発者間の会議の後、2つのプロジェクトをマージし、新しいプロジェクトをSelenium WebDriver またはSelenium 2.0 と呼ぶことが決定した[2]

2008年、Philippe Hanrigou(当時はThoughtWorks)は「Selenium Grid」を作成した。これは、複数のローカルまたはリモートシステムで複数のSelenium テストを同時に実行できるハブを提供し、テストの実行時間を最小限に抑える。 グリッドは、オープンソースとして、Selenium RC の内部/プライベートGoogle クラウドと同様の機能を提供した。Pat Lightbody はすでに「HostedQA」のプライベートクラウドを作成しており、これをGomez、Inc. に販売した。

Selenium の名前は、メールでHuggins が作ったジョークに由来し、マーキュリーという競合他社をあざけって、Selenium(セレン)のサプリメントを摂取することで水銀中毒を治すことができると述べている。メールを受け取った他の人は名前を取り、それを採用した[3]

コンポーネント 編集

Selenium はいくつかのコンポーネントで構成され、それぞれがWeb アプリケーションテスト自動化の開発を支援する特定の役割を果たす[4]

Selenium IDE 編集

Selenium IDE は、Selenium テスト用の完全な統合開発環境(IDE)である。これは、 FirefoxアドオンおよびChrome 拡張機能として実装される。機能テストの記録、編集、デバッグが可能である。 以前はSelenium Recorder として知られていた。Selenium IDE は、もともと笠谷真也によって作成され、2006年にSelenium プロジェクトに寄付された。Selenium IDE は以前はほとんどメンテナンスされていなかった[5]。Selenium IDE は2018年に積極的にメンテナンスされ始め[6][7][8][9]、SideeXが開発基礎とされた[10]

スクリプトは自動的に記録され、手動で編集されて、自動補完サポートとコマンドをすばやく移動する機能を提供する。スクリプトは、Selenium 用の特別なテストスクリプト言語であるSelenese で記録される。Selenese には、ブラウザでアクションを実行(リンクをクリックしてオプションを選択)するコマンド、および結果のページからデータを取得するコマンドが用意されている。

Firefox 用のSelenium IDE の2.xバージョンは、Firefox 55 のアップグレード後に機能しなくなり[11]、Selenium IDE 3.x に置き換えられた[12]

公式のSelenium IDE プロジェクトに加えて、2つの代替Selenium IDE ブラウザ拡張機能が積極的に維持されている[13]: Kantu(オープンソースGPLライセンス)とKatalon Recorder(クローズドソース)。

Selenium クライアントAPI 編集

Selenese でテストを作成する代わりに、テストをさまざまなプログラミング言語で作成することもできる。これらのテストは、Selenium クライアントAPIのメソッドを呼び出すことによってSelenium と通信する。Selenium は現在、JavaC#RubyJavaScriptRPython 用のクライアントAPIを提供している。

Selenium 2では、WebDriver を中心コンポーネントとして使用する新しいクライアントAPIが導入された。ただし、古いクラス(Selenium クラスを使用)は引き続きサポートされる。

Selenium WebDriver 編集

Selenium WebDriver は、Selenium RC の後継である。Selenium WebDriver は(Selenese で、またはクライアントAPIを介して送信される)コマンドを受け入れ、それらをブラウザに送信する。これは、ブラウザにコマンドを送信して結果を取得するブラウザ固有のブラウザ・ドライバを介して実装される。ほとんどのブラウザ・ドライバは、実際にブラウザアプリケーション(FirefoxGoogle ChromeInternet ExplorerSafariMicrosoft Edge 等)を起動してアクセスする。ヘッドレスブラウザーHtmlUnitを使用してブラウザーをシミュレートするHtmlUnit ブラウザ・ドライバもある。

テストを実行するためにSelenium サーバが必要であったSelenium 1とは異なり、Selenium WebDriver はテストを実行するために特別なサーバを必要としない。代わりに、WebDriver は直接ブラウザインスタンスを起動して制御する。ただし、Selenium Grid をWebDriver と共に使用して、リモートシステムでテストを実行できる(以下参照)。可能な場合、WebDriver はブラウザベースのJavaScript コマンドではなく、ネイティブのオペレーティングシステムレベルの機能を使用してブラウザを駆動する。これにより、セキュリティ制限等、ネイティブコマンドとJavaScript コマンドの微妙な違いに関する問題が回避される[14]

実際には、これはSelenium 2.0 API の呼び出しがSelenium 1.0 API の呼び出しよりも大幅に少ないことを意味する。Selenium 1.0は、さまざまなブラウザ操作に豊富なインターフェースを提供しようとしたが、Selenium 2.0は、開発者が独自のドメイン固有言語を作成できる基本的なビルディングブロックのセットを提供することを目的としている。そのようなDSL の1つは既に存在する。Ruby 言語のWatir プロジェクトには、優れた設計の豊富な歴史がある。 Watir-webdriver は、Ruby のSelenium-Webdriver のラッパーとしてWatir API を実装している。 Watir-Webdriverは、WebDriver 仕様とHTML 仕様に基づいて、完全に自動的に作成される。

2012年の初めに、当時Google に、現在はFacebook にいたSimon Stewart(WebDriver の発明者)とMozilla のDavid Burns は、WebDriver をインターネット標準にするためにW3Cと交渉している。2012年7月にワーキングドラフトがリリースされ、2018年6月に勧告が行われた[15]。Selenium-Webdriver(Selenium 2.0)は、PythonRubyJava、およびC#で完全に実装およびサポートされている。

Selenium リモートコントロール 編集

Selenium Remote Control(RC)は、Java で記述されたサーバであり、HTTP経由でブラウザのコマンドを受け入れる。 RCを使用すると、任意のプログラミング言語Web アプリケーションの自動テストを作成できる。これにより、Selenium を既存の単体テストフレームワークに適切に統合できる。テストの記述を簡単にするために、Selenium プロジェクトは現在、PHPPythonRuby.NETPerlJava 等のクライアント・ドライバを提供している。 Java ドライバはRhino エンジン経由でJavaScript でも使用できる。HTML テストケースを起動するには、Selenium RC サーバのインスタンスが必要である。つまり、並列実行ごとにポートが異なる必要がある[要出典]。ただし、Java/PHP テストケースでは、1つのSelenium RC インスタンスのみを継続的に実行する必要がある[16]

Selenium Remote Controlは、Paul Hammant によって設計されたDriven Selenium またはSelenium B のリファクタリングであり、Selenium の共同作成者としてJason 氏と称された。 元のバージョンは、Java.NETPython またはRuby のテスト言語から、問題のブラウザのプロセスを直接起動した。Wire protocol(当時は「Selenese」と呼ばれていた)は、各言語ポートで再実装された。 Dan Fabulich とNelson Sproul によるリファクタリングの後(Pat Lightbody の助力を得て)、ドライビング・テスト・スクリプトとブラウザの間に中間デーモンプロセスがあった。利点には、リモートブラウザを駆動する機能と、コードのすべての行をますます成長する言語のセットに移植する必要性の減少が含まれる。Selenium Remote Control は、2006年にDriven Selenium コードラインから完全に引き継がれた。'Driven' / 'B' および 'RC' のブラウザパターンは応答/要求だったが、後にCometと呼ばれるようになった。

Selenium 2 のリリースに伴い、Selenium RC はSelenium WebDriver を支持して正式に非推奨になった。

Selenium Grid 編集

Selenium Grid は、リモートマシンで実行されているWeb ブラウザインスタンスをテストで使用できるようにするサーバである。Selenium Grid では、1つのサーバがハブとして機能する。 テストはハブに接続して、ブラウザインスタンスへのアクセスを取得する。ハブには、ブラウザインスタンス(WebDriver ノード)へのアクセスを提供するサーバのリストがあり、テストでこれらのインスタンスを使用できる。Selenium Grid を使用すると、複数のマシンで並行してテストを実行し、さまざまなブラウザのバージョンとブラウザの構成を、個別のテストではなく、集中管理できる。

リモートブラウザインスタンスでテストを実行する機能は、テストの負荷を複数のマシンに分散し、異なるプラットフォームまたはオペレーティングシステムで実行されているブラウザでテストを実行するのに役立つ。後者は、テストに使用されるすべてのブラウザが同じプラットフォームで実行できない場合に特に役立つ。

参考 編集

脚注 編集

  1. ^ Releases - SeleniumHQ/selenium”. 2022年5月5日閲覧。
  2. ^ The Selenium Project”. NewCircle. 2014年6月29日閲覧。
  3. ^ Krill, Paul (April 6, 2011). Open source Selenium web app test suite to support iPhone and Android. http://news.techworld.com/applications/3272444/open-source-selenium-web-app-test-suite-to-support-iphone-and-android/ 2012年5月9日閲覧。. 
  4. ^ Moizuddin (2018年6月7日). “Components of the Selenium Automation Tool”. dzone.com. DevOps Zone. 2019年7月10日閲覧。
  5. ^ Evans. “Selenium Users - Selenium IDE seems dated and lacks features”. groups.google.com. 2016年2月7日閲覧。
  6. ^ It’s back! Selenium IDE Reborn with Dave Haeffner”. testingpodcast.com. 2018年12月26日閲覧。
  7. ^ Selenium IDE Is Dead, Long Live Selenium IDE!”. Selenium IDE Official Blog (2018年8月6日). 2019年11月27日閲覧。
  8. ^ Colantonio (2018年11月27日). “Stunning return of Selenium IDE”. testguild.com. 2019年11月27日閲覧。
  9. ^ List of new Selenium IDE features”. applitools.com. 2019年7月19日閲覧。
  10. ^ Selenium IDE v0.1”. 2021年2月26日閲覧。
  11. ^ Firefox 55 and Selenium IDE”. Official Selenium Blog (2017年8月9日). 2017年8月21日閲覧。
  12. ^ Selenium IDE Download Site”. seleniumhq.org. 2018年5月10日閲覧。
  13. ^ Selenium IDE rises like a phoenix from the ashes”. Automation Technology Blog. 2019年4月8日閲覧。
  14. ^ The Architecture of Open Source Applications: Selenium WebDriver”. aosabook.org. 2016年2月7日閲覧。
  15. ^ Smith. “WebDriver motors on to W3C Recommendation”. W3C Blog. 2018年9月10日閲覧。
  16. ^ Selenium Remote-Control”. seleniumhq.org. 2019年11月13日閲覧。

外部リンク 編集