概要
ブログ・Qiitaまとめ枠として参加したのでまとめます。
各発表のトピックを箇条書きでまとめていきます。
初めてのquickで初めてのテスト
@ktanaka117:「初めてのQuickで初めてのテスト」
発表資料
- Quick/Nimbleとは
- Specの基本
- テストの文脈に沿った記述を行う
-
context
,describe
,it
-
-
expect
で期待する結果を記述
- テストの文脈に沿った記述を行う
- まとめ
- テストのテストコードを書くよりも、テストケースを取り出すことがしんどい
- テストはテスト対象のパーツを書いている時に書くべし
ViewController ⇄ Presenter by RxSwift
-
RxSwiftに関する軽い紹介
- ViewControllerとPresenterは互いにEventとStateをやり取りしている。
- ViewControllerはユーザーのタッチイベントをEventブジェクととしてPresenterへ通知。
- Presenterは受け取ったEventからStateを生成し、VireControllerへ渡す。
- ViewControllerとPresenterは互いにEventとStateをやり取りしている。
- ViewControllerとPresenterのやりとりに関するテストを書く。
- Presenteの入出力に関するテストを書く。
- 入力はEvent、出力はStateとして記述可能
- 時刻への依存が強く、書きづらい
- Presenteの入出力に関するテストを書く。
-
RxTest
- RxSwift のテストフレームワーク
- 前述の時間に依存したテストを書きやすく支援してくれる。
- 自分で設定した時刻でイベントが発火したものとしてテストを記述できる。
開発を効率化するテストのデザインパターン
- 型による防御
- テストの実行前にバグを見つけることで、時間のロスを減らす
- SemanticType
- 文脈に沿った名前付け、型の作成を行うことで可読性を向上させる
- RegistrationToken
- 必要な事前処理を強制することで安全性を担保する。
- テスト容易設計
- ViewControllerFactory
- Storyboardとの整合性が崩れた時に、テストでそれを検知できるようにする
- State-Machine Model
- モデルの状態数を制限し、状態遷移に着目してテストを書くことで、網羅性を維持する。
- ViewControllerFactory
- テストの構造化
- Parameterized Test
- テストコードを共通化することで、テストコードの保守性を向上。
- 共通化によって発生する問題(どこでテストが落ちたかわからなくなる)は#line を使って回避
- 非同期テストはPromisKitを使う
- Parameterized Test
- デバッグの効率化
- Diff Assertion
- MIRRORDIFFKIT
- diffが読み辛いのため読みやすくするためのライブラリを作った。
- Diff Assertion
- オススメの資料
発表者によるブログ記事
What is FBSimulatorContro
shingo_tamaki_948
- simctl と FBSimulatorControlの紹介
- simctl
- Xcodeに入っているシミュレータを制御するコマンド
- デバイスの制御、アプリケーションのインストール、起動などが行える。
-
FBSimulatorControl
- 上記のsimctl に加え、複数デバイスの起動、制御が行える。
- headlessでも動作可能、早い。
- まとめ
- 並列起動は一見すごいがそこまで美味しくない
- 対話的なシナリオをE2Eで行うなどには適用できそう
参考:発表者によるsimctlに関するQiita記事
Bluepillを使ったiOS自動テストの並列化!
- iOSテストに関するつらみ
- テストの実行時間の増大
- 不安定なiOSシミュレータ
- Bluepillが諸々の問題を解決してくれそう
- まとめ
- 並列化を早期に行うことはメリットである
- 後々導入するのは苦痛
- 最初の段階から使っていても便利な機能が多く、導入のメリットは大きい
- 並列化を早期に行うことはメリットである
発表者によるまとめ
5分でわかる! AWS Device Farmでテストしよう!
-
AWS Device Farmの紹介
- テスト時に実機を用意するのは面倒
- DeviceFarmを使えばその手間を省ける
- iOSやAndroidアプリを実機でテストが可能。
- iOSもAndroidもOSバージョンはかなり幅広く対応している
- iOS7.1 ~ iOS10
- Xcodeからipaファイルを作成し、DeviceFarmへアップロード
- これだけで実機によるテストが可能になる
- テスト時に実機を用意するのは面倒
テストを書かない言い訳をさせてくれ
- テストをできるだけ書きたくない
- テストコードと実装コードを行き来するのはコストである。
- このコストを避けるべきだという点はレガシーコード改善ガイドにも書いてある。
- テストよりも型チェックでなんとかしたい。
- テストそのもののコストの下げ方を求む!
Pull Request とテストカバレッジの連携
- カバレッジを実際に計測する話をする
発表者によるブログ記事
感想
テストの知見を得るために参加したのですが、想像以上に知見が溜まりました。
テストそのものよりも、テストがあることは前提で、その次に発生する問題に対してどう対処するか、という話が耳目を集めていたように思えます。
また、テストそのものへの問題提起的な発表もあり、テスト手法だけではなく、その周りの話題も盛り上がっていました。
ありがとうございました🙏🏼