ios实现fastlane自动化打包
终于抽出时间来学习自动化打包了,app在测试阶段一天总会经历好几次的打包,每次打包真是身心疲惫,刚打完的包说不定就被测试妹子反应还要微调什么地方,我就真的有气没法出,打一次包怎么也得浪费十几分钟,还不能改动自己的项目,一个上午或者下午发现很快就过去了,真的很是憋屈。下面就讲述自己的项目用自动化打包的详细过程。
一、安装前的准备工作
- 首先确认是否安装了ruby,终端查看下ruby版本, 要求大于2.0.0
$ ruby -v
2.确认是否安装了xcode命令行工具
$ xcode-select --install
1)如果出现
表示已经安装成功
2)如果出现
就点击安装就行了。。。
二、正式安装
安装fastlane
$ gem install fastlane -nv
三、项目配置
1、为项目配置 fastlane
$ cd 项目目录
$ fastlane init
初始化的过程中会出现下面的选项:
第一个选项的意思是:自动截屏。这个功能能帮我们自动截取app中的截图,并添加手机边框(如果需要的话)
第二个选项的意思是:自动发布beta版本用于testflight
第二个选项的意思是:自动发布到appstore
第二个选项的意思是:手动设置
我在这里选的是第四个(大家可根据自己需要选择),截图如上,紧接着一直点击enter
键。
出现上面的就表明成功了。
中间可能会让输入苹果开发者账号和密码,安装成功之后之后会在你项目工程的目录下生成一个fastlane文件夹,里面有fastlane的配置文件,一个是appfile文件,一个是fastfile文件(如果要上传appstore的话还有deliverfile文件)。
- appfile保存苹果开发者的相关信息、项目的相关信息等。
-
fastfile是运行脚本。
类似下面
四、打包上传
1、上传到蒲公英
1)创建好faselane文件之后,安装蒲公英插件
//在项目目录下执行
$ fastlane add_plugin pgyer
中途遇到下面情况,选择y
出现下面的提示即成功了
2)修改fastfile 内容
打开自动生成的fastfile文件
$ vim ./fastlane/fastfile
我们可以看到
将对应的地方更改如下,有两种方式build_app或者gym,任选其一即可
i、build_app方式
default_platform(:ios)
platform :ios do
desc "description of what the lane does"
lane :testimgpgyer do #lane冒号后面一定要紧跟名字,不能有空格
# add actions here: https://docs.fastlane.tools/actions
build_app(export_method: "development")
pgyer(api_key: "1b49e52f7ca2e286999ebdfa10f53c85", user_key: "1eaff70f6ff3b919b0f6c43fc1ec9378")
end
end
gym
(ios和android应用程序自动化测试版部署和发布的最简单方法),gym和上面的build_app功能一样,是他的别名。default_platform(:ios)
platform :ios do
desc "上传蒲公英1"
lane :testimgpgyer do #testimgpgyer 为lane 名称,只要和后面的lane保持一致即可,我们执行时就是执行这个方法
scheme_name = "testimg"
#导出路径 我们可以桌面创建ipa_info(没有的话会自动创建) 文件夹来集中管理生成的ipa等文件
output_directory = "/users/xywy/desktop/ipa_info"
#导出名称
output_name = "#{scheme_name}_#{time.now.strftime('pgyer%y%m%d%h%m%s')}.ipa"
gym(
export_method: "development", #这里填写导出方式 ad-hoc、enterprise、app-store
#xcode 9 默认不允许访问钥匙串的内容,必须要设置此项才可以
export_xcargs: "-allowprovisioningupdates",
scheme: scheme_name,# target的名字
clean: true, # 在构建前先clean
output_directory: output_directory, #ipa输出目录
output_name: output_name#ipa名字
)
# 上传蒲公英,update_description为版本更新描述。
pgyer(api_key: "1b49e52f7ca2e286999ebdfa10f53c85", user_key: "1eaff70f6ff3b919b0f6c43fc1ec9378", update_description: "haha")
end
end
以上的 api_key 和 user_key,在蒲公英自己账号下的 应用管理 - api 中可以找到,并替换到以上相应的位置。
在 xcode 8.3 和 xcode 8.3 以后的版本中,对于 build_app 的 export_method 的值,需要根据开发者的打包类型进行设置,可选的值有:app-store、ad-hoc、development、enterprise。一定要确保你选择环境的对应的项目证书已配置正确,否则会报错误。对于 xcode 8.3 以下的版本,则不需要设置 export_method。
3)打包并自动上传 app 到蒲公英
//在项目目录下执行
$ fastlane testimgpgyer #和前面lane后面的名称保持一致
2、上传到fir.im
1)类似上传到蒲公英,需要安装fir插件
$ fastlane add_plugin firim
出现下面的提示即成功了
自动上传到fir
还需执行如下命令:
$ gem install fir-cli
如果报下面的权限错误
改用
$ sudo gem install -n /usr/local/bin fir-cli --no-ri --no-rdoc
提示下面信息,则成功了
2)修改fastfile 内容。
$ vim ./fastlane/fastfile
下面只附上对应gym方式的内容
default_platform(:ios)
platform :ios do
desc "上传fir”
lane :testimgfir do #testimgfir 为lane 名称,只要和后面的lane保持一致即可,我们执行时就是执行这个方法
scheme_name = "testimg"
#导出路径 我们可以桌面创建ipa_info(没有的话会自动创建) 文件夹来集中管理生成的ipa等文件
output_directory = "/users/xywy/desktop/ipa_info"
#导出名称
output_name = "#{scheme_name}_#{time.now.strftime('fir_im%y%m%d%h%m%s')}.ipa"
gym(
export_method: "development", #这里填写导出方式 ad-hoc、enterprise、app-store
#xcode 9 默认不允许访问钥匙串的内容,必须要设置此项才可以
export_xcargs: "-allowprovisioningupdates",
scheme: scheme_name,# target的名字
clean: true, # 在构建前先clean
output_directory: output_directory, #ipa输出目录
output_name: output_name#ipa名字
)
# 上传蒲公英
firim(firim_api_token: "fffea58a4baed4d2b1fc2179d2f32119")
end
end
注意:
以上的firim_api_token可以在fir.im上,点击账号处的“api token”查看或者生成
3)打包并自动上传 app 到蒲公英
//在项目目录下执行
$ fastlane testimgfir #和前面lane后面的名称保持一致
至此,自动化打包安装过程结束!!!
参考自:
https://www.jianshu.com/p/b357d7c7076f
上一篇: JavaScript实现继承方式的整理