「第6回Selenium談話会 in Slack」~Selenium デザインパターン&ベストプラクティスの読書会 Part1~ のまとめ


Selenium談話会 in Slackとは

  • 私、@oh_rusty_nail が主催しているSlackを使ったオンライン勉強会です
    • https://seleniumjp.slack.com
    • 地方に住んでいて勉強会に行くのも遠征しないときびしい!といった方には特におすすめです
  • 月1回程度の頻度で企画しています
  • 日本Seleniumユーザーコミュニティで開催の案内を出しています
  • ラフな感じでやってますのでお気軽にご参加ください!
  • 情報を共有し合ったり、流行のツールについてしゃべったり、困りごとや相談をしたり...etc
  • 2015/10/16現在の総登録ユーザ数:86名

参加方法

過去に開催した談話会のまとめ

「第6回Selenium談話会 in Slack」の議事録

<第1章 最初のテストを書く>

SeleniumIDE

  • この本で紹介されているのはSeleniumIDEやWebdriverだがSeleniumBuilder愛用者は取り扱われていなくて残念
    • ⇒ 確かにこの本ではBuilderの紹介はされていない
  • そして度々のFirefoxやSelenium自体のバージョンアップによって動かなかったりBuilderが起動しなかったりすることがある
  • Builderとは?
  • form操作をサクッと書きたいときにSeleniumIDEを使うようにしている。name属性なら確実に使えるので。。。
  • SelBlocks (for Selenium IDE) を使って分岐ループでゴリゴリまでするとWebDriverの方がもはや楽っていうのある
    • この本にもありましたが比べてみるとWebdriverもそんなに壁もなく使い始められる
    • さすがにSelenium IDEと同じスピードでとは行きませんが、いざとなれば好きな言語で色々できるのはうれしい

出来の悪いロケーターと柔軟性のないテスト

  • Selenium IDEでも記録モードで取得するものにCSS,xpathを優先にすることが可能だが、実際にそのまま使えるケースのほうが少ないような気がする
    • ⇒ ロケーターはテーブルのような相対で取りたいときには、そのままのキャプチャされたロケーターだと厳しい
  • 例に挙げてあるアカウント登録をするケースなどはWebdriverが向いているのかなと思った
    • ⇒ WebDriverでプログラム的に書く方が柔軟かと思う
  • この2点が原因で、SeleniumIDEのシェアも落ちているらしい
    • ⇒ 簡単に導入できるが、慣れてくると複雑なこともしたくなるため、Webdriverへ移行したくなるのも不思議ではない

クロスドメインポリシーの制限

  • "Selenium IDE と Seleniuim RCは1回のテスト実行で複数のウェブサイトをテストすることができません" とは?

Seleniumが判断するページが開けたとは?

  • Seleniumが判断する"ページが開けた"は何をもってそういっているのか?
    • Selenium - IEで自動テストを動かすときにハマったあれこれ - Qiitaを参照
    • ⇒ 基本的には、JavascriptのonLoadが呼ばれるのと同じだと思うが、ロードが終了、つまり(Ajax通信とかはまだ動いていることもありますが)ベースのHTMLが取得できたときでも、画面遷移の仕組みによってはそこまで待たないこともある。というちょっとモヤッとした定義のようだ
    • ⇒ 経験上だと、IEの場合はちゃんと次画面の要素を指定して待たないと失敗することがある
    • SeleniumHQ/seleniumを見るとHTMLファイル自体がhttp get 他で取得されたタイミングっぽいので、 上で挙げたような問題がある

send_keysコマンドの前にはclearコマンドをはさむと良い

  • テキスト入力する前にテキストのクリアをしておく
    • ⇒ 確かにこれやっておけば、もし前になんかゴミがはいっていたんじゃない?とかいう疑いも持たなくてよいですし
ruby
element.clear
element.send_keys("hogehoge")
  • Selenium RCのtype(指定した値で上書きする)とWebDriverのsendKeys(指定した値を既存の値に追加する)の動きの違いのせいで「あれ?」となる方が多い
  • 初期値を気にしないようにするため「常にclear()とsendKeys()をセットで呼ぶ」という使い方をよくする

なぜこの本で扱われている言語はRubyなんだろう、Javaではなく

  • この本を読んでいるとRubyの書籍を読んでいる気持ちになる
    • ⇒ この本がRubyなのは恐らく作者さんが最も得意な言語というのと、CucumberのようなBDDフレームワークと相性が良いからかと
    • http://www.slideshare.net/NozomiIto/1selenium この資料の11ページのSelenium勉強会参加者アンケートの結果によるとJavaが最も多く、ついでRuby

使用する言語

  • 現場で自動化に取り組むときは、最も経験者が多い言語を採用するやども検討する必要があると感じた
    • ⇒ そうでないと書くのもしんどいしレビューもしんどいしと いいことなし

本の作成に関してこぼれ話

  • (シークレットだろうと思われるのでここには書きません^^)
  • これ実際に関わられた方に聞けるなんてこんな面白いことないだろ案件でしたが、本日一番貴重な体験談をお聞きしました

<第2章 Spaghettiパターン>

これはスパゲティ?

  • 登録機能で登録したデータを、照会機能で照会するような結合テストは、スパゲッティに該当するのか
    • ⇒ 「テストケースの意図」が「登録して検索する」というものならOK
    • ⇒ 検索のバリエーションテストをするような場合、Fixtureで事前投入しての方がテストケースの意図として自然
    • ⇒ 検索の部分が主体のテストなのにそこのデータ準備もSeleniumでやると時間もかかるし、意図と関係ないところでコケるとわけわからなくなる

xUnit Test Patterns

  • http://xunitpatterns.com/ 粒度は異なることが多いが、テストケースやスィートとしてまとめる基準としてはxUnit Test Patternsでかなり検討されているので、Seleniumの機能テストやシステムテストでも考え方は応用できる

ロケータはどのように使っているのか?

  • CSSやxpath,リンクテキストなど様々なロケータで要素が指定してあるものを見たことがあり、気持ち悪かったので全部CSSに変えたことがあった
  • でも、チームでルールきめたりするのがよいなと後で思った。例えば、リンクはリンクテキストで指定しよう xpath/cssで書くならばcss使おうよ! など
    • Selenium の locator とうまくつきあうための話 - Qiita このokitanさんの資料がシンプルにまとまっていてすばらしいと思う
      • Qiita記事のlink textが最下位なのはなんでだろうと思ったが、多言語の問題のためだった(納得)
    • ⇒ idは使えるようでランダムにふる酷いシステムもある
      • 数字とか入ってるやつはidとはいえもう使えないも同然
    • ⇒ 全部CSSまたはxpath指定でやっていますという方もちらほら
      • xpathが一番表現力あるので、統一するならxpath。しかし、CSSの圧倒的な見やすさも魅力がある
      • 規則性があるものはxpathだと思うが、基本CSSが一番よい。パフォーマンス的にはxpathの方がよくない

ミクロネシアミツスイってご存知です?

  • この本のカバーの鳥
    • ⇒ これを聞いて答えられるのは本を読了している証拠と

次回開催日時


~ただの宣伝~

  • 全国のSeleniumer必読
  • Selenium, Appium, SauceLabs, TravisCI, Jenkinsに関するノウハウ書いているのでよかったら参考にしてみてください