最近 DeviceWallpaper というアプリをリリースして、勉強のためテストも書いているためTravis CI と連携してテスト結果を README に表示させる手順をまとめてみる。
Travis CI は OSS なら無料で、 private は有料になっている。
Travis CI - Test and Deploy with Confidence
0. 前提
CocoaPods や Carthage はソース管理されていること。
ソース管理していない場合は毎回 Clone & Build が必要になるため、それらの設定を別途 .travis.yml に書く必要がある。
1. Sign Up と Switch ON
Travis CI から Sign Up する。
そのあと CI したいレポジトリのスイッチを ON にする。
data:image/s3,"s3://crabby-images/378d2/378d28642368b9fba11a82c3f2f3391ba1fd54af" alt="スクリーンショット 2017-05-14 15.47.58.png"
設定
.travis.yml が無いと Build しないようにした。
しかし OSX Project の場合はいずれにしろ .travis.yml が無いと success することはない、 Linux で Build しようとしてしまうので。
data:image/s3,"s3://crabby-images/ca981/ca9816ebfc694fbc9b4886c101e6f39e60f6323b" alt="スクリーンショット 2017-05-14 15.53.41.png"
2. fastlane test
テストは bundle exec fastlane test
で動くようにした。
Scheme の Shared をチェック
テストを実行するために Scheme を共有する必要がある。
data:image/s3,"s3://crabby-images/a1381/a1381a3e79f6a1db9f77d63df0f0c9ebcc829aa2" alt="スクリーンショット 2017-05-14 16.26.38.png"
fastlane
Scanfile
こんな感じで書いた、実物は Scanfile にある。
scheme "DeviceWallpaper"
configuration "Debug"
device "iPhone SE"
workspace "DeviceWallpaper.xcworkspace"
open_report true
clean true
skip_build true
output_types "html"
Fastfile
scan するだけ。実物は Fastfile にある。
lane :test do
scan
end
fastlane を使わない場合
Default Test Script に書いてある書き方でできそう、試してはいない。
3. Ruby version
Travis CI: Precompiled Ruby Versions にあるように、2017/05/14時点で Ruby 2.4.1 は使えないので 2.4.0 以下にする必要がある。
.travis.yml に rvm: 2.4.0
と書くか .ruby-version ファイルに 2.4.0 と書いておけば良い。
CocoaPods + Swift で Travis CI を使う - Qiita には .ruby-version があるとコケるとあったが、Using .ruby-version にあるように問題なく利用できる。
4. .travis.yml
Building an Objective-C or Swift Project - Travis CI を見ながら yml を書いた。
osx_image: xcode8.3
language: swift
script:
- bundle exec fastlane test --verbose
5. 結果
starhoshi/DeviceWallpaper - Travis CI
成功した
data:image/s3,"s3://crabby-images/efc96/efc96c17532f4f9b9771a896d989657a2dece012" alt="スクリーンショット 2017-05-14 16.15.07.png"
6. badge を README に貼る
Travis CI 上の build: passing
をクリックするとダイアログが出るので、それを Markdown でコピーして README に貼る。
data:image/s3,"s3://crabby-images/b46fc/b46fc304b4cd6f6b91fea5399dfc12d6acf6db38" alt="スクリーンショット 2017-05-14 16.17.15.png"
すると こんな感じ で README に badge が表示される
data:image/s3,"s3://crabby-images/baa6c/baa6c80ce6bbc272377a1d3a4c6eccfe267fc07e" alt="スクリーンショット 2017-05-14 16.21.19.png"
実際に動くサンプル
GitHub - starhoshi/DeviceWallpaper: Device information wallpaper (VIPER Architecture)
Travis CI: starhoshi/DeviceWallpaper