Tizenネイティブアプリ(C++)のビルドをUbuntuのJenkinsでビルド出来るようにした時のメモを記載します。
結論から言うとEclipse CDT Headless build機能を利用する事で簡単に出来ました。(その結論まで辿り着くのに時間が掛かったけど。。。。)
また、上記での運用の場合、.project及び.cprojectファイルもあわせてリポジトリにコミットする事でEclipse(TizenIDE)での設定(平行ビルドやincludeするプロジェクトなどなど)をそのまま使え、新たにmakefile作成ようにシェルを作成しなくても良いのがとても楽です。
環境は以下の通りとなります。
- Ubuntu 12.10
- TizenSDK 2.2
また、私の環境では以下のように運用しています。
- 30分ごとにリポジトリをポーリングし、更新があれば再ビルド
- ビルドによってtpkまで作成する
- ビルドの成功可否をIRCで通知
- Doxygenでドキュメント生成
- Cppcheckによる静的解析
なお、実施の際には以下を参考にさせて頂きました。
JenkinsでEclipse CDT (C++) プロジェクトをビルドする
目次
- UbuntuへのTizenSDKインストール
- UbuntuへJenkinsのインストール
- Xvfbのインストール
- JenkinsでEclipse Headless Build
- tpk作成スクリプト作成
- Jenkinsプラグインの導入
1.UbuntuへのTizenSDKインストール
Tizenの公式サイトに記載の通り実施します。 java.lang.NoClassDefFoundError: Could not initialize class org.eclipse.swt.widgets.Displayというエラーが出る事がありますが、対応方法は
として以前のエントリに記載したのでご確認ください。 上記以外は特に点はないかと思いますので、詳細は省きます。
インストール後、TizenIDEが利用できる所までを確認してください。
2.UbuntuへのJenkinsのインストール
以下のコマンドでOK。
sudo apt-get install jenkins
あとはブラウザでJenkinsにアクセスし、適当な名称でジョブを追加します。
3.Xvfbのインストール
Eclipse Headless Buildをコマンドラインから実行する場合に、Xvfbがないとエラーが出るのでインストールします。
>sudo apt-get install xvfb
Xvfbの起動起動及び停止はJenkinsのXvfb Pluiginを利用する事でプラグイン側で自動でやってくれるので、今回はそれを利用します。
Jenkisnのプラグイン管理から上記プラグインをインストールして、パスを設定します。 その後、予め作成したジョブの設定でXvfbに関する設定にチェックを入れればビルド開始時にXvfbの起動を行い、ビルド終了時にXvfbの停止を行ってくれます。
上記を利用しない場合には以下のようなコマンドで実行可能なので一応メモっておきます。
Xvfb :99 -screen 0 1024x768x24 > /dev/null 2>&1 & export DISPLAY=:99
4. JenkinsでEclipse Headless Build
いよいよHeadless Buildを利用してビルドします。 Jenkinsのシェル実行の箇所で以下のように記載します。
# move workspace cd ../ # headless build /home/toshihirock/tizen-sdk/ide/eclipse -data workspace --launcher.suppressErrors -nosplash -application org.eclipse.cdt.managedbuilder.core.headlessbuild -import Utility -build Utility/Debug
上記例ではUtilityというネイティブプロジェクトをDebugプロファイルでビルドしています。
- /home/toshihirock/tizen-sdk/ide/eclipse→TizenIDE(Eclipse)の場所を指定。Windowsの場合、eclipse.exeを指定。Macの場合、TizenIDE.app/Contents/MacOS/TizenIDEを指定。
- -data workspace→workspaceを指定。
- –launcher.suppressErrors→ポップアップ画面を抑制し、メッセージをコンソールへ出力する。おまじない。
- -nosplash→スプラッシュ画面抑制。おまじない。
- -application org.eclipse.cdt.managedbuilder.core.headlessbuild→headless buildを指定。おまじない。
- -import→Utility ビルド対象のネイティブプロジェクトを指定
- -build→Utility/Debug Debugビルドを実施。
上記を実行すると.project及び.cprojetの設定に従い、makefileの生成、実行を自動で実施し、ビルドを行います。 (TizenIDEでプロジェクトを右クリック→Build Projetと実行した場合と同じ挙動)
上記実行後、Utility/Debugフォルダが作成され、ビルドがうまくいけばexeファイルの作成が確認できます。
5.tpkファイルの作成
ビルドを行う事でexeファイルは作成できますが、最終的にアプリとして動作させる為にはネイティブアプリの場合にはtpkにパッケージングする必要があります。
上記はTizenから提供されるnative-packagingコマンドを利用します。
コマンドは$TIZEN_SDK_HOME/tools/ide/bin配下に存在します。
なお、tpk作成時の設定ファイル(build_data)については上記と同じ場所に存在するnative-genコマンドを利用して事前に作成します。
cd workspace/Utility /home/toshihirock/tizen-sdk/tools/ide/bin/native-gen makefile -t app
上記でCommandLineBuildフォルダが作成され、その中にbuild_dataという設定ファイルが作成されるので、適当な場所にコミットします。 (native-genやnative-makeコマンドを利用してビルドも出来ますが、バグっぽいのがあってうまく出来ない事があったので今回はその方法を利用していません。)
また、もし、証明書(p12)を作成していない場合には、予め作成してこちらも適当な場所にコミットします。
これで準備ができたので、native-packaginコマンドを利用してtpkを作成するシェルを作成します。
# Debugフォルダに移動 cd workspace/Utility/Debug # build_dataをDebugフォルダに移動 cp ../build_data . # パッケージング /home/toshihirock/tizen-sdk/tools/ide/bin/native-packaging -ak ../../ryan.p12 -ap mypassword
これで成功すればtpkファイルがDebugフォルダに作成されます。
-akオプションで証明書の場所を指定し、-apコマンドで証明書のパスワードをしております。 各コマンドの詳細はTizenの公式サイトをご確認下さい。
6.Jenkinsプラグインの導入
一応、これでビルドからtpk作成までをJenkisnのジョブとして実行できますが、せっかくなので便利だったJenkinsプラグインもこちらに記載します。(詳細は省きます)
- Cppcheck Plugin:C++の静的解析が可能です。かなり便利!
- Doxygen Plugin:連携させておくとDoxygen形式のドキュメントが見れます。
- IRC Plugin:ビルドの正否をIRCで通知できます。コミットログも合わせてPOSTしてくれるのが意外と便利。
- Task Scanner Plugin:TODOを集計できます。