Ranorex v9.5の新機能(Self-Healing機能)
data:image/s3,"s3://crabby-images/c5027/c5027ea6d51c5d9ab305d5a40b3b49e4c8cb36c2" alt=""
2021年7月8日に、国内リリースされた Ranorex バージョン 9.5で、新たにSelf-Healing機能が追加されました。新たに搭載されたSelf-Healing機能では、1つのオブジェクトに対し、RanoreXPathとは別に、もう1つのパス情報(堅牢性重視型のRanoreXPath)を保持することで、テスト実行時にRanoreXPathにてオブジェクトが検出できなくても、もう1つのパス情報を使用してテストの続行を可能とします。
設定方法
① Ranorex Studioにて設定ボタンをクリックします。
data:image/s3,"s3://crabby-images/505e2/505e2adda5184695d67d351de227b74cc88e7a0f" alt=""
② 詳細タブを選択し、高度な設定をクリックします。
data:image/s3,"s3://crabby-images/16bff/16bff215c2ce0ada6c5e266f052bfbf0bdf1e260" alt=""
③ RanoreXPath生成モードを Robust RanoreXPath(new) に変更します。
data:image/s3,"s3://crabby-images/a7e51/a7e51939c3d53c2d6aa5ef68c1d70265ca92450a" alt=""
この設定をおこなうことでSelf-Healing機能が有効となり、Ranorexでオブジェクトのパス情報を取得した時に、RanoreXPathとは別に、堅牢性重視型のRanoreXPathを保持します。
Webアプリケーションを使用した例
Webアプリケーションを使用した、Self-Healing機能の利用例をご紹介します。
① Ranorex Studioで、下図のようなアプリケーションの[発送オプション]をクリックする操作をレコーディングします。
data:image/s3,"s3://crabby-images/2dbda/2dbda9726c1a966ef0f7ab86a487b9016b5c90e8" alt=""
取得したリポジトリアイテムのプロパティで、オブジェクトのRanoreXPath(Absolute Path)と、Self-Healing機能により取得した堅牢性重視型のRanoreXPath(RobustPath)を確認できます。
- RanoreXPath(Absolute Path): /dom[@domain=’localhost:38080′]//div[#’spc-orders’]/div/div/div[3]/div/div/div[2]//fieldset/div[1]/input[@name=’option’]
- 堅牢性重視型のRanoreXPath(RobustPath): /dom[@domain=’localhost:38080′]//div[#’spc-orders’]//input[@name=’option’]
data:image/s3,"s3://crabby-images/90ea2/90ea289b07b2b09abf423ee7d0df0972b7448a45" alt=""
② 画面レイアウトの変更により、[発送オプション]ボタンの位置が変更となった場合、下図の例ではオブジェクトのdom情報(RanoreXPathの構成)も変更されます。
data:image/s3,"s3://crabby-images/146d2/146d285c4ba64a92b98501f38373c3490ab91209" alt=""
画面レイアウトの変更前と比較すると、RanoreXPath(Absolute Path)は異なりますが、Self-Healing機能により取得した堅牢性重視型のRanoreXPath(RobustPath)は同じであることが確認できます。
- RanoreXPath(Absolute Path): /dom[@domain=’localhost:38080′]//div[#’spc-orders’]/div/div[2]/?/?/fieldset/div[1]/input[@name=’option’]
- 堅牢性重視型のRanoreXPath(RobustPath): /dom[@domain=’localhost:38080′]//div[#’spc-orders’]//input[@name=’option’]
data:image/s3,"s3://crabby-images/5cb67/5cb67fb51f1049fd8a68cb612cb9ef831d27ba2d" alt=""
③ 画面レイアウトが変更された②のWebアプリケーションを使用して、①でレコーディングしたRanorexのテストを実行します。
④ 画面レイアウトの変更前と変更後でRanoreXPathが異なるので、本来であればテストを実行した時にオブジェクトが見つからずにエラーとなりますが、RanoreXPathの代わりに、堅牢性重視型のRanoreXPath(RobustPath)が使用されることでオブジェクトが検出され、テストが成功します。
テスト結果のレポートには、堅牢性重視型のRanoreXPath(RobustPath)を使用した内容を表すメッセージが出力されます。
data:image/s3,"s3://crabby-images/e71d7/e71d7a3d3fb6dfe1f03cb6369bc273042ffc5ac0" alt=""
※Self-Healing機能を利用しない(堅牢性重視型のRanoreXPathを取得しない)場合、設定されているRanoreXPathではオブジェクトが検出できず、”Failed to find item” エラーが発生します。
data:image/s3,"s3://crabby-images/df424/df424b0b935aadc588f5b9e17d2ef5b1a1fcf6dd" alt=""
まとめ
本記事では、Self-Healing機能についてご紹介しました。Self-Healing機能を使用し、1つのオブジェクトに対して通常のRanoreXPathと堅牢性重視型のRanoreXPathの2つのパス情報を保持することで、予期しないエラーでテストが中断されることを回避し、より安定したテストを実行することが可能となります。
・ユーザーガイド:設定 – セルフヒーリング
Self-Healing 機能の詳細は、以下の資料にて紹介しております。