構(gòu)建作為CI中重要且不可缺少的環(huán)節(jié)之一。構(gòu)建自動(dòng)化不管是對(duì)移動(dòng)端開發(fā)還是測(cè)試開發(fā)來說帶來的效率的提升還是很明顯的。之前我們是存在者一套基于XcodeBuild的shell打包腳本的。一套流程下來可以完成構(gòu)建,上傳蒲公英測(cè)試。由于多證書管理的繁瑣以及配置的可擴(kuò)展性。我們最終選擇Fastlane進(jìn)行自動(dòng)化構(gòu)建的優(yōu)化。站在巨人的肩膀上。我們可以更加的高效。
文章主要是講解實(shí)現(xiàn)的思路。一些工具的安裝還需自行g(shù)oogle.
Jenkins
jenkins是構(gòu)建的核心工具。它觸發(fā)著整套的構(gòu)建流程。一整套的jenkins包含的以下的配置過程:
1.General(概述)
主要是介紹項(xiàng)目整體的構(gòu)建配置。這里面最常用的是This project is parameterized和Throttle builds:
- This project is parameterized(參數(shù)化構(gòu)建):讓項(xiàng)目的構(gòu)建參數(shù)可配置化。例如添加git paramer讓我們可以選擇指定的分支進(jìn)行構(gòu)建。
-
Throttle builds:設(shè)置構(gòu)建的數(shù)目和時(shí)長(zhǎng)。
屏幕快照 2019-10-21 上午11.30.11.png
2.Source Code Management(源代碼的管理)
通過代碼版本工具git等將遠(yuǎn)程代碼倉(cāng)庫(kù)和jenkins進(jìn)行關(guān)聯(lián)。將在本地拉取一個(gè)全新的倉(cāng)庫(kù)進(jìn)行代碼的管理。這里需要注意的項(xiàng):
- Repositories:這里進(jìn)行關(guān)聯(lián)倉(cāng)庫(kù)設(shè)置。
-
Branches to build:分支進(jìn)行構(gòu)建。我們可以固定需要構(gòu)建的分支。也可以在上一步中參數(shù)化配置中通過${branchName}獲取分支構(gòu)建。
屏幕快照 2019-10-21 上午11.40.05.png
3.Build Triggers(構(gòu)建觸發(fā))
設(shè)置自動(dòng)構(gòu)建的觸發(fā)條件,webhook是一個(gè)很好的觸發(fā)器。可以在我們每次push代碼到遠(yuǎn)程倉(cāng)庫(kù)的時(shí)候觸發(fā)構(gòu)建的流程。
4.Build Environment(構(gòu)建環(huán)境)
構(gòu)建環(huán)境的設(shè)置
5.Build(構(gòu)建)
這里進(jìn)行構(gòu)建,構(gòu)建的方式可以使用自帶的xcode插件構(gòu)建,也可以使用擴(kuò)展性更強(qiáng)的自定義打包腳本構(gòu)建。下面fastlane就是腳本的一種。
6.Post-build Actions
配置構(gòu)建后的行為
Fastlane
通過對(duì)jenkins的配置我建立了代碼構(gòu)建觸發(fā)的條件后,我們需要開始對(duì)代碼進(jìn)行打包。之前我們說過打包可以使用自定義的shell,python還有fastlane.其實(shí)本質(zhì)都是使用了xcodeBuild這個(gè)命令行工具實(shí)現(xiàn)的。我們這里使用fastlane來快速的配置develop的打包工具。
1.fastlane init
切換進(jìn)入jienkin/workspace下的項(xiàng)目的根目錄下執(zhí)行該命令。
這里根據(jù)需要有4個(gè)選項(xiàng)可選。我們這里選擇4進(jìn)行自定義。然后會(huì)在項(xiàng)目的根目錄下生成一些文件。
./fastlane/Fastfile文件是我們打包的可配置項(xiàng):
這些就是生成ipa的一些配置項(xiàng)。有些是可以省略的。參考文檔building這里有些配置是因項(xiàng)目而已的。比如我們的項(xiàng)目是存在多targe生成多個(gè)product的需求。所以這里的scheme需要?jiǎng)討B(tài)可配。我們的環(huán)境變量支持多套的。所以我們讓configuration動(dòng)態(tài)可配。 export_options中需要注意的是如果項(xiàng)目中存在著share擴(kuò)展。因?yàn)樗莫?dú)立存在。這里導(dǎo)出的時(shí)候同樣需要我們提供share的profile文件。
2.Build
通過上面的配置,我們基本上是可以導(dǎo)出ipa了。
cd .jenkins/workspace/xxx
fastlane custom_lane
build只是fastlane中的一些。我們還可以在build的前后進(jìn)行些其他的配置操作。其中最靈活的是fastlane的插件。我們可以通過安裝ipa上傳蒲公英的插件上傳adHoc包。
Jenkins配置fastlane
有了上面的fastlane的Build腳本。把它集成進(jìn)jenkins就簡(jiǎn)單了。以execute shell的形式執(zhí)行fastlane的腳本基本上就可以實(shí)現(xiàn)構(gòu)建到上傳ipa的蒲公英的流程。
目前項(xiàng)目因?yàn)榇嬖诙鄐cheme,多環(huán)境變量,多branch等可配的情況。這里我們以多xcodeBuildconfig,branchs為例配置參數(shù)化構(gòu)建。
我們配置了Git Parameter參數(shù)。如果沒有找到請(qǐng)到j(luò)enkins的插件中下載安裝。XCodeBuildConfig配置了編譯的環(huán)境變量。然后需要將參數(shù)傳到腳本中:
branch指定我們拉取的分支,XCodeBuildConfig指定編譯的環(huán)境變量。
最后指定分支和環(huán)境進(jìn)行參數(shù)化構(gòu)建。
通過以上的步驟快速搭建了iOS的自動(dòng)化構(gòu)建流程。我們選擇性的利用jenkins和fastlane的插件可以做更多的事情。感興趣的繼續(xù)探索吧。后面我會(huì)繼續(xù)補(bǔ)充。