[关闭]
@pockry 2016-10-08T16:36:03.000000Z 字数 3952 阅读 3324

Fastlane实战(三):Fastlane在Android平台的应用

移动 Fastlane Android 持续集成 自动化


平心而论,Fastlane本身对Android平台的支持力度确实有限,15个核心工具中仅有2个是用于Android平台的,其中:

  1. Supply是用于上传APK文件和同步Meta信息到Google Play商店(类似iOS的Deliver)
  2. Screengrab是用于生成各种屏幕尺寸的截屏,然后上传这些截屏到Google Play商店

好吧,看上去这两个工具都和Google Play相关,这个对于国内大部分Android开发者来说,似乎都派不上用场。

当然这也不能怪Fastlane重iOS,轻Android。和iOS不同,Android本身就没有那么多琐碎的事情,比如:证书管理,Provisioning文件管理,推送证书管理,签名等等,也不需要专门使用一个类似Testflight的测试平台来分发测试包,基本上一个APK打包出来,就能随便安装了。

不过俗话说得好:“家家有本难念的经”,如果从开发复杂度来比较,Android平台其实是有过之而无不及的。功能开发完毕只是一切的开始,多系统,多屏幕,多厂商的适配,五花八门的市场分发才是真正的难题。如何快速,低成本的解决这些难题,将成为Andriod工程师们所面临的挑战。

多渠道打包

我相信每个公司的市场部门都希望精确的统计到各个投放渠道的安装,激活,注册,留存,变现等数据,从而能够有的放矢。这一切的数据统计都来源于渠道包的生成。由于国内Android市场众多,所以在最终发版的时候,我们需要提供多个渠道包给市场同学,如果手动处理的话,那么步骤大概如下:

  1. 执行Git Pull命令,拉最新的代码到本地
  2. 修改渠道标识,如:在APK的META-INFO目录增加一个空的文件,文件名为渠道名
  3. 执行./gradlew clean命令清理环境
  4. 执行./gradlew assembleRelease打包Release版本
  5. 将生成的APK文件重新命名为改渠道对应的名字

然后以上步骤重复N次,N=渠道数,如果N>=3,我相信无论是多么有耐心的人,经过两三次下来,结果都会崩溃,尤其是万一上线前发现版本中包含Bug,那么只能重来一遍,此时N=渠道数x重来的次数。

其实我这里描述的场景可能稍显夸张,我相信大部分公司都会或多或少使用一些自动化的方式来处理,比如通过Shell命令等等。这里我们可以看看使用Fastlane如何进行处理:

首先,我们自定义一个Action:add_channels_to_apk,这个Action的作用就是:

  1. 拷贝最终打包生成的apk文件,并修改文件名为渠道名,如gengmei_qq_630.apk
  2. 然后将一个渠道名写入到apk文件的META-INFO目录中

其次,新建一个txt文件,里面写入所有需要打包的渠道名,如:QQ,360,Baidu...等等,渠道名之间用逗号隔开。

最后,在Fastfile中定义一个Lane来进行最终的集成处理:

  1. desc "Package a new app version with different channels"
  2. lane :do_package_apk do |options|
  3. project = "#{options[:project]}"
  4. target_version = options[:version]
  5. hipchat(message: "Start package #{project} at version #{target_version}")
  6. git_pull
  7. gradle(task: "clean")
  8. gradle(task: "assembleRelease")
  9. add_channels_to_apk(channels: './channels.txt')
  10. hipchat(message: "Deliver app #{project} successfully!")
  11. end

接下来的事就简单多了,每次需要打包的时候,只要执行如下的命令即可:

  1. fastlane do_package_apk project:Gengmei version:6.3.0

无论是5个渠道,还是50个渠道,1分钟内全部搞定,非常的方便。

私有AAR发布

随着业务的发展,产品线的增加,我们需要将APP拆分为若干个基础组件和业务组件,以便跨APP使用,并且方便管理维护。每个组件都由一个私有AAR来管理,这些AAR最终会发布到内部的Maven仓库中(我们使用Sonatype Nexus搭建)。对于这些AAR,一般我们团队内部的原则是:谁制作,谁管理,谁发布,AAR的负责人我们内部称之为库管,这件事也就分担到了每个库管身上,库管发布一个AAR的流程大约如下:

  1. 执行Git Pull命令,拉最新的代码到本地
  2. 增加一下库的版本号
  3. 执行./gradlew clean命令清理环境
  4. 执行./gradlew assembleRelease打包Release版本
  5. 执行./gradlew upload(自定义的Gradle命令)将AAR上传到私有Maven仓库
  6. 由于修改了版本号,所以需要将代码Commit和Push一下
  7. 打一个Git Tag
  8. 将Tag Push到远端

从本质上来看这件事和iOS端使用Cocoapods来发布一个私有pod库的过程基本一致,当然也面临着和iOS同样的问题:如果库不多并且库的更新频率较低的时候,每次手动来处理还好。但是当库逐渐增多的时候这件事就变得相当麻烦,尤其是当顶层的库依赖底层库的时候,那么升级一个库,影响面将远远超过其本身,通过人工的方式处理的话,整个过程会变得相当痛苦。

所以针对以上这个场景,我们同样可以使用Fastlane来解决,Lane具体内容如下:

  1. desc "Release a new version to the Gengmei Maven Repo"
  2. lane :do_release_lib do |options|
  3. project = options[:project]
  4. target_version = options[:version]
  5. release_notes = options[:release_notes]
  6. hipchat(message: "Start release aar #{project} at version #{target_version}")
  7. hipchat(message: release_notes)
  8. git_pull
  9. update_gradle_version(version: target_version)
  10. gradle(task: "upload") # 包含clean,release命令
  11. git_commit_all(message: "Bump version to #{target_version}") # 提交版本号修改
  12. add_git_tag(tag: target_version, message: release_notes || "Bump version to #{target_version}") # 设置 tag
  13. push_to_git_remote # 推送到 git 仓库
  14. hipchat(message: "Release aar #{project} successfully!")
  15. end

这样,每次发布一个AAR的时候,我们只需要执行一个命令就能完成:

  1. fastlane do_release_lib project:GMAlbum version:0.3.0 release_notes:增加xxx功能

以上的两个场景如果结合诸如Jenkins,Circle等CI系统的话(我们使用的是内部开发的Jaguar系统)的话效果会更好。这样每次动动鼠标,点击一个按钮,然后泡个咖啡回来整个流程就能自动跑完了,相当的惬意。

注意事项

当在一个Andriod项目下使用Fastlane的时候,需要先初始化,执行如下的命令:

  1. fastlane init

Fastlane会自动检测到当前项目为Andriod平台,然后会引导你填写一些和项目以及Google Play相关的信息,需要注意的是:对于国内开发者来说,由于基本不会考虑Google Play,所以这些信息可以快速跳过:

  1. Do you have everything commited in version control? If not please do so now!(是否已经将所有内容提交到版本控制了,如果没有尽快完成),选择Y
  2. Package Name (com.krausefx.app)(输入包名):输入你项目的包名即可
  3. Do you plan on uploading metadata, screenshots and builds to Google Play using fastlane?(是否上传Meta信息,截屏等到Google Play),选择N

然后Fastlane会在你的项目下创建一个fastlane目录,里面包含Appfile和Fastfile,以及actions目录,对于我们来说基本上只需要关注FastFile文件即可。这些内容在Fastlane系列的第一篇文章中有详细的讲解,不太清楚的同学可以先看一下:Fastlane实战(一):移动开发自动化之道

结语

虽然Fastlane本身对Andriod平台的支持并不全面,但是得益于Fastlane本身灵活的架构和扩展性,我们还是可以发挥自己的想象力,将一切流程化,重复性的工作交给其处理,从而节约宝贵的时间。

更为详细的内容,大家可以参考Fastlane给出的Andriod相关的官方文档:https://docs.fastlane.tools/getting-started/android/setup/

下一篇文章,我将从移动端自动化测试的角度,详细介绍一下Fastlane如何发挥作用。

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注