コマンドライン引数でモックに差し替える

Xcodeに内蔵されているUITestingは非常に強力です。

ユニットテストの一種で、コードで操作を記述して、アプリをユーザーが操作するのと同じように動かして、表示内容や動作など、ユーザーインターフェイスに関する自動テストを行うことができます。

しかし、実際に取り組んでみると慣れていないために、色々と苦戦しました。その一つが、モックの差し替えです。

モックは、HTTPの通信やデバイスとのやり取りなど、自動テストするときにやりづらい部分を解決するための一つの方法です。実際の通信やデバイスとのやり取りを行わずに、テストのために返して欲しい、任意のデータを返す仮のオブジェクトです。

モックで置き換える部分は別にテストする必要がありますが、UIのテストの上では必要ではありません。

そのためには、UIのコードから呼び出す処理は、プロトコルを使います。例えば、ApiClientプロトコルなどを作ります。本当の通信は、このプロトコルに適合したクラスを作って実装します。UIテストのときはこのプロトコルに適合したモッククラスを実装します。

ここで、問題が起きます。どのようにして、モックと本当のクラスとを使い分けるか?

コマンドライン引数を使う

XcodeのUIテストは、対象プログラムの起動もテストコードから行います。そのときに、コマンドライン引数を渡すことができます。これを使って、特定の引数が渡されたら、モックに差し替えるようにしました。

例えば、次のような感じです。

var app = XCUIApplication()
app.launchArguments = ["--mock_device"]
app.launch()

この例では「–mock_device」が指定されていたらモックのデバイスクラスに切り替えるように実装しました。

UIテストってどうなんだろう?

UIテストに取り組んでみて、まだ、大きな有用性は見えていません。テストコードやモックの作成に工数がかかるためです。後工程の結合試験と修正が大幅に減ることが確認できれば効果有りですが、現時点では不明です。

しかし、少しコードを修正したときに、予期しない場所が動かなくなっていたのを検出できたということが起きました。この点については良かったです。

慣れていないために工数が余計にかかっているようにも思われるので、しばらく取り組んでみてから改めて考えてみます。

実際に取り組んで少し経つと、かなり有効だということが分かりました。内部構造の変更がGUIに影響を与えていないことを確認することが自分が考えている以上にありました。自分でも気が付いていなかったくらい、頻繁に改良を行っていました。

投稿者プロフィール

林 晃
林 晃macOS/iOSアプリ/SDK/ミドルウェア開発が専門の開発者
アールケー開発代表。macOS/iOSアプリ/SDK/ミドルウェア開発が専門の開発者。ObjC/Swift/C++使い。豊富な開発実務経験を基に、教育コンテンツ開発、技術書執筆、技術指導、技術セミナー講師、企業内研修講師、行政・自治体職員研修講師も行います。

基礎から学ぶMetal


「基礎から学ぶMetal」を執筆しました。本書はMetalを使ってGPUプログラミングを行うための最初のステップを解説するMetalの解説書です。

私が初めてGPUプログラミングを行ったとき、どこから手をつけて、学んでいけば良いのか分からず呆然としました。もし、あのとき、これを教えてくれればという部分を解説しました。本書で解説している部分はMetalの基礎となる部分で、Metalを使うときに必ず触れることになる部分です。

詳細

基礎から学ぶSwiftUI


「基礎から学ぶ SwiftUI」というタイトルの本を執筆しました。

SwiftUIの入門書です。

SwiftUIのコンセプトは「ユーザーインターフェイスを作るための最短パスを提供する」「一度学べば(Appleのプラットフォームの)どこにでも適用できる」です。

SwiftUIの概要から始まって、一つ一つのテクノロジートピックに注目しながらSwiftUIとは何か?どんなことができるのか?どのようなコードを書けば良いのかなどを丸々一冊使って解説しています。

詳細

関連記事

  1. Apple Notarization Service に対応するための…

  2. XcodeでGoogle Test (gtest) を使えるようにセッ…

  3. 古いOS対応アプリを最新Xcodeで作る

  4. XcodeやAppCodeで16進数や2進数で値を確認する方法

  5. Xcode 10対応 : 古いヘッダーマップはサポートされなくなる

  6. Xcode 8.3に移行したらnullabilityのワーニングが出た…

  7. XcodeのリファレンスはiOSとOS Xアプリの開発を区別してくれる…

  8. 仮想環境と古いXcodeそして古いOS

最近の著書

  1. 基礎から学ぶ SwiftUI

最近の記事