iOS自动化打包发布(fastlane)

时间:2022-08-29 13:10:36

一、FastLane介绍

1.1 FastLane是什么?

FastLane是一种配置iOS和Android自动化Beta部署和发布的最简单的方法之一。它可以简化一些乏味、单调、重复的工作,像截图、代码签名以及发布App。

参考官方文档:https://docs.fastlane.tools/getting-started/ios/setup/

1.2 FastLane使用优势

省时:每次将新版本推送到商店或Beta测试服务时,都可节省时间。

集成:集成当前开发环境中所有存在的工具和服务。

开源:100%基于MIT许可开源。

简单:简单的设置助手,几分钟配置即可使用。

运行:基于你的app和数据,运行在本地机器上。

CI:集成几乎所有CI系统。

支持:支持iOS、Mac以及Android 应用。

自定义:根据自身需要扩展和定制fastlane,不依赖任何人。

命令行:不需要记住除fastlane以外的任何命令。

配置:可以在任何电脑上配置,包括CI服务器。

1.4 FastLane基础组件

实际上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.5 FastLane基础环境

1) Fastlane其实是一个Ruby脚本的集合,首先查看是否安装Ruby

ruby -v

2) 检测:确保已安装最新Xcode命令行工具

xcode-select  --install

3) 安装:安装fastlane命令行

检查gem源: gem sources

必须添加此项:gem sources --add https://rubygems.org

安装fastlane:sudo gem install fastlane

4) 初始化:进入工程目录,初始化fastlane

fastlane init

在此过程中,fastlane将会自动检查你的工程项目,然后提示输入为输入信息及验证已输入信息是否正确。

5)给截图添加外框

初始化:fastlane frameit setup或者bundle exec fastlane frameit setup

安装依赖库:brew update && brew install imagemagick

1.7 FastLane主要文件说明

1) Fastfile:自动化执行配置文件

2) Appfile:存储App公共信息

3) Deliverfile:存储App发布信息

1.8 FastLane插件安装

1) 查看支持的所有插件:fastlane search_plugins

2) 安装插件:fastlane add_plugin [name]

3) 常用插件安装:

fastlane add_plugin versioning(设置App插件号车间)

fastlane add_plugin firim(设置测试版发布平台firim)

fastlane add_plugin pgyer (安装蒲公英)

二、FastLane抓图

2.1 FastLane自动抓图

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命令的时候将会被加载

2.3上传截图到App Store

使用fastlanesnapshot生成截图后,我们就开始上传图片到iTunes Connect。安装fastlane并且在工程根目录下运行snapshot init命令,我们会在工程根目录下看到fastlane/screenshots和fastlane/metadata目录。我们截取的图片就保存在fastlane/screenshots中。

上传截图很简单,只需要运行:

fastlane deliver

2.4使用Fastfile文件实现自动化

如果我们将上面的分步操作组合在一起执行,那么在开发团队中的任何人都可以上传新的截图,而通过对Fastfile文件的配置帮助我们实现了这一点,配置如下:

lane :screenshots do

snapshot

deliver

end

2.5为我们的截图加上物理设备边框

frameit将帮助我们为App截图构建漂亮的设备边框,只需要运行命令:

fastlane frameit

在此不在详述具体过程,效果如下(相当漂亮):

iOS自动化打包发布(fastlane)

三、详细配置

3.1 Fastfile

default_platform(:ios)

platform :ios do
desc "Generate new localized screenshots"
lane :screenshots do
capture_screenshots
frame_screenshots(silver: true)
# upload_to_app_store
end
lane :tests do
run_tests(workspace: "xxx.xcworkspace",
devices: ["iPhone 6s"],
scheme: "xxxUITests")
end
lane :beta do
sigh(development: true)
# increment_build_number(xcodeproj: "xxx.xcodeproj")
# sync_code_signing(type: "appstore")
build_app(scheme: "xxx",
workspace: "xxx.xcworkspace",
include_bitcode: true,
export_method: "development")
pgyer(api_key: "xxxxxx", user_key: "xxxxxx")
# upload_to_testflight
end
end

3.2 Appfile

app_identifier("com.xxx") # The bundle identifier of your app
apple_id("xxx@xxx.com") # Your Apple email address itc_team_id("xxxxxx") # iTunes Connect Team ID
team_id("xxxxxx") # Developer Portal Team ID

3.3 Pluginfile

# Autogenerated by fastlane
#
# Ensure this file is checked in to source control!

gem 'fastlane-plugin-pgyer'

3.4 Snapfile

# Uncomment the lines below you want to change by removing the # in the beginning

# A list of devices you want to take the screenshots from
devices([
"iPhone 8",
"iPhone 8 Plus",
"iPhone SE",
"iPhone X"
]) languages([
"zh-CHT",
# "en-US"
]) # The name of the scheme which contains the UI Tests
scheme("xxxUITests") # Where should the resulting screenshots be stored?
output_directory("./fastlane/screenshots") # remove the '#' to clear all previously generated screenshots before creating new ones
clear_previous_screenshots(true) # Arguments to pass to the app on launch. See https://docs.fastlane.tools/actions/snapshot/#launch-arguments
# launch_arguments(["-favColor red"]) # For more information about all available options run
# fastlane action snapshot

3.5 screenshots配置

screenshots/Framefile.json
{
"default": {
"keyword": {
"fonts": [
{
"font": "./fonts/Chinese.ttf",
"supported": ["zh-CHT"]
}
]
},
"title": {
"fonts": [
{
"font": "./fonts/Chinese.ttf",
"supported": ["zh-CHT"]
}
],
"color": "#545454"
},
"background": "./background.jpg",
"padding": 50,
"show_complete_frame": false,
"stack_title" : false,
"title_below_image": false
}, "data": [
{
"filter": "Health",
"keyword": {
"color": "#d21559"
}
},
{
"filter": "Medical",
"keyword": {
"color": "#feb909"
}
},
{
"filter": "Insurance",
"keyword": {
"color": "#aa4dbc"
}
},
{
"filter": "myCenter",
"keyword": {
"color": "#31bb48"
}
}
]
}

screenshots/zh-CHT/keyword.strings

"Health" = "健康";

"Medical" = "医疗";

"Insurance" = "保险";

"myCenter" = "我的";

screenshots/zh-CHT/title.strings

"Health" = "活动 & 自测";

"Medical" = "家庭医生 & 名医直达";

"Insurance" = "健康险 + 1对1服务";

"myCenter" = "订单、分期、保单等";

screenshots/fonts/Chinese.ttf

下载合适的字体文件并改名为Chinese.ttf

screenshots/background.jpg

iOS自动化打包发布(fastlane)

iOS自动化打包发布(fastlane)的更多相关文章

  1. Mac Jenkins+fastlane 简单几步实现iOS自动化打包发布 + jenkins节点设置

    最近在使用jenkins 实现ios自动化打包发布蒲公英过程实践遇到了一些坑,特意记录下来方便有需要的人. 进入正题: 一.安装Jenkins 1.Mac上安装Jenkins 遇到到坑 因为 Jenk ...

  2. iOS 自动化打包发布(Fastlane+ Jenkins+蒲公英)

    安装 Xcode 命令行工具:xcode-select --install 安装 fastlane:sudo gem install fastlane --verbose 安装成功后查看版本:fast ...

  3. IOS自动化打包介绍

    IOS自动化打包介绍  标签: app打包 , Ios打包 , iphone打包 , iphone自动化打渠道包    分类:无线客户端技术, 贴吧技术 摘要 随着苹果手持设备用户的不断增加,ios应 ...

  4. iOS自动化打包上传的踩坑记

    http://www.cocoachina.com/ios/20160624/16811.html 很久以前就看了很多关于iOS自动打包ipa的文章, 看着感觉很简单, 但是因为一直没有AppleDe ...

  5. 【2】IOS APP打包发布

    目的: 本文的目的是对IOS APP打包发布做了对应的介绍,大家可根据文档步骤进行mac环境部署: 申请苹果开发者账号 此处略 创建申请证书 这样做的目的就是为你的电脑安装发布许可证,只有这样你的电脑 ...

  6. Jenkins+ Xcode+ 蒲公英 实现IOS自动化打包和分发

    Jenkins+ Xcode+ 蒲公英 实现IOS自动化打包和分发 直接入正题: Screen Shot 2015-09-18 at 16.56.20.png Mac上安装Jekins jekins下 ...

  7. iOS 自动化打包

    理想的情况:不打开工程的情况下,直接双击就能打包出一个IPA文件,这样就可以让测试直接使用 itools 进行安装. 分如下两种情况: 1)不依赖cocoapod  管理项目的自动化. 如果没有一个简 ...

  8. iOS企业版打包 发布在线安装包 plist

    本文转载至 http://blog.csdn.net/u011452278/article/details/49511385 原文转载:http://blog.csdn.net/pang040328/ ...

  9. 一个IOS自动化打包的脚本

    网上找了一个脚本,在其中进行了修改,只需要一条命令就可以了 支持自动导入配置文件 支持自动安装p12证书 支持自动修改版本号和build版本号 支持自动修改app显示名称 支持自动修改bundle i ...

随机推荐

  1. TAP/TUN浅析(一)

    参考链接:https://www.ibm.com/developerworks/cn/linux/1310_xiawc_networkdevice/ TAP 设备与 VETH 设备     TUN/T ...

  2. WinForm中DataGridView显示更新数据--人性版

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  3. eclipse新建maven项目(2)

    本篇博文是继续之前的博文eclipse新建maven项目(1),那篇博文不在随笔在文章中.首先按照之前那篇博文进行创建maven项目操作,一系列操作下来之后发现刷新项目后会报错: 别急哈,可以解决. ...

  4. 比较全面的MySQL优化参考(上下篇)

    转自:http://imysql.com/2015/05/24/mysql-optimization-reference-1.shtml 本文整理了一些MySQL的通用优化方法,做个简单的总结分享,旨 ...

  5. ZOJ3229 Shoot the Bullet

    http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=20756 思路:就讲一下有源汇上下界最大流的做法吧!对于所有的边,就按照无源汇 ...

  6. Linux fdisk命令参数及用法详解---Linux磁盘分区管理命令fdisk

    fdisk 命令 linux磁盘分区管理 用途:观察硬盘之实体使用情形与分割硬盘用. 使用方法: 一.在 console 上输入 fdisk -l /dev/sda ,观察硬盘之实体使用情形. 二.在 ...

  7. MailTest

    GridBagLayout把一个界面分为m行n列的网格 GridBagConstraints的一个实例:gridx = 2; // X2,表示组件位于第2列gridy = 0; // Y0,表示组件位 ...

  8. 【前端】深入浅出Javascript中的数值转换

    由于Javascript是一门弱类型的语言,在我们的代码中无时无刻不在发生着类型转换,所以了解Javascript中的类型转换对于了解我们认识Javascript的运行原理至关重要. 本文主要从数值转 ...

  9. 图解script的三种加载方式 异步加载顺序

    摘录如下: 可以很清晰的看出: <script>: 脚本的获取和执行是同步的.此过程中页面被阻塞,停止解析. <script defer = "defer"&gt ...

  10. nodejs版本更新问题:express不是内部或外部命令

    版本更新后,我们使用熟悉的npm install -g express命令安装,但是,安装成功之后居然提示express不是内部或外部命令. nodejs小问题:[1]express不是内部或外部命令 ...