最近、iOSアプリ向けのCIサービスが増えてきている。
その中から、今回はgreenhouseciを触ってみたので使い方をまとめてみた。
設定
以下の順で設定していきます。
新規Projectの作成
greenhouseciにログインしたら、以下のボタンを押して新規Projectを作る。
新規Projectが作成されると左側に以下のようなメニューが表示されるので、上から順に設定していけばOK。
Projectの設定
メニューから「Project」を選択する。
githubのRepository URLを入力する。
上記画像では、「Public repository」だけど、「Private repository」も可能で、その場合は以下のように「Username and password」か「SSH key」を設定する必要がある。
Build対象となる情報の設定
メニューから「Build」を選択する。
対象となるリポジトリに複数のiOSプロジェクトがあれば、その中から好きなのを選択することが出来る。
ここの設定が一番ミスしやすい箇所だと思う。
- cocoapodsを利用している場合は、Projectは[workspace]になっているものを選ぶ
- Schemeでsharedの設定をしておく。
- Xcodeから「Product-> Scheme -> Manage Schemes」でsharedにチェックを入れておく。
- Provisioning profileとDeveloper certificateの2種類がいることに注意。
Test
メニューから「Test」を選択する。
XCTestがある場合は、ここでXCTestsにチェックを入れると実行時にTestもおこなってくれる。
Publish時の設定
メニューから「Publish」を選択する。
Build -> Testと来てPublishの段階で以下の4つを設定することが出来る。
Emailを設定しておくとインストールリンク付きのHTMLメールが飛んでくるので、インストールしたい端末でメールを受信しておけば、そのままインストールすることが出来る。
また、それ以外に外部サービスの「TestFlight」「HockeyApp」「Crashlytics」にアップロードすることも出来る。
Git Hookの設定
メニューから「Hook」を選択する。
githubのwebhookを使ってpush時にこのjobを動かすように設定することができる。
このURLを緑色のリンク(Github hooks page)を押して飛んだ先で設定するだけ。
実行
全ての設定が終わったら実際に実行してみる。
メニューの一番上のプロジェクト名をクリックする。
以下の「build」をクリックしたら実行される。
実行結果
実行されると以下のように一覧に結果が表示される。
ここでipaファイルのダウンロードも出来る。
また、LOGをクリックすると以下のように詳細な情報が分かる。
また実行時のログも見ることが出来るので何をおこなったかが分かる。
まとめ&追記
- 設定は比較的簡単。
- 今回設定してみて特につまった箇所は無い。
- githubのprivate repositoryが利用出来る。
- ipaファイルの作成&端末にインストールすることが出来る。
- TestFlightなどの外部サービスにアップロードすることが出来る。
- Appiumが利用できる。
- 2Projectまでは無料。
- カスタマイズが出来ない。
- 2015/4/14の段階でXcodeのバージョンは最新の6.3。
- 6.3がリリースされたのは、2015/4/9
プロトタイプとかあまりやることが細かくないならこのCIはありだと思う。
今後調べる予定
Appium
- Appiumも出来るみたいなのだけど、どのようにすればいいのか調べてない。
- 現状、対応しているのはJava/PHP/Python。
For both iOS and Android applications Greenhouse also supports Appium tests written in Java, PHP or Python. In case you are interested in other languages, please let us know.
http://greenhouseci.com/faq.html