搜文章
推荐 原创 视频 Java开发 iOS开发 前端开发 JavaScript开发 Android开发 PHP开发 数据库 开发工具 Python开发 Kotlin开发 Ruby开发 .NET开发 服务器运维 开放平台 架构师 大数据 云计算 人工智能 开发语言 其它开发
Lambda在线 > fireantzhang > App Bundle 开发流程优化最新指北来啦~~~

App Bundle 开发流程优化最新指北来啦~~~

fireantzhang 2020-07-25
在上次:  一文中我们聊到应用升级使用 App Bundle 进行版本发布后,带来了各种好处,但是对于:开发 --> 测试 --> 版本发布,这个流程做了一定的妥协,就是开发阶段依然是 apk 的出包方式,发版阶段则利用开发的 shell 脚本协助正式包的验证工作。具体详情可查看之前的文章:


虽然这个蹩脚的方案,能满足日常的版本发布节奏,但是长久来看,弊端还是蛮大的,需要发布到 GP 的 aab 包,没有经过测试同学的完整性测试,会存在一定的 BUG 风险。比如之前就踩过坑:在其中一个版本,升级了项目依赖的 gradle 版本,apk 出包一切正常,但是 aab 包则由于新版本的 gradle 生成的清单文件由于路径发生变化,导致替换清单文件第三方登录授权 KEY 的逻辑没生效,从而导致第三方登录模块无法生效,详细情况可见上文:

所以开发过程中,以及发版阶段,测试同学需要对发布的 aab 包能够进行完整性测试;解决这个场景迫在眉睫。

让测试同学能够把 aab 包安装到手机进行测试,有两种可行方案:
  • 第一种是研发帮助测试同学把 aab 包安装到测试机中,不过这种对人员有极强的依赖,所以基本上是还未走完流程就已经被 PASS 掉了;

  • 第二种是借助 CI 自动完成出包,然后测试同学自己把 aab 包安装到测试机中,不需要研发同学参与帮忙;


第二种方案当然是最优解,不过这个方案要落地,有两个需要解决的现实问题:
  • CI 自动出 aab 包之后,由于 fir 并不支持 aab 格式安装包的上传,所以测试同学怎么顺利得从日常开发过程中拿到 aab 包,成了这个方案的第一个拦路虎;

  • 假设我们把第一个拦路虎 Game Over 掉了,面临的第二个难题是:测试同学如何把 aab 包安装到手机中呢?我猜你已经有想法了,还不容易么,把 bundletool 的文档给他们,教教他们怎么用就 OK 了;(只是这很不人性化~~~);


第一个拦路虎其实想解决也挺简单的,那就是想办法让 fir 支持 aab 格式安装包的上传,当然这个得得到 fir 官方的支持才行;这里不得不给 fir 他们点个赞,当时联系上他们的研发负责人之后,进行简单的沟通之后,快速得到了挺感动的答复:他们会尽快在 fir-cli 支持 aab 安装包的上传,虽然中间过程有些小波折,但最终结果是很完美的(给你们点赞):
fir-cli 更新日志:(2.0.2) 有限支持 aab 文件上传, 强依赖 bundletool 工具, 具体请参见参数 --bundletool_jar_path--auto_download_bundletool_jar


方便拿包的问题得到解决,接下来就是要解决怎么安装的问题了,当然可能也很简单,那就是直接教会测试同学怎么使用 bundletool 命令工具把 aab 包装到手机上即可,不过就是测试同学的电脑需要满足一些环境要求:
  • adb 命令环境;

  • java 命令环境;

  • bundletool 命令环境;

  • 应用的签名信息:签名文件、签名密钥;


这样一样是极其繁琐的,并且有一个致命的问题就是会把应用的签名信息暴露给测试同学,这是难以接受的。

所以当时蹦出的想法是:是否可以直接做一个软件工具,把这些依赖环境打包进软件工具中,测试同学通过软件可以直接选择 aab 包即可自动安装到连接的设备中。

既然想法已有,那接下来的事当然是落地(梦想是要有滴,万一哪天实现了呢),首先软件得是跨平台的开发方案,毕竟想法这么美好,当然少不了其他同学也会用到,比如我们的设计湿同学、产品同学,这么一算下来 Mac、Window 平台全部覆盖到了,一通搜索,最后锁定采用 Electron 进行开发。

经过漫长的胡乱倒腾,过程省略一万字···(毕竟过程不重要,我们要滴是结果),最后得到一个可用的 aab 包安装辅助工具软件:AabInstallHelp,支持双平台出包:Mac、Window。丑媳妇总得见公婆,我们瞅瞅她的真面貌:


软件很简陋(麻雀虽小,五脏俱全),但是足以解决目前 App Bundle 开放流程中面临的困境,操作方式也很简单,支持的功能也是很人性化:
  • 内置了所有依赖环境,无需复杂配置,开箱即用;

  • Mac、Window 双平台;

  • 支持直接拖动 aab 包到指定区域,安装完成自动启动应用;


虽然这个流程优化方案,还有很多瑕疵,比如不支持多设备,安装过程中电脑只能连接一台设备等等缺点,不过也算是能给 App Bundle 的开发流程提供了一种优化思路,最近也是把这个辅助软件开源了一个通用的版本:签名信息内置的是通用的,所以如果想自己公司业务使用的话,可以按着文档操作即可自己完成专属于你们自己业务的辅助软件。

最后感谢你们的阅读,希望能给你的 App Bundle 开发流程带来小小的帮助,也欢迎你们留言区一起交流你们的想法和方案。


点 "在看" 或者 "关注" 是对我的最大的肯定和鼓励。


附上相关地址
[1]  AabInstallHelp 软件地址: https://github.com/fireantzhang/AabInstallHelp
[2]  AppBundleDemo: https://github.com/fireantzhang/AppBundleDemo
[3]  fir-cli: https://github.com/FIRHQ/fir-cli
[4]  bundletool: https://developer.android.com/studio/command-line/bundletool

版权声明:本站内容全部来自于腾讯微信公众号,属第三方自助推荐收录。《App Bundle 开发流程优化最新指北来啦~~~》的版权归原作者「fireantzhang」所有,文章言论观点不代表Lambda在线的观点, Lambda在线不承担任何法律责任。如需删除可联系QQ:516101458

文章来源: 阅读原文

相关阅读

关注fireantzhang微信公众号

fireantzhang微信公众号:fireantzhang

fireantzhang

手机扫描上方二维码即可关注fireantzhang微信公众号

fireantzhang最新文章

精品公众号随机推荐