《云栖TechDay》第9期:移动时代的自动化测试

简介: 在4月9日的云栖TechDay活动上,徐达峰为大家分享了移动时代的自动化。达峰分享了支付宝团队自主研发的“Macaca自动化测试方案”,主要介绍如何覆盖业务、跨平台支持,如何玩转持续集成测试等,把积累的实战经验及目前对于移动领域测试的一些想法与大家交流。

49日的云栖TechDay活动上,徐达峰为大家分享了移动时代的自动化。

达峰分享了支付宝团队自主研发的“Macaca自动化测试方案”,主要介绍如何覆盖业务、跨平台支持,如何玩转持续集成测试等,把积累的实战经验及目前对于移动领域测试的一些想法与大家交流。

 

下面是现场速记内容整理。

 

 


移动互联时代的挑战

 

  • web演进速度越来越快,web端构建和工程化的速度也越来越快
  • 软件的版本分化越来越频繁
  • 场景越来越多且愈发复杂

怎么理解这个问题呢?

 

端在变革,每当一个交互方式出现时,新的入口往往随之诞生。目前来看,云的边界已经愈发清晰,端也越来越多元化,在未来,手机未必是主流设备,入口可能会在手表或者眼镜上和更充满想象的穿戴上。混合式的技术选型来为业务提供支撑。同时要注意的是,我们既要迎合技术栈的更新频率,又要迎合市场。

 


为什么要做自动化测试呢?

 

我们的测试方案和手段被透明化了。当一个APP的测试工程师不再接触这个业务时,如果你有自动化的方案,那么,所有的智慧或者解决问题的办法是可以被沉淀下来的。而且,做人工测试的时候,别人并不知道你的思路、手段,当自动化后,就变得公开透明了,会降低其他人再来接受这个业务测试的成本,而且我们可以保持、复用、甚至将它模块化或者数据驱动起来,这样可以更方便、更低成本的对产品质量做高质的覆盖。

   

自动化测试还在做一些靠人工没法完成的事情。如APP耗电量、性能、内存占用,我们可以通过自动化测试(耐久性测试、性能基准测试等)中了解,所以说自动化是专项测试的驱动器。

 


自动化的本质


自动化的本质是软件开发。首先面对的困难是版本差异,市面上安卓、iOS有多个SDK版本共存,操作系统的版本也不统一,软件包、WEB容器、APP自身都会有多个版本。其次,环境和配制差异也是要面对的,例如开发环境、测试环境、计算测试环境、Beta环境、灰度测试环境等。

 

c37abd136611b71e6fe106d8750f95e6254904dc

 

我们需要一个闭环的、长效的质量保障。首先在研发阶段,它就可以通过自动化测试提供的工具覆盖产品,给产品写一些自动化脚本。接下来在持续集成阶段保证产品。当产品被释出去后的用户用环境是最至关重要的,需要有一个质量监控机制,可以及时发现产品中的质量问题,如果有需要可以做用户验收测试。

 

Macaca


402dd87b9858dde1b561788da8cfdee1bc9f8204

Macaca概念模块

Macaca方案的理论基础是W3标准中的webderiver协议标准,把各种设备先通过这个协议标准抽象成一个常规浏览器。Nodejs是首要技术选型,它是跨平台的Web实时应用首选,事件驱动与非阻塞 I/O 模型使其轻量、高效,它繁荣和极速膨胀的生态也是非常庞大的。Macaca在使用者端会提供本地命令行工具和Web操作平台。

   

69bb37dcb2e2735dd7eb20c512d05f8f75e10995

Macaca-client结构图

Macaca-client提供一体化的测试体验,还有可定制化和可扩展的API,面对不同的APP会有业务层面的分装,针对不同的APP会有可定制化的功能,并且零配置以降低大家使用成本。  

 

接下来要做数据集成,可以有多个结点扩展。为什么要自建CI呢?在建CI的时候参考了一些很优秀的CI系统,如Gitlab-CIJnekins-CITravis-CI,考虑到master有一定的适配成本,所以自建CI系统。它有什么功能呢?支持并发任务,同时还可以管理多节点,还会带Web平台集成,还有数据沉淀甚至生成月质量报表,为了便于传播和开发,Docker部署这样的一个系统。


7b563e1db7129646ca3ad0eae990dd50fd4c0bcd

最初的时候它就是一个单节点的master机器。比较重要的是实现进程控制、处理数据存档、实现任务调度。例如,当得知某些slave的内存用量和CPU使用率的时候,就可以占用一些比较空闲的、比较优质的slave资源来运行任务。slave能做什么呢?slave端本身是做配置管理的功能,把它当成模块集成进slave里,同时它还要集成测试框架,这就意味着我们每一个人的PC电脑都是一台slave,只不过现在有专门的slave服务器在运行而已。最终这个平台可以看到每个任务的通过情况、用力通过的百分比,现在我们可以初步的做一个无人职守的自动化的持续集成系统。

ffb386de0119eaef2ff54895902b6d6267ab0be8


最终的平台框架如图所示,可以看到每个任务的通过情况、用例通过的百分比、slave的负载情况。我们的产品还运行出一些截图,在平台里可以看到我们的测试报告,如果测试报告使用截图功能,就会有大量的截图输出来,这样,我们便可以清晰的看到利用率和通过,如果失败也能排查到问题在哪儿,现在我们正在做一个无人职守的自动化持续集成系统。Macaca的主要模块,客户端的、数据集成的、服务端的模块都已经开源了,其他的团队可以使用这些模块来做一套Macaca的自动化测试方案。就跟大家分享这些吧。

 

 

 


关于分享者

2bef95285256386a22eb4133267f329f2813adca

徐达峰

 

现任蚂蚁金服-国际事业部高级前端开发工程师,多年WEB开发相关工作经验,关注移动端开发和Node.js领域,同时在移动测试工具方面积累了较多经验。

 

现场问题:

 

现场的问题在Macaca的FAQ中都有记录:

 

问题1:Macaca 支持测试用例调试吗?解答:

https://github.com/alibaba/macaca/issues/28


问题2:Macaca在PC端测试的环境问题 解答:https://github.com/alibaba/macaca/issues/8

 

问题3:iOS中模拟器打开了,用例没成功执行 解答:

https://github.com/alibaba/macaca/issues/4

 

问题4:Android SDK版本兼容性引起的异常:

https://github.com/alibaba/macaca/issues/7

目录
相关文章
|
移动开发 Rust 前端开发
前端周刊第二期
前端周刊第二期
|
Web App开发 移动开发 人工智能
前端周刊第一期
前端周刊第一期
|
前端开发 JavaScript API
前端周刊第十期
前端周刊发表每周前端技术相关的大事件、文章教程、一些框架的版本更新、以及代码和工具。每周定期发表,欢迎大家关注、转载。
前端周刊第十期
|
人工智能 前端开发 JavaScript
阿里云开发者DevUP沙龙·成都前端技术沙龙 圆满结束
2020年8月15日下午,在武侯区天府五街菁蓉汇2栋5楼举办了阿里云开发者DevUP沙⻰。 本次活动邀请了阿里巴巴高级前端工程师常艳芳、Web/javaSCript全栈开发者水歌,阿里云高级前端技 术专家杜欢,来和大家分享~~~
1439 0
阿里云开发者DevUP沙龙·成都前端技术沙龙 圆满结束
|
移动开发 小程序 架构师
|
程序员 分布式数据库 Hbase
技术人的灵魂3问,阿里工程师如何解答? | 8月28号栖夜读
今天的首篇文章,讲述了:在业务团队做事的工程师摸爬滚打了一段时间后,一定会有所疑问。团队同学在最初的一段时间都提出这样的疑惑:如何在业务中发现有技术价值的问题?发现问题后如何思考和发起再到解决?最后的技术结果跟业务结果如何衔接?很多时候我们听别人说“思考是不够的/要多思考”,其实都是在说这几点。
3307 0
|
前端开发 关系型数据库 MySQL
手把手教你D2C,走向前端智能化 | 7月31号云栖夜读
今天的首篇文章,讲述了:这几年来 AI 来势汹汹,在部分领域应用也逐渐成熟。前端发展至今,我们也有许多成熟的前端解决方案代码,有大量的设计稿,我们是否能够结合智能化的能力将一个 Design 变成一个 Code (设计转代码,简称 D2C)来提效,让前端从一个资源型的角色中解放出来将精力投入到前端其...
5854 0
|
存储 运维 分布式计算
如何带领团队“攻城略地”?优秀的架构师这样做 | 7月4号云栖夜读
今天的首篇文章,讲述了:架构师是一个既能掌控整体又能洞悉局部瓶颈并依据具体的业务场景给出解决方案的团队领导型人物。看似完美的“人格模型”背后,是艰辛的探索。今天,阿里巴巴技术专家九摩将多年经验,进行系统性地总结,帮助更多架构师在进阶这条路上走得更“顺畅”,姿态更“优雅”。
13184 0
|
Kubernetes 监控 容器
K8s学习进阶月刊第四期 直击 KubeCon 2019 现场
欢迎订阅K8s学习进阶月刊 推荐阅读 分享 KubeCon 2019 (上海)关于 Serverless 及 Knative 相关演讲会议直击 KubeCon 2019 现场,阿里云 Hands-on Workshop 亮点回顾阿里云ACK简介及入门实践Knative 实践:人脸图片识别Windo...
6925 1
|
前端开发 JavaScript 存储
《阿里云前端技术周刊》第十期
作者:@南逸(chuck.ql))校对:@染陌(ranmo.cy)) 知乎:阿里云中台前端/全栈团队专栏Github:阿里云前端技术周刊 给我们投稿:传送门[链接]()参与交流:传送门 前端速报 Jetbrains,发布了2019年开发者报告,可以去看看有多少人跟你习惯一样;了解一下 Ap...
1329 0