FastLane是一种配置iOS和Android自动化Beta部署和发布的最简单的方法之一。它可以简化一些乏味、单调、重复的工作,像截图、代码签名以及发布App。
你可以从项目工程中创建FastLane文件开始,在FastLane文件里定义了Beta部署或App Store发布过程,如下:
省时:每次将新版本推送到商店或Beta测试服务时,都可节省时间。 |
集成:集成当前开发环境中所有存在的工具和服务。 |
开源:100%基于MIT许可开源。 |
简单:简单的设置助手,几分钟配置即可使用。 |
运行:基于你的app和数据,运行在本地机器上。 |
CI:集成几乎所有CI系统。 |
支持:支持iOS、Mac以及Android 应用。 |
自定义:根据自身需要扩展和定制fastlane,不依赖任何人。 |
命令行:不需要记住除fastlane以外的任何命令。 |
配置:可以在任何电脑上配置,包括CI服务器。 |
实际上fastlane是一套工具集,包含如下工具:
1) 测试工具
scan:自动运行测试工具,可以生成漂亮的HTML报告
2) 生成证书、配置文件工具
cert:自动创建iOS代码签名证书(.cert文件)
sigh:自动创建、更新、下载、修复Provisioning Profile
pem:自动生成、更新推送配置文件
3) 截图、描设备边框
deliver:上传截图、元数据、App到iTunesConnect
snapshot:使用UI test功能实现自动截图
frameit:在截图的图片外层套上物理设备边框
4) 自动化编译工具
gym:自动化编译工具
5) App公测工具
pilot:管理TestFlight测试用户,上传二进制文件
firim:管理firim
1) Fastlane其实是一个Ruby脚本的集合,首先查看是否安装Ruby
ruby -v
2) 检测:确保已安装最新Xcode命令行工具
xcode-select --install
3) 安装:安装fastlane命令行
brew cask install fastlane
4) 初始化:进入工程目录,初始化fastlane
fastlane init
在此过程中,fastlane将会自动检查你的工程项目,然后提示输入为输入信息及验证已输入信息是否正确。
├── Appfile
├── Deliverfile
├── Fastfile
├── Pluginfile
├── README.md
├── Snapfile
├── SnapshotHelper.swift
├── metadata
│ ├── copyright.txt
│ ├── itunes_rating_config.json
│ ├── primary_category.txt
│ ├── primary_first_sub_category.txt
│ ├── primary_second_sub_category.txt
│ ├── review_information
│ ├── secondary_category.txt
│ ├── secondary_first_sub_category.txt
│ ├── secondary_second_sub_category.txt
├── report.xml
├── screenshots
└──README.txt
1) Fastfile:自动化执行配置文件
2) Appfile:存储App公共信息
3) Deliverfile:存储App发布信息
1) 查看支持的所有插件:fastlane search_plugins
2) 安装插件:fastlane add_plugin [name]
3) 常用插件安装:
fastlane add_plugin versioning(设置App插件号车间)
fastlane add_plugin firim(设置测试版发布平台firim)
1) 、App Store屏幕截图可能是说服潜在用户下载或购买应用的最重要事情之一。然而,许多app的屏幕截图做得并不好,因为准备图片和展示图片会花费很多时间 。我们主要会基于以下考虑:
App Store展示的截图是否和最新的app设计一致?
App截图的本地化语言显示是否一致?
App截图不完整是否导致图片显示的差异?
屏幕截图在各种设备上显示内容是否存在差异?
对于这些问题,fastlane都可以进行快速的自动化处理,并产生我们所期望的结果。而手动截图最大的缺点是我们需要在每次发布app之前不断的重复相同的流程,或许因为一个拼写错误、一个本地语言的增加或删除、一个页面更新等,我们都得从头再来,真是太可怕了。
2) 、Fastlane在snapshot自动抓取app截图的过程中,我们可以:
抓取不同设备、不同语言的截图。
在抓取截图的过程中,我们可以省下很多时间做其他事情。
一次完整的配置,可以和其他协同开发成员共享。
生成的所有截图可以通过网页展示出来。
3) 、抓取截图完成后,漂亮的HTML页面显示如下所示:
snapshot使用UI Tests功能来抓取App上的图片。在开始使用UITests时,可以使用UI Test录制,只需按下Xcode底部的红色按钮。这是,xcode将会记录下你的操作代码。实际操作步骤如下:
1) 在xcode工程中创建一个新的UI测试目标。
2) 在工程目录下运行:fastlane snapshot init。
3) 将生成的./SnapshotHelper.swift文件添加到UI测试文件目录下。
4) 添加桥接头文件到我们的测试类中(只适用于OC代码)。
5) 在UI测试类中,按下录制按钮开始录制我们的交互操作。
6) 在UI测试类需要截图的地方添加代码:
Swift:snapshot(“01LoginScreen”);
OC:[Snapshotsnapshot:@”01LoginScreen” waitForLoadingIndicatore:YES];
7) 在setup()函数中添加如下代码:
swift:letapp = XCUIApplication()
setupSnapshot(app)
app.lanuch()
oc:XCUIAppication*app = [[XCUIApplication alloc] init];
[Snapshot setupSnapshot:app];
[app launch];
8) 在运行setup()函数过程中,将生成一个名为Snapfile的文件,这个文件在运行fastlane snapshot命令的时候将会被加载,内容如下所示:
# A list of devices you want totake the screenshots from
# devices([
# "iPhone 6",
# "iPhone 6 Plus",
# "iPhone 5",
# "iPhone 4s",
# "iPad Retina",
# "iPad Pro"
# ])
languages([
"en-US",
"de-DE"
])
… …
注:如果没有生成Snapfile文件,使用命令行$ fastlane snapshot init
生成。
9)
如果已经安装fastlane,我们可以很容易的通过snapshot截图。
fastlane snapshot
使用fastlanesnapshot生成截图后,我们就开始上传图片到iTunes Connect。安装fastlane并且在工程根目录下运行snapshot init命令,我们会在工程根目录下看到fastlane/screenshots和fastlane/metadata目录。我们截取的图片就保存在fastlane/screenshots中。
上传截图很简单,只需要运行:
fastlane deliver
如果我们将上面的分步操作组合在一起执行,那么在开发团队中的任何人都可以上传新的截图,而通过对Fastfile文件的配置帮助我们实现了这一点,配置如下:
lane :screenshots do
snapshot
deliver
end
frameit将帮助我们为App截图构建漂亮的设备边框,只需要运行命令:
fastlane frameit
在此不在详述具体过程,效果如下(相当漂亮):
fastlane通过gym来构建app,需要在fastfile中添加:
lane :beta do
gym(scheme: “MyApp”)
end
然后运行:fastlanebeta,我们在当前目录下将会看到[ProductName].ipa文件。
在编译打包完成后,我们就可以上传测试版本到测试服务器上了,这时修改3.1中的配置为:
lane :beta do
match(type: “appstore”)
gym(scheme:”MyApp”)
testflight
slack(message: “成功上传测试版到testflight”)
end
打开Fastfile文件,添加如下内容:
lane :upload_firim do
sigh(adhoc: true)#
申请
adhoc证书
increment_build_number_in_plist(target: [target_name])
increment_version_number_in_plist(
target: [target_name],
version_number: '7.1.3'
)
gym(
#gym用于编译ipa
output_directory: './firim',
export_options: {
method: "ad-hoc", #
默认
,
可以不指定
thinning: "
"
}
)
firim(firim_api_token: [firim_api_token])
#上传ipa到fir.im服务器
end
输入命令:fastlaneupload_firim一键上传。
fastlane通过gym来构建app,需要在fastfile中添加:
lane :appstore do
gym(scheme: “MyApp”)
end
然后运行:fastlaneappstore,我们在当前目录下将会看到[ProductName].ipa文件。
在编译打包完成后,我们就可以上传测试版本到测试服务器上了,这时修改4.1中的配置为:
lane :appstore do
sigh
increment_build_number_in_plist(target: [target_name])
increment_version_number_in_plist(
target: [target_name],
version_number: '7.1.3'
)
gym(# 指定输出目录
output_directory: './build',
)
deliver(force: true) # 上传所有信息到App Store
end
输入命令:fastlaneappstore一键上传。