轉(zhuǎn)載請注明出處,感謝您的支持焕梅。
文章來源:【chenyk的簡書】http://www.reibang.com/p/d9fa18c0a93b
簡要說明
本篇幅主要介紹如何實現(xiàn)Android項目的持續(xù)集成师脂,配合Jenkins和Gradle插件以及版本管理工具git/svn來完成担孔。最后根據(jù)需要,將自動構(gòu)建成功apk放置內(nèi)網(wǎng)或外網(wǎng)危彩,其主要目的是將打包工作交由Jenkins處理攒磨,減少開發(fā)人員的工作量。
全局工具配置
操作:點擊 系統(tǒng)管理 -> 全局工具配置
1汤徽、Gradle安裝
操作:點擊 新增Gradle -> 填寫名稱 -> 填寫Gradle所在目錄(這里我使用本地的Gradle插件)
2娩缰、添加Git
注意: 如果您使用svn工具進行版本管理的話,請?zhí)^此步驟
操作:點擊 Add Git -> 填寫名稱 -> 填寫Git路徑
新建任務(wù)
操作:回到首頁谒府,點擊新建 -> 輸入任務(wù)名稱 -> 構(gòu)建一個自由風(fēng)格的軟件項目
配置General
- 輸入項目名稱和描述內(nèi)容
- 點擊高級 -> 勾選使用自定義的工作空間 -> 填寫目錄及顯示名稱
PS:上面指定的目錄拼坎,將成為當(dāng)前項目的工作空間浮毯,也就是項目源碼會存放在jenkins安裝路徑下的workspace/ChenykPro_Android文件夾中
源碼管理
1、配置Subversion
注意: 如果您使用Git工具進行版本管理的話泰鸡,請?zhí)^此步驟
操作:勾選Subversion選項 -> 填寫項目地址 -> 選擇Credenitals(如果沒有债蓝,則Add)
2、配置Git
注意: 如果您使用Subversion工具進行版本管理的話盛龄,請?zhí)^此步驟
操作:勾選Git選項 -> 填寫項目地址 -> 選擇Credenitals(如果沒有饰迹,則Add)-> 選定一個要編譯的分支代碼(我這里是master)
構(gòu)建觸發(fā)器
在構(gòu)建觸發(fā)器,有兩種自動拉取代碼并編譯的策略:
- 設(shè)置Poll SCM余舶,設(shè)置定時器啊鸭,定時檢查代碼更新,有更新則編譯匿值,否則不編譯
- 設(shè)置Build periodically赠制,周期性的執(zhí)行編譯任務(wù)。
構(gòu)建
操作:點擊增加構(gòu)建步驟 -> 選擇Invoke Gradle script -> 勾選Invoke Gradle -> 選擇前面配置的gradle3.3 -> 點擊高級 -> 填寫Switches和Root Build script內(nèi)容
Switches內(nèi)容如下:
build
-Dcom.android.build.gradle.overridePathCheck=true
-Dorg.gradle.daemon=true
Apk安裝包處理
1挟憔、復(fù)制Apk到指定目錄
使用場景:將公司的所有項目的apk處理到指定目錄下钟些,同時配置window的IIS服務(wù)(IIS配置操作請自行找度娘)將該目錄共享到內(nèi)網(wǎng),配置完IIS服務(wù)后绊谭,便可通過瀏覽器訪問已打包成功的所有apk列表政恍,可提供給公司內(nèi)部人員使用
操作:點擊增加構(gòu)建步驟 -> 選中Execute Windows batch command -> 輸入命令
if not exist ..\APPList\%JOB_NAME% (mkdir ..\APPList\%JOB_NAME%)
copy app\build\outputs\apk\app-yixiangjia-release.apk ..\APPList\%JOB_NAME%\YxjUser-r%SVN_REVISION%-%BUILD_NUMBER%.apk
copy app\build\outputs\apk\app-yixiangjia-debug.apk ..\APPList\%JOB_NAME%\YxjUser-r%SVN_REVISION%-%BUILD_NUMBER%-debug.apk
JOB_NAME:對應(yīng)上面的自定義空間的顯示名稱
SVN_REVISION:對應(yīng)SVN版本號
GIT_COMMIT:可以理解為對應(yīng)的版本號,長度有40位达传,這里我截取了前7位(GIT_COMMIT:~0,7)
BUILD_NUMBER:對應(yīng)當(dāng)前構(gòu)建序號
注意:如果使用Git的話抚垃,這里需要把SVN_REVISION更改為GIT_COMMIT:~0,7,其余相同趟大。命令的語法比較簡單鹤树,這里不再贅述
2、上傳Apk到蒲公英
操作之前逊朽,需先下載安裝curl應(yīng)用程序罕伯,請前往并配置環(huán)境變量即可,下載鏈接:https://curl.haxx.se/download.html
a. 獲取蒲公英API信息
操作:賬戶配置 -> 查看api信息
b. Jenkins配置添加全局環(huán)境變量
操作:系統(tǒng)管理 -> 系統(tǒng)設(shè)置 -> 全局屬性勾選環(huán)境變量 -> 添加鍵值對 -> 添加構(gòu)建步驟
curl -F "file=@app\build\outputs\apk\app-yixiangjia-debug.apk" -F "updateDescription=AppDescription" -F "uKey=%PGY_USER_KEY%" -F "_api_key=%PGY_API_KEY%" http://www.pgyer.com/apiv1/app/upload
保存配置信息叽讳,點擊立即構(gòu)建追他,等待構(gòu)建結(jié)果
構(gòu)建成功
通過以上配置構(gòu)建成功后,可在內(nèi)外網(wǎng)訪問編譯成功的apk列表
1岛蚤、內(nèi)網(wǎng)訪問
2邑狸、外網(wǎng)訪問(蒲公英)
構(gòu)建失敗,踩坑處理
1涤妒、Unable to open PNG file
......
......
AAPT err(Facade for 1935004044): \\?\C:\Windows\System32\config\systemprofile\.android\build-cache\5ccc03017054f34e70c07f56dc529077515acba2\output\res\drawable-xhdpi\abc_ic_menu_copy_mtrl_am_alpha.png ERROR: Unable to open PNG file
AAPT err(Facade for 1935004044): \\?\C:\Windows\System32\config\systemprofile\.android\build-cache\5ccc03017054f34e70c07f56dc529077515acba2\output\res\drawable-hdpi\abc_btn_radio_to_on_mtrl_000.png ERROR: Unable to open PNG file
Error: Some file crunching failed, see logs for details
:**app:mergeYixiangjiaDebugResources** FAILED
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':app:mergeYixiangjiaDebugResources'.
> Error: Some file crunching failed, see logs for details
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
BUILD FAILED
- 原因:項目路徑太長
- 解決方法:打開計算機管理 -> 服務(wù)和應(yīng)用程序 -> 服務(wù) -> 右鍵Jenkins屬性 -> 切換到登錄選項卡 -> 勾選此賬戶 -> 輸入開機賬戶密碼 -> 點擊確定
2单雾、Execution failed for task ':xxx:lint'.
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':xxx:lint'.
> Lint found errors in the project; aborting build.
Fix the issues identified by lint, or add the following to your build script to proceed with errors:
...
android {
lintOptions {
abortOnError false
}
}
...
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
BUILD FAILED
解決方法:在項目的所有module下的build.gradle文件中,添加代碼lintOptions { abortOnError false }即可