はじめに
こんにちは。一升餅と申します。
今回の記事では、こちらのテスト自動化の練習用のテスト対象サイト「HOTEL PLANISPHERE」を使わせて頂き、ログインから宿泊の予約を行うテストケースを作成していきたいと思います。
このサイトはいろいろな機能があって、本当にありがたいです。
私のT-DASHの使用状況について簡単に説明です。
T-DASHを使い慣れているわけではありませんが、既に一度テストケースの作成までは行っています。
前回触ってから間が空いてしまったので、復習がてら簡単なテストケースを作成したいという気持ちです。
なので既にT-DASHを使っている方は、この記事を読んでもあまり得るものはないかもしれません。
まだ一度もT-DASHを使ったことのない人に、テストケース作成までの流れを説明するように記事を書いていきたいと考えています。
インストールまでは行えている前提の内容になるので、まだお済みでない方はこちらの公式記事を見ながら進めて頂きたいです。
https://service.valtes.co.jp/t-dash/function/tutorial/tdash_forbeginners001
手順
テストケース完成まで
まずは、このサイトで使うプロジェクトの作成を行います。プロジェクトとはフォルダのようなもので、その中にテストケースなどが入ります。テスト対象ごとに作成するのが一般的な使い方なのかなと思います。
T-DASHを立ち上げた時に遷移するこの画面で、画面右上の「プロジェクトを作成」ボタンから新規プロジェクトを作成します。
(既に他のプロジェクトを開いている場合、ヘッダーの「プロジェクト一覧へ」を押下することでこの画面に遷移できます)
続いてプロジェクトを押下したら、左メニューから画面定義を行います。
画面定義とは、WEBサイトにはこういう画面があり、こういう要素がありますよ、という事をT-DASHに理解してもらうための工程です。
各画面ごとに、URLと、要素名(とそのXpath)を指定していく流れになります。
今回遷移する画面はこの6つだと思います。画面名は適当に設定しちゃいます。
足りなければあとで追加します。
次に画面名を選択し、URLに該当のWEBサイトのページのURLをコピペします。
その後、画面キャプチャを押下
T-DASHにはキャプチャツールがあり、ツール上で対象のWEBサイトを開くことで、XPathを探しやすくなっています。
ただし全て自動で行ってくれるわけではなく、要素名の指定は手動で入力が必要です。
例えば「氏名」と手動で入力すると、それに関連するXPathを自動で取得してくれます。
完璧ではないので、上手く取得出来なかった場合は手動でのXPath取得が必要なこともあります。
こちらのキャプチャツールの使い方についてのリンクを確認しながら進めます
開いたキャプチャツールで要素名を手動で入力、完了したら「パス取得実行」ボタンを押下
「パスチェック」ボタンを押下し、OKなら画面上に1つのXpathが取得できています。無事取得出来たようです、
チュートリアルの記載を見ながら進めていますが、この手順で詰まりました
(手動でも値を確認しよう)
1.取得済みの値のセルをクリックすると、左エリアの該当する要素が黄色でハイライトされる
2.要素名と値が一致していることを確認できる
引用元:https://service.valtes.co.jp/t-dash/function/tutorial/screendefinition_vol_005
画像では黒い帯の位置にある「会員登録」を指定しているつもりですが、サイトのロゴの上あたりがハイライト表示されています。
公式のチュートリアルに以下のような記載がありました。
※ 想定とは異なる場所が黄色にハイライトしている場合には、トラッキングによるパス取得を実施する。ハイライトの位置がサイトの作りによってズレる場合もあるので、どうしても異なる場合は一度テスト実施してみてください
引用元:https://service.valtes.co.jp/t-dash/function/tutorial/screendefinition_vol_005
トラッキングで該当のボタンにマウスカーソルを合わせた画像です。
赤枠が「トラッキング」で自動入力された値。青枠は「パス取得実行」で自動入力された値です。XPathが違いますね。
どちらが正しいかわからず、ハイライトがズレているだけかもしれないので一旦青枠の、自動で取得した値のまま進めます
他にも要素はありますが、今回のテスト実施のためにはこれで十分だと思うので「保存」ボタンを押下。
するとT-DASHの画面で、要素名と値が保存されます。
これを各画面で、繰り返し行います。
ログインしないと遷移できないマイページ画面は、キャプチャツール内でログインしてからパス取得を行いました。
チェックアウト画面も同様に進めます。
これで全ての画面の必要な要素を取得できたので、テストケースの作成を進めます。
左の画面の「テストスイート」から、テストスイートを作成します。
テストスイートとは、「特定のテストサイクルで実行されるテストケースやテスト手順のセット」です。
どのように分類すれば良いかまだ理解できていないので、仮置きで「基本操作」という名前にしてみます
テストスイートが出来たので、その中にテストケースを作っていきます。
この名づけ方も適切かわかりませんが、「ログインから宿泊予約」としました。
画面左から「要素をクリックする」などの手順と、対象の画面や要素を選んでいくだけで、簡単にテストケースを作ることが出来ます。
更に、T-DASHキーワード手順という形で、操作内容を表した文章が自動で作成されます。
このテストケースの作りやすさ・メンテナンスのしやすさと、可読性の高さはT-DASHの魅力だと思います。
クリック回数が多いのでもしかすると面倒に感じる人もいるかもしれませんが自分は好きです。
こんな感じで書き終えたので、保存して動かしていきます
テストケース作成後のテスト実施・調整
画面右上の選択したテストを実行するを押下すると、新しくブラウザが立ち上がり、自動で操作が行われて行きます。
初回は失敗してしまいました。原因を見ていきます
どうやら、画面遷移が上手くいかなかったようです。
この画面遷移は別タブで開くので、工夫する必要がありそうです。
選択できる手順に、「最新のウィンドウに切り替える」という項目があったのでこれを試してみます。
先ほどの別タブ切り替えは成功したようです。
今度のエラーはテストケースのミスですね、別画面の要素を指定してしまっていました。
他にも入力する値が適切でなかった項目を修正します
ミスを修正したところ、今度は長いエラーが出ました。
要素の指定が上手くいっていないかもしれないので見直します
XPathを変えてもダメでした、chatGPTに聞いてみます
どうやらクリックしようとしたのに、他のものにさえぎられてクリック出来なかったようです。
選択できる手順に「要素を強制クリックする」というものがあったのでこれを選択してみます
長いエラーは消えました!うまくいったみたいです
今度はプルダウンリストの選択が上手くいかないとのこと
ソースを見ると、希望しないのvalueには"no"と入っているようです。
「希望しない」から「no」を選択するように変更。
プルダウンは選択できました。
次は要素の指定に問題があるのかな。あと見落としていましたが宿泊日の項目には入力可能な範囲が定められていたので、入力値を入れるのをやめてみます。(現在日から3ヶ月以内)
代わりに、デフォルトで実施日の翌日の値が入っているのでそれを取得するように変更
ついに成功しました…!!!良かった…
ただ、テキストを取得するを選択しましたがテスト結果には反映されないんですね。
このように取得した値を入力したり保存したりする向けの機能なのかもしれません。
このあたりは後日もっと触ってみたいです。
おわりに
予想していなかったエラーが沢山でてきて思ったより大変でした。
動作を確認する目的で作ったので、必要最低限の動作のみの手順しか今回のテストケースには入れていません。
実際にテストをする時は、テストの目的に合わせてテストケースを調整していきたいです。
使えていない機能が沢山あるので、理解を進めていきたいです。
T-DASHは30日の無料期間があり、月額料金もお手頃です。
コードが書けない自分でも問題なく使えるので、興味のある方は一度触ってみてはいかがでしょうか。
記事を書き慣れていないので、読みにくい部分が多々あったかと思います。
最後まで読んでいただきありがとうございました。