我們在日常開發中經常會遇到如下問題
團隊成員一不小心Revoke了證書導致所有的開發小伙伴需要重新下載證書
每次提交App Store審核需要重復【修改證書】- 【打包】-【iTunes Connect】- 【發布】等一系列動作
真的是不厭其煩,讓人抓狂。這個時候,幸好Fastlane來了,看他怎么來拯救我們吧。在開始我們的教程之前,筆者先做個澄清,fastlane不是什么:
fastlane 不是一個工具,而是一系列工具的集合。比如match工具能管理證書,deliver能提交APPStore審核。所以我們在使用fastlane的時候更多的是和它的工具集打交道。
fastlane內部的工具不是新寫的,而是調用mac本身的命令,只不過是實現了自動化而已。比如gym工具只是xcodebuild工具的一個封裝,如果你會xcodebuild,那gym對你來說小菜一碟。
fastlane本身沒有一套特殊語法,使用的Ruby語言,相信使用過cocoapods的同學應該很容易上手。
安裝完fastlane并調用fastlane init
后,目錄結構大概如下所示:
具體的安裝和初始化,本文稍后會詳細講述,先帶大家分析一下安裝后的fastlane的目錄結構。紅色區域就是多出來的文件。本項目是筆者的一個APP Store上線項目,大家可以點擊這里獲取。
Gemfile 告訴我們fastlane 依賴的gem以及版本等其他信息。這個跟本文主題不大,筆者就不詳細描述了
fastlane文件夾里的Appfile看文件也知道,里面是關于本App的信息的;Fastfile則是fastlane的最主要的文件,在這個文件中可以編寫我們需要使用的各個工具的順序、方式等。
這里我們先看一個已經寫好的fastlane的內容:
default_platform(:ios)
platform :ios do
desc "Description of what the lane does"
lane :custom_lane do
# add actions here: https://docs.fastlane.tools/actions
match(
git_url: "https://github.com/zjh171/fastlaneProvingProfile",
type: "appstore" , readonly: true
)
gym(
scheme:"Wallpaper",
export_method:"app-store",
output_directory:"./build",
archive_path:"./Archive"
)
end
end
這里我們只需要關注 match 和gym這兩個工具以及括號后的內容。match工具是我們本文開頭描述的用于同步開發小伙伴證書的工具,而gym則是xcodebuild工具的封裝,它指定了打包的目錄以及打包的類型。保存該文件并執行fastlane custom_lane
后我們可看到
這就表明我們打的App Store包已經生成了。目錄就是我們指定的output_directory
對應的目錄。當然大家也不難猜想到,如果要讓fastlane實現自動提交到App Store審核,還需要在gym后面加上我們需要的工具。這里先賣個關子,稍后告訴大家。下面筆者就詳細的介紹一下fastlane的使用。
安裝
執行命令sudo gem install fastlane --verbose
即可,安裝完成后檢查一下是否安裝成功輸入fastlane --version
看是否有版本號顯示。
初始化
輸入命令fastlane init
會看到如下選項
What would you like to use fastlane for?1\. Automate screenshots2\. Automate beta distribution to TestFlight3\. Automate App Store distribution4\. Manual setup - manually setup your project to automate your tasks
這四個選項的意思是
自動截屏。這個功能能幫我們自動截取APP中的截圖,并添加手機邊框(如果需要的話),我們這里不選擇這個選項,因為我們的項目已經有圖片了,不需要這里截屏。
自動發布beta版本用于TestFlight,如果大家有對TestFlight不了解的,可以參考王巍寫的這篇文章
自動的App Store發布包。我們的目標是要提交審核到APP Store,按道理應該選這個,但這里我們先不選,因為選擇了以后會需要輸入用戶名密碼,以及下載meta信息,需要花費一定時間,這些數據我們可以后期進行配置。
手動設置。
選擇第四個后一路回車即可,我們會看到生成了我們熟悉的fastlane目錄,該目錄下包含了Appfile和Fastfile。我們打開這兩個文件。 Appfile
# app_identifier("[[APP_IDENTIFIER]]") # The bundle identifier of your app# apple_id("[[APPLE_ID]]") # Your Apple email address# For more information about the Appfile, see:# https://docs.fastlane.tools/advanced/#appfile
發現里面沒有任何信息(“#”在ruby里是注釋,所以里面沒有任何信息)注釋的部分中,app_identifier
用于指定APP的bundle id
,apple_id
指的是你的AppleID。
Fastfile
# Uncomment the line if you want fastlane to automatically update itself# update_fastlanedefault_platform(:ios)
platform :ios do
desc "Description of what the lane does"
lane :custom_lane do
# add actions here: https://docs.fastlane.tools/actions
end
end
這個文件的信息稍微多一點,而且我們也更熟悉了,語法跟cocoapods很像,而且我們在文章開頭已經稍微做了一些介紹,發現在lane :custom_lane do
后面是空的。其實意思也就是說,這里任何操作都沒有執行。
運行
雖然這是個什么都沒有做的fastlane項目,但其實我們可以運行了,執行 fastlane custom_lane
命令,我們可以看到如下輸出
fastlane detected a Gemfile in the current directory however it seems like you don't use `bundle exec` to launch fastlane faster, please use
$ bundle exec fastlane custom_lane
//此處省略多行
fastlane.tools finished successfully
大致意思就是,我們可以使用命令bundle exec fastlane custom_lane
代替fastlane custom_lane
,這樣會執行的更快。最后的fastlane.tools finished successfully
表示執行成功了。
打包
提交審核的前一步是打包,也是最主要的一步fastlane中有專門用于編譯、打包的命令gym
,我們加到lane :custom_lane do
后看看會不會有問題。
然后執行fastlane custom_lane
我們會收到如下提示
Select Scheme:1\. Wallpaper2\. AFNetworking3\. Mangogo4\. Masonry5\. MJRefresh6\. Pods-Wallpaper
?
毫無疑問我們選擇1,其他的都是我們調用的三方庫。但聰明的讀者肯定在想,這個Scheme
是否能在fastlane
文件中就設置好,省的這里在自己選擇。是的,這就是文章開頭提到的
gym(
scheme:"Wallpaper",
export_method:"app-store",
output_directory:"./build",
archive_path:"./Archive"
)
中scheme:"Wallpaper",
的含義。其他的參數也就不一一贅述了。讀到這里,相信大部分讀者已經對fastlane的原理一清二楚了。其實所謂的會用fastlane也就是會用里面的各種工具而已。我相信大家選完Scheme
后還沒到打包這一步,應該已經出現了錯誤提示,錯誤應該就是大家都非常熟悉的證書問題;當然,如果讀者夠僥幸,證書已經設置好了,并將output_directory
、archive_path
設置好了,那就能生成對應的對應的IPA包。但相信成功的讀者應該寥寥無幾,這個時候就要使出我們的大殺器match
證書管理
fastlane中能管理證書和簽名的工具其實還有sigh
以及cer
,那為何筆者要給大家推薦match
呢,原因已經在文章開頭指出了,對于多人開發時出現的證書錯亂問題match
可以很好的處理。它將開發人員的證書提交到一個git倉庫進行集中處理,在有新的成員加入開發時候,只需要運行一兩條命令。下面我就詳細講一下其實現過程吧:
1.創建一個倉庫(空倉庫或者現有倉庫都可以,但建議大家使用一個空倉庫專門處理證書),這里筆者的倉庫地址是:https://github.com/zjh171/fastlaneProvingProfile
2.在終端運行fastlane match init
可以看到需要我們輸入giturl地址,我們將地址拷進來即可。
輸入地址后我們會看到如下提示
You can now run `fastlane match development`, `fastlane match adhoc`, `fastlane match enterprise` and `fastlane match appstore
我們按照提示生成development
和App Store
證書,然后會在Xcode中發現生成的證書以及Provision Profile
文件。我們在Xcode中設置好即可。
接下來,我們將match添加到fastlane文件中,如下
當然,這個文件我們已經在文章開頭看過了,是不是再次感覺豁然開朗?;氐矫钚校覀冊俅螆绦?code>fastlane custom_lane發現我們可愛的IPA包已經打包完畢。
提交App Store審核
終于到了最令人激動的提交App Store時刻了。我們要使用的工具是deliver
。聰明的你應該已經知道,第一步肯定是要調用fastlane deliver init
,這里會讓我們輸入APPle ID
,輸入以后就看到我們的項目文件夾發生了變化:
接著,我們修改一下fastfile
文件,添加deliver
,因此我們最終版的fastlane
文件是這樣的:
lane :release do
# 增加build版本號
increment_build_number
match(
git_url: "https://github.com/zjh171/fastlaneProvingProfile",
type: "appstore" ,#can be appstore,adhoc, development,enterprise
app_identifier:"cn.kyson.wallpaper",
username:"zjh171@qq.com", readonly: true
) # 編譯代碼
gym(
scheme:"Wallpaper",
export_method:"app-store",
) # 發布到Apple Store
deliver
end
可以看到,大部分配置跟以前一樣,只做了lane名的改變,還有添加了increment_build_number
這一行。increment_build_number
的作用是防止本地版本的build號比App Store
(或上次)低而做的自動增長版本號的處理。當然加了這幾句還需要在Xcode中做相應處理:
最后在命令行中輸入fastlane release
,等待大概十幾分鐘就可以看到成功的提示了。然后我們進入iTunes Connect
,確認一下:
確實是已經在審核狀態。如果大家想實現“一鍵審核”可以給deliver帶上參數submit_for_review
。這樣就真正實現了一鍵提交App Store
審核。至此,我們的一鍵打包審核流程完美收工。
注意點
筆者從開始研究fastlane
到完全跑出來大概花了三天時間,期間遇到了很多問題,走了很多彎路,總結一下,希望對讀者有一定幫助
fastlane的初始化命令是
fastlane init
,不需要加root權限,也就是sudo fastlane init
是不需要的,如果使用了sudo會對后面的各個操作造成很大影響,比如項目文件(workspace后project文件)會鎖定不能操作,還會引起打包失敗很多剛接觸fastlane的同學會一不注意就被fastlane上的各種命令整的暈頭轉向,例如
sync_code_signing
命令,其實是match
命令的另外一種寫法;build_app
命令其實是gym
的別名。因此大家在學習fastlane的時候只需要學習本文介紹的命令,大部分情況下已經夠用。如果對一個命令的用法不熟悉,可以通過fastlane action
查找,例如fastlane action match
。
原文:http://www.code4app.com/blog-363485-1856.html