一、Fastlane工具的簡介:ios
Fastlane是一套使用Ruby寫的自動化工具集,旨在簡化Android和iOS的部署過程,自動化你的工做流。它能夠簡化一些乏味、單調、重複的工做,像截圖、代碼簽名以及發佈App。可使用 fastlane 上傳到firim和蒲公英。api
二、Fastlane工具的功能分類:xcode
Testing 測試相關ruby
Building 打包app
Screenshots 截圖ide
Project 項目配置工具
Code Signing 代碼簽名測試
Documentation 文檔ui
Beta 內測相關spa
Push 推送
Source Control Git工做流
Notifications 通知相關
Misc 其餘的東西
三、Fastlane工具的安裝:
《1》檢查Ruby版本,須要2.0及以上版本,在終端輸入如下命令:
ruby -v
《2》須要注意的是須要將gem的source改成https://gems.ruby-china.org/,在終端輸入如下命令:
gem source
檢查結果爲:
*** CURRENT SOURCES ***
https://ruby.taobao.org/
http://gems.ruby-china.org/
《3》檢查Xcode命令行工具是否安裝,在終端輸入如下命令:
xcode-select --install
若是沒有安裝會進行安裝,若是已經安裝則會提示以下:
xcode-select: error: command line tools are already installed, use "Software Update" to install updates
解決辦法:
sudo xcode-select --switch /Library/Developer/CommandLineTools/
《4》安裝Fastlane,在終端輸入命令以下:
sudo gem install fastlane --verbose
若是安裝出現如下錯誤:
ERROR: While executing gem ... (Gem::FilePermissionError)
You don't have write permissions for the /usr/bin directory.
解決辦法:
sudo gem install -n /usr/local/bin fastlane或sudo gem install fastlane -NV
《5》檢查Fastlane是否安裝正確,輸入如下命令:
fastlane --version
四、Fastlane工具的使用:
《1》使用命令切換到項目工程:
cd /Users/yh/Desktop/xxx/FloatingWindow_Demo
《2》初始化Fastlane:
fastlane init
若是初始化出現如下錯誤:
[!] Unable to locate Xcode. Please make sure to have Xcode installed on your machine
解決辦法:
在Xcode中沒有設置「Command Line Tools」:打開Xcode偏好設置,選擇"Location"選項卡,選擇相應的「Command Line Tools」便可。好比:Xcode9.1
《3》提示輸入開發者帳號、密碼, 登陸成功後會提示你輸入App名稱,是否須要下載你的App的metadata。點y等待就能夠了:
完成後顯示結果爲:
+----------------+--------------------------------+
| Summary for produce 2.98.0 |
+----------------+--------------------------------+
| username | admin@xxxxxx.com |
| team_id | xxxxxx |
| itc_team_id | xxxxxx |
| platform | ios |
| app_identifier | com.xxxxxx.FloatingWindow-Demo |
| skip_itc | true |
| sku | xxxxxx |
| language | English |
| skip_devcenter | false |
+----------------+--------------------------------+
注意事項:
A、會問你想使用fastlane作什麼?這裏咱們輸入3,自動發佈到Apple Store。
B、接着會問是否想用fastlane來管理你的app metadata。輸入y,fastlane則會下載現有的元數據和屏幕截圖。輸入n,不作任何操做,仍然能使用fastlane上傳app到App Store。
C、若是最後出現fastlane release,就表示init成功了。
五、Fastlane工具組成的內容:
《1》初始化成功後會在當前工程目錄生成一個fastlane文件夾和一個Gemfile文件, 文件夾目錄爲
《2》Appfile:存放App的apple_id,team_id, app_identifier等信息
《3》Deliverfile:存放發佈的配置信息
《4》Fastfile:工做編輯文件
《5》metadata:App元數據
《6》screenshots:商店應用截圖
六、操做並編輯Fastfile文件:
# 自動更新fastlane 工具
# update_fastlane
#須要的fastlane的最小版本,在每次執行以後會檢查是否有新版本,若是有會在最後末尾追加新版本提醒
fastlane_version "2.98.0"
default_platform(:ios)
platform :ios do
#lane以前的操做
before_all do
# ENV["SLACK_URL"] = "https://hooks.slack.com/services/..."
cocoapods
end
#執行lane成功後的回調
after_all do |lane|
# slack(
# message: "Successfully deployed new App Update."
# )
end
desc "提交一個新的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: "FloatingWindow_Demo") # Build your app - more options available
pilot
# sh "your_script.sh"
end
desc "部署一個新版本到App Store"
lane :release do
# match(type: "appstore")
# snapshot
gym(scheme: "FloatingWindow_Demo") # Build your app - more options available
deliver(force: true)
# frameit
end
# 你能夠定義本身的lane
desc "打包到蒲公英"
lane :test do |options|
gym(
clean:true, #打包前clean項目
export_method: "ad-hoc", #導出方式
scheme:"shangshaban", #scheme
configuration: "Debug",#環境
output_directory:"./app",#ipa的存放目錄
output_name:get_build_number()#輸出ipa的文件名爲當前的build號
)
#蒲公英的配置 替換爲本身的api_key和user_key
pgyer(api_key: "xxxxxxx", user_key: "xxxxxx",update_description: options[:desc])
end
# 若是流程發生異常會走這裏並終止
error do |lane, exception|
# slack(
# message: exception.message,
# success: false
# )
end
end
七、Fastlane插件命令:
《1》列出全部可用插件
fastlane search_plugins
《2》搜索指定名稱的插件:
fastlane search_plugins [query]
《3》添加插件:
fastlane add_plugin [name]
《4》安裝插件:
fastlane install_plugins
其它命令字:
gym:編譯打包生成 ipa 文件
sigh:能夠生成並下載開發者的 App Store 配置文件
deliver:用於上傳應用的二進制代碼,應用截屏和元數據到 App Store
snapshot:能夠自動化iOS應用在每一個設備上的本地化截屏過程
scan:自動化測試工具,很好的封裝了 Unit Test
match :同步團隊每一個人的證書和 Provision file 的超讚工具
八、使用Fastlane上傳到蒲公英:
《1》打開終端輸入命令:
fastlane add_plugin pgyer
《2》新建一個定義本身的lane,option用於接收咱們的外部參數,這裏能夠傳入當前build的描述信息到蒲公英平臺:
desc "打包到蒲公英"
lane :test do |options|
gym(#測試打包
clean:true, #打包前clean項目
export_method: "ad-hoc", #導出方式
scheme:"FloatingWindow_Demo", #scheme
configuration: "Debug",#環境
output_directory:"./app",#ipa的存放目錄
output_name:get_build_number()#輸出ipa的文件名爲當前的build號
)
sigh( #發佈打包
clean:true, #打包前clean項目
export_method: "app-store」, #導出方式
scheme:"FloatingWindow_Demo", #scheme
configuration: 「Release」,#環境
output_directory:"./app",#ipa的存放目錄
output_name:get_build_number()#輸出ipa的文件名爲當前的build號
)
#蒲公英的配置 替換爲本身的api_key和user_key
pgyer(api_key: "xxxxxxxxxxxx", user_key: "xxxxxxxxxxxx",update_description: options[:desc])
end
《3》在工做目錄的終端執行命令:
fastlane test desc:測試蒲公英打包
九、使用Fastlane上傳到firim:
《1》打開終端輸入命令:
fastlane add_plugin firim
《2》新建一個定義本身的lane
desc "打包到fir」
lane :test2 do |options|
gym(#測試打包
clean:true, #打包前clean項目
export_method: "ad-hoc", #導出方式
scheme:"FloatingWindow_Demo", #scheme
configuration: "Debug",#環境
output_directory:"./app",#ipa的存放目錄
output_name:get_build_number()#輸出ipa的文件名爲當前的build號
)
sigh( #發佈打包
clean:true, #打包前clean項目
export_method: "app-store」, #導出方式
scheme:"FloatingWindow_Demo", #scheme
configuration: 「Release」,#環境
output_directory:"./app",#ipa的存放目錄
output_name:get_build_number()#輸出ipa的文件名爲當前的build號
)
#firim的配置 替換爲本身的api_key和user_key
firim(firim_api_token: 「xxxxxxxxxxxx」)
end
《3》在工做目錄的終端執行命令:
fastlane test2 desc:測試firim打包