iOS - fastlane自動化打包

iOS自動化打包,我推薦fastlane 方案。

fastlane 的原理又是如何?

實(shí)現(xiàn)自動化打包,又有什么流程?

簡介

1、什么是打包?

? ? Objective-C是編譯語言,需要編譯后才能執(zhí)行。我們發(fā)布一個(gè)版本的App,需要? ? ? 對源碼編譯、導(dǎo)出編譯產(chǎn)物的過程稱之為打包。

2、非自動化打包,是如何實(shí)現(xiàn)的

? ? 1)手動打包,使用Xcode

? ? 2)半自動化打包,我們都知道Xcode打包,其實(shí)使用的是`xcodebuild`命令,關(guān)于如何使用`xcodebuild`,請移駕這篇文章Xcode9+版本的打包方式,其得到了各位道友的認(rèn)可。

3、fastlane

Fastlane是一套使用Ruby寫的自動化工具集,用于iOS和Android的自動化打包、發(fā)布等工作,可以節(jié)省大量的時(shí)間。

我們在選擇一些三方開源庫或是工具的前提是:可以滿足我們當(dāng)下的需求并且提供好的擴(kuò)展性, Fastlane做到了。我當(dāng)前項(xiàng)目的需求主要是下面幾方面:

一行命令實(shí)現(xiàn)打包工作,不需要時(shí)時(shí)等待操作下一步,節(jié)省打包的時(shí)間去做其他的事。

避免頻繁修改配置導(dǎo)致可能出現(xiàn)的Release/Debug環(huán)境錯(cuò)誤,如果沒有檢查機(jī)制,那將是災(zāi)難,即使有檢查機(jī)制,我們也不得不重新打包,浪費(fèi)了一次打包時(shí)間。畢竟人始終沒有程序可靠,可以告別便利貼了。

通過配置自動上傳到蒲公英內(nèi)測平臺進(jìn)行測試分發(fā),也可以直接上傳到TestFlight,iTunes Connect。

證書的同步更新,管理,在新電腦能夠迅速具備項(xiàng)目打包環(huán)境。

Github:https://github.com/fastlane/fastlane

官網(wǎng):https://fastlane.tools/

文檔:https://docs.fastlane.tools/

fastlane中常用的插件介紹


測試工具

scan:自動運(yùn)行測試工具,可以生成漂亮的HTML報(bào)告

生成證書、配置文件工具

cert:自動創(chuàng)建iOS代碼簽名證書(.cert文件)

sigh:自動創(chuàng)建、更新、下載、修復(fù)Provisioning Profile

pem:自動生成、更新推送配置文件

截圖、描設(shè)備邊框

deliver:上傳截圖、元數(shù)據(jù)、App到iTunesConnect

snapshot:使用UI test功能實(shí)現(xiàn)自動截圖

frameit:在截圖的圖片外層套上物理設(shè)備邊框

自動化編譯工具

gym:自動化編譯工具

安裝

1、首先要安裝正確的 Ruby 版本。在終端窗口中用下列命令來確認(rèn):

ruby -v

2、然后檢查 Xcode 命令行工具是否安裝。在終端窗口中輸入命令:

xcode-select --install

如果未安裝,終端會開始安裝,如果報(bào)錯(cuò)誤:command line tools are already installed, use "Software Update" to install updates.代表已經(jīng)安裝。

3、以上依賴配置好之后就可以通過 rubygem 進(jìn)行安裝了:

$ sudo gem install fastlane

安心等待一會,fastlane就安裝完成了。

使用

初始化

打開終端,cd到你的工程目錄,然后執(zhí)行fastlane init:

$ cd to/your/ios/project

$ fastlane init

在 "Your Apple ID" 這一步輸入蘋果開發(fā)者賬號。在“Please confirm the above values”這一步,確認(rèn)信息,沒問題輸入 y。然后,fastlane 會進(jìn)行一系列的初始化操作,包括下載 App Store 上的元數(shù)據(jù)和截屏文件。

等待初始化完成之后,工程目錄下就多了一個(gè) fastlane目錄,其內(nèi)容如下:

fastlane目錄

咱們來看兩個(gè)主要的,Appfile和Fastfile。

Appfile

Appfile用來存放app_identifier,apple_id和team_id。 了解詳情,它的格式是這樣的:

app_identifier "com.xxx.xxx"# app的bundle identifier

apple_id "xxx@xxx.com"# 你的Apple ID

team_id "XXXXXXXXXX"# Team ID

···

你也可以為每個(gè)lane(后面會講到)提供不同的 app_identifier, apple_id 和 team_id,例如:

app_identifier "com.aaa.aaa"

apple_id "aaa@aaa.com"

team_id "AAAAAAAAAA"

for_lane :inhouse do

? app_identifier "com.bbb.bbb"

? apple_id "bbb@bbb.com"

? team_id "AAAAAAAAAA"

end

這里就是為Fastfile中定義的:inhouse設(shè)置單獨(dú)的信息。

Fastfile

Fastfile管理你所創(chuàng)建的 lane ,了解詳情。它的格式是這樣的:

# 自動更新fastlane 工具

# update_fastlane

#需要的fastlane的最小版本,在每次執(zhí)行之后會檢查是否有新版本,如果有會在最后末尾追加新版本提醒

fastlane_version "2.30.1"

#默認(rèn)使用平臺是 ios,也就是說文件可以定義多個(gè)平臺

default_platform :ios

platform :ios do

? before_all do

? ? # ENV["SLACK_URL"] = "https://hooks.slack.com/services/..."

? ? cocoapods

? end


? desc "Runs all the tests"

? lane :test do

? ? scan

? end


? desc "提交一個(gè)新的Beta版本到 Apple TestFlight"

? desc "This will also make sure the profile is up to date"

? lane :beta do

? ? # match(type: "appstore") # more information:https://codesigning.guide

? ? gym(scheme: "Docment") # Build your app - more options available

? ? pilot


? ? # sh "your_script.sh"

? end


? desc "部署一個(gè)新版本到App Store"

? lane :release do

? ? # match(type: "appstore")

? ? # snapshot

? ? gym(scheme: "Docment") # Build your app - more options available

? ? deliver(force: true)

? ? # frameit

? end


? # 你可以定義自己的lane

? #執(zhí)行l(wèi)ane成功后的回調(diào)

? after_all do|lane|

? ? # slack(

? ? #? message: "Successfully deployed new App Update."

? ? # )

? end


? # 如果流程發(fā)生異常會走這里并終止

? error do|lane, exception|

? ? # slack(

? ? #? message: exception.message,

? ? #? success: false

? ? # )

? end

end

我們也可以定義一個(gè)自己的lane:

? desc "企業(yè)版"

? lane :inHouse do

? gym(scheme: "XXX",

? ? ? export_method:"enterprise",

? ? ? output_directory "./build", # 打包后的 ipa 文件存放的目錄

? ? ? output_name "XXX"# ipa 文件名

? )

? end

其中一個(gè)lane就是一個(gè)任務(wù),里面是一個(gè)個(gè)的action組成的工作流。

執(zhí)行

定義完lane之后怎么執(zhí)行呢?打開終端,切換到項(xiàng)目的根目錄:執(zhí)行fastlane lane'name就可以了。成功之后會在相應(yīng)的路徑下生成ipa文件,如果報(bào)錯(cuò)的話就根據(jù)錯(cuò)誤信息好好查看文檔。

其他

1)想了解fastlane命令的話可以執(zhí)行$ fastlane --help

2)查看可用任務(wù)的列表,可以執(zhí)行命令$ fastlane lanes

3)fastlane也提供了很多插件方便我們使用,例如pgyer(發(fā)布app到蒲公英)。我們也可以打完包直接傳到蒲公英上,具體的可以看蒲公英提供的文檔

如果你感覺有些插件不符合自己的情況,你甚至可以自定義插件

4)多個(gè) lane 的話實(shí)際上是可以相互調(diào)用的,這個(gè)其實(shí)特別實(shí)用。例如:

default_platform :ios

platform :ios do

? lane :prepare do

? ? cocoapods

? ? match

? end


? desc 'fastlane build''fastlane build type:adhoc'

? lane :build do|options|

? ? # 調(diào)用上面的 prepare 任務(wù)

? ? prepare

? ? caseoptions[:type]

? ? when 'adhoc'

? ? ? adhoc

? ? else

? ? ? appstore

? ? end

? end


? lane : adhoc do

? ···

? end


? lane : appstore do

? ···

? end

end

6、我們可以在 Fastfile 文件中添加一個(gè)函數(shù)來設(shè)置version號和build號。

default_platform :ios

def prepare_version(options)

? ? increment_version_number(

? ? ? ? version_number: options[:version]

? ? )

? ? increment_build_number(

? ? ? ? build_number: options[:build]

? ? )

end

然后可以在一個(gè)lane中使用這個(gè)函數(shù):


lane :appstore do|options|

? ···

? ? prepare_version(options)

? ···

end

然后執(zhí)行這個(gè)lane的時(shí)候:

$ fastlane appstore version:2.4.0 build:2.0

證書管理-match

使用match管理證書,可以省去很多復(fù)雜操作,如:Mac上申請頒發(fā)證書、AppleDeveloper去創(chuàng)建證書、創(chuàng)建真機(jī)測試Provision文件、添加設(shè)備等。

1)搭建一個(gè)git-project,所有證書文件存放在git上,各iOS開發(fā)組員可以更方便同步證書等文件

2)在fastlane文件夾中,初始化match

$ fastlane match init

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容