思い立ったが吉日。Jenkins上で実行しているAndroidアプリのInstrumentationテストをAWS DeviceFarm上で実行させてみる。
AWS Device Farm PluginをJenkinsにインストール
http://docs.aws.amazon.com/ja_jp/devicefarm/latest/developerguide/continuous-integration-jenkins-plugin.html や https://github.com/jenkinsci/aws-device-farm-plugin を読むと「GitHubからcloneしてきてビルドしてできたaws-device-farm.hpi
ファイルをインストールしてくれな」とか書いてるけど普通にJenkinsのプラグインマネージャからインストールできるのでそちらからインストールする
Device Farm用IAMユーザを作成
以下の権限をつけたユーザを作成、もしくはJenkinsを稼働させているサーバのRoleに以下の権限を付与。
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "DeviceFarmAll",
"Effect": "Allow",
"Action": [ "devicefarm:*" ],
"Resource": [ "*" ]
}
]
}
AWSDeviceFarmFullAccess
というポリシーが用意されてるのでそれをアタッチするだけで良い。
Device Farm Pluginの設定
Jenkinsの管理
-> システム設定
にAWS Device Farm
の項目があるので設定。
(Jenkins稼働サーバにRoleがついている場合は設定不要、だと思う。試してない)
Device Farmにプロジェクトを作成
Consoleからプロジェクトを作成する。まだTokyoには来ていないのでオレゴンに。
「まずはapkをアップロードしてね!」みたいな画面になるけどJenkinsから使うことが目的なのでここからはapkのアップロードはしない。
Jenkinsにジョブを作成する
例としてGoogleが提供してるサンプルプロジェクト https://github.com/googlesamples/android-testing を使う。
今回はInstrumentationテストを試したいので使うのはunit/BasicUnitAndroidTest
JenkinsのジョブにDevice Farmの処理を追加
普通にJenkinsでテストさせるだけならシェルスクリプトに
cd unit/BasicUnitAndroidTest
./gradlew assembleDebug
./gradlew connectedAndroidTest
のようにconnectedAndroidTest
ジョブを追加すれば良いのだけれども、テストはDevice Farmで実行したいのでしない。
Device Farmで使うテストapkをビルドするassembleDebugAndroidTest
タスクを追加する。
cd unit/BasicUnitAndroidTest
./gradlew assembleDebug
./gradlew assembleDebugAndroidTest
Projectは先にDevice Farmコンソール上で作成したものを選択。
Device Poolは一旦Top Devices
にする。(Kindle Fire HDX 7, LG G Pad 7.0, Galaxy S5, Galaxy S6, Galaxy Tab 4という5つのデバイスでテストを実行する設定となっています)
実行すると、ビルド後にDevice Farmにapkをアップロードしテストを実行してくれる。
結果はJenkins上に表示されてるし、もちろんDevice Farmコンソール上では詳細も表示できる。
なかなか簡単だし、悪くない。
難点
Device Farmは実機を大量に稼働させてる謎システムとのことで、テストが走り始めるまでに時間がかかることがある。
上記テストも実行ではGalaxy S5のデバイスの準備に時間がかかり全体で以下のように6分ほどかかってしまった。
00:39:41 [AWSDeviceFarm] Using Project 'android-app'
00:39:42 [AWSDeviceFarm] Using DevicePool 'Top Devices'
00:39:42 [AWSDeviceFarm] Using App 'unit/BasicUnitAndroidTest/app/build/outputs/apk/app-debug.apk'
00:39:42 [AWSDeviceFarm] Archiving artifact 'app-debug.apk'
00:39:42 [AWSDeviceFarm] Uploading app-debug.apk to S3
00:39:43 [AWSDeviceFarm] Waiting for upload app-debug.apk to be ready (current status: PROCESSING)
00:39:49 [AWSDeviceFarm] Upload app-debug.apk succeeded
00:39:49 [AWSDeviceFarm] Getting test to schedule.
00:39:49 [AWSDeviceFarm] Archiving artifact 'app-debug-androidTest-unaligned.apk'
00:39:49 [AWSDeviceFarm] Uploading app-debug-androidTest-unaligned.apk to S3
00:39:50 [AWSDeviceFarm] Waiting for upload app-debug-androidTest-unaligned.apk to be ready (current status: PROCESSING)
00:39:55 [AWSDeviceFarm] Upload app-debug-androidTest-unaligned.apk succeeded
00:39:55 [AWSDeviceFarm] Scheduling 'INSTRUMENTATION' run 'app-debug.apk (Jenkins)'
00:39:56 [AWSDeviceFarm] View the INSTRUMENTATION run in the AWS Device Farm Console: https://console.aws.amazon.com/devicefarm/home?#/projects/xxxxxxxxxxxxxxxxxxxx/runs/xxxxxxxxxxxxxxxxxx
00:39:56 [AWSDeviceFarm] Waiting for test run to complete.
00:39:56 [AWSDeviceFarm] Run app-debug.apk (Jenkins) status SCHEDULING
00:40:26 [AWSDeviceFarm] Run app-debug.apk (Jenkins) status RUNNING
...
00:45:58 [AWSDeviceFarm] Run app-debug.apk (Jenkins) status COMPLETED
00:45:58 [AWSDeviceFarm] Test run is complete.
既存のInstrumentationテストの実行環境として使うには遅いかも。Device Poolを変更してテスト対象デバイスを減らすなどすれば緩和はされるけども。
実機じゃなくていいからとても速いエミュレータとかがあると非常にありがたいのでDevice Farm側のアップデートに期待したい。
スクショ取るとかそういう機能もあるので毎日CI経由で実行してアプリの画面を記録しつづけるとかそういうのには向いてそう。
AWSなのでもちろん全部API経由で操作できるし色々使いどころはありそう。