Fastlane自動化構(gòu)建工具(完整解決測試和發(fā)布流程)

Fastlane自動化構(gòu)建工具(完整解決測試和發(fā)布流程)

fastlane

控制整體流程和實現(xiàn)的框架容器
支持平臺:iOS、Android
官方地址:https://github.com/fastlane/fastlane

fastlane流程

fastlane安裝:

系統(tǒng)要求:macOS或 Linux 使用 Ruby 2.0.0及以上版本
1.終端

sudo gem install fastlane --verbose

sudo gem install -n /usr/local/bin fastlane

2.確保Xcode安裝了最新版本的命令行工具

xcode-select --install

3.如果你的fastlane加載緩慢,請嘗試運行

gem cleanup

4.成功

fastlane安裝成功

fastlane快速使用:

參考文檔

1.進入要使用fastlane的項目根目錄

cd 你的項目根目錄

2.初始化fastlane

在項目根目錄下生成fastlane文件, 包含Appfile和Fastfile配置文件

fastlane init

3.根據(jù)提示,配置你的app

4.進一步定制Fastfile(基于Ruby語言)文件的額外活動

5.fastlane 指南

fastlane可用命令:

fastlane 命令名

其他命令:

fastlane actions:      列出所有可用fastlane活動
fastlane action [action_name]:   顯示一個更詳細的活動描述
fastlane lanes:      列出所有可用lanes (有描述)
fastlane list:       列出所有可用lanes (沒有描述)
fastlane new_action:     在fastlane創(chuàng)建一個活動(集成)

fastlane工具:

除fastlane命令,你還可以訪問以下fastlane工具

  • deliver: 上傳截圖, 元數(shù)據(jù), app應(yīng)用程序到App Store
  • supply: 上傳Android app應(yīng)用程序和元數(shù)據(jù)到Google Play
  • snapshot: 自動捕獲iOS app應(yīng)用程序本地截圖
  • screengrab: 自動捕獲Android app應(yīng)用程序本地截圖
  • frameit: 快速截屏并將截屏放入設(shè)備中
  • pem: 自動生成和更新推送通知配置文件
  • sigh: 開發(fā)證書和描述文件下載
  • produce: 使用命令行在iTunes Connect上創(chuàng)建新的app和開發(fā)入口
  • cert: 自動創(chuàng)建和配置iOS代碼簽名證書
  • spaceship: Ruby 庫訪問 Apple開發(fā)者中心和 iTunes Connect
  • pilot: 最好的方式管理你的TestFlight 測試人員和從終端構(gòu)建
  • boarding: 最簡單的方式邀請你的TestFlight beta測試人員
  • gym: iOS app打包簽名自動化工具
  • match: 使用Git同步你的團隊證書和配置文件
  • scan: 最簡單方式測試你的 iOS 和 Mac apps

gym打包簽名自動化工具

gym
gym是fastlane的一部分
自動構(gòu)建和發(fā)放iOS和Android應(yīng)用程序最簡單的方式

gym可以構(gòu)建和打包iOS和macOS應(yīng)用程序,很容易的生成一個簽名的ipa和app文件的所有重擔(dān)
官方地址:https://github.com/fastlane/fastlane/tree/master/gym

gym安裝:

1.終端

sudo gem install gym

2.確保Xcode安裝了最新版本的命令行工具

xcode-select --install

生成腳本:

將腳本文件放在項目相同的路徑下

1.進入項目路徑下

cd 你的項目根目錄

2.創(chuàng)建并編寫腳本

vim build_using_gym.sh

3.復(fù)制如下代碼到build_using_gym.sh文件中,修改項目名稱后保存

#!/bin/bash

#計時
SECONDS=0

#假設(shè)腳本放置在與項目相同的路徑下
project_path=$(pwd)
#取當(dāng)前時間字符串添加到文件結(jié)尾
now=$(date +"%Y_%m_%d_%H_%M_%S")

#指定項目的scheme名稱
scheme="項目名稱"
#指定要打包的配置名
configuration="Adhoc"
#指定打包所使用的輸出方式,目前支持app-store, package, ad-hoc, enterprise, development, 和developer-id,即xcodebuild的method參數(shù)
export_method='ad-hoc'

#指定項目地址
workspace_path="$project_path/項目名稱.xcworkspace"
#指定輸出路徑
output_path="project_path/APP"
#指定輸出歸檔文件地址
archive_path="$output_path/項目名稱_${now}.xcarchive"
#指定輸出ipa地址
ipa_path="$output_path/項目名稱_${now}.ipa"
#指定輸出ipa名稱
ipa_name="項目名稱_${now}.ipa"
#獲取執(zhí)行命令時的commit message
commit_msg="$1"

#輸出設(shè)定的變量值
echo "===workspace path: ${workspace_path}==="
echo "===archive path: ${archive_path}==="
echo "===ipa path: ${ipa_path}==="
echo "===export method: ${export_method}==="
echo "===commit msg: $1==="

#先清空前一次build
gym --workspace ${workspace_path} --scheme ${scheme} --clean --configuration ${configuration} --archive_path ${archive_path} --export_method ${export_method} --output_directory ${output_path} --output_name ${ipa_name}

#上傳到fir
fir publish ${ipa_path} -T fir_token -c "${commit_msg}"

#輸出總用時
echo "===Finished. Total time: ${SECONDS}s==="

4.為腳本添加執(zhí)行權(quán)限

chmod +x build_using_gym.sh

5.運行build_using_gym.sh腳本

./build_using_gym.sh 

6.自動打包完成

iOS打包成功

7.項目根路徑下APP文件夾

APP文件夾

gym使用:

#在項目根目錄下執(zhí)行:
gym

#如果你想更多的控制,可以執(zhí)行如下:
gym --workspace "Example.xcworkspace" --scheme "AppName" --clean

#如果你想使用不同的Xcode安裝,使用xcode-select或者定義DEVELOPER_DIR
DEVELOPER_DIR="/Applications/Xcode6.2.app" gym

#查看可用參數(shù)列表
gym --help

#遇到任何問題,獲得更多信息
gym --verbose

#遇到任何問題,導(dǎo)出存檔
gym --use_legacy_build_api

#如果你不想上傳AppStore或TestFlight,可以設(shè)置正確的導(dǎo)出方法
gym --export_method ad-hoc

#通過布爾參數(shù)來確定使用gym
gym --include_bitcode true --include_symbols false
訪問原始xcodebuild輸出: ~/Library/Logs/gym
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

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