讲师:潘志刚

声网质量效能部门负责人,超过 14 年服务器、移动终端、音视频编解码以及汽车电子等跨行业从业经历,负责建立测试基础架构和自动化测试方案,主持搭建持续集成测试生态体系。现任声网质量效能部门负责人,负责推进质量和效能持续优化,专注技术创新赋能团队软件保证,通过软件和硬件的高效结合,探索产品交付的最优解决方案。

前言

SDK 测试不同于 APP 测试,不仅要站在终端用户角度考虑问题,还需要站在 APP 开发者的角度考虑问题。面对不同的行业需求,如何保证质量固若金汤,这是一条探索未知的赛道。本期推送将为大家带来声网研发效能负责人潘志刚的《SDK 测试最佳实践——打造质量保证的一体化应用平台》,分享一体化应用平台的演变以及如何整合基础能力,保证测试和交付的高效执行,提升质量效能。

1.0 GUI Driven Test

SDK(软件开发工具包)是声网对外主要的产品交付,是用于为特定软件包、软件框架、硬件平台以及操作系统等创建应用软件的开发应用的集合,跟传统意义上的 APP、外围应用或者最终客户感知到的产物是不一样的,对于最终端用户来说是无形的。

早期为了保障 SDK 测试的质量,测试人员需要根据 SDK 交付的 API 设置 GUI demo。比如在一个实时的互联网通讯界面,需要用户加入到对应频道进行相应的音频和视频通讯,在这样的界面里会设计对应 Button、下拉列表,或者小的图标,每一个对应的元素体现对应接口实现能力。如下图所示,最下面 4 个 Button 分别是麦克风、摄像头、挂机按纽,对应 API 接口 enableLocalAudio、enableLocalVide、startScreenCapture 和 leaveChannel,右上角看到信号条图标是获取 onNetworkQuality 接口。通过这样简单的 Demo,测试人员设计相应的 test case,确保每一个接口可以正常调用,基于此来保证初期迭代里交付的质量标准。

然而随着交付平台越来越多,交付需要基于桌面端、移动端、web 端,桌面端包括 Windows,macOS 和 Linux,移动端包括安卓和 ios,越来越多平台设计相应的 demo 势必需要测试人员投入更多资源,同时 API 在不断增长。因此自动化是必然趋势。

2.0 GUI Demo Test Automation

2.0 阶段是 GUI Demo Test Automation,开发人员将平台进行了分层。

如上图,上面的 iOS、OSX、Android 等是对外交付的平台,下面是对应平台用到的第三方开源工具,如 Appium 和 Selenium,中间这一层做相应分装,其目的在于提高测试效能,用一套 case 覆盖到所有交付的平台。实现 70% 的自动化程度已经能够让团队节约一半的时间,极大地提高了测试效率。

3.0 API Demo Test

3.0 阶段进入到 API Demo Test。声网的测试主体是 SDK,SDK 关注点在于 API 功能实现、平台适配、面向开发者、性能功耗包体积,集成构建打包;而 APP 关注业务功能、用户交互、终端用户、界面操作和程序安装。针对 SDK、APP 两种完全不同的测试重点,声网重新设计了一套针对 SDK 的自动化测试框架——Wayang Testframework。

Wayang 的原理来自印度尼西亚的一种木偶戏,前端是一个木偶,后台表演者通过线和灵巧的手控制前端木偶去做相应的动作。在这样的一个体系里有三个不同的对象,左边的对象是 test client,中间是 test server,右边是对应的 test demo。Test client 相当于木偶戏幕后的表演者,需要明确自己的测试需求是什么,设计相应的 test case;test demo 相当于前端的木偶,会根据测试端发出持续请求做相应行为调用。所有的主动调用以及被动调用都是基于代码输出。在整个体系里面所有的接口调用和相应回调都是基于代码终端的输出,无需关心界面的实现。和自动化 2.0 与手工 1.0 相比,目前每天可以完成一百个以上 API 测试,自动化测试覆盖率能够超过 80%。

4.0 AIO

在完成 Wayang 实践后,声网仍在思考是否能够有进一步的优化实践。随着产品交付迭代周期越来越紧,以及更多的需求介入,从测试角度来说,光考虑测试环节是不够的,需要把整个产品交付纳入思考范围之内——包括前期构建、打包、测试、交付。因此,这里引入了 AIO 的理念。

AIO 是箱庭和沙盒的结合。那么,什么是箱庭和沙盒呢?箱庭能够提供基础设施,相当于游戏里提供相应的陷阱、敌人或者宝箱,如何去获取或者击败由自己决定。而沙盒意味着把最小的原子单位开放给用户,典型例子有我的世界、乐高,最小单位就是一个 cube。声网的测试单位是基于 API,那么在整个交付里面,箱庭对应着保证基础设施(e.g:网络、电源,测试环境)稳定运行,至于沙盒则会拆分构建、测试、上线发布三个版块。

在声网一体化 AIO 架构里面,包含了一系列相应的 module。

AIO 架构包括了设备集群。因为不同平台交付必然覆盖各种各样的情况,需要考虑到不同设备的兼容性。调度中心确保所有设备在预期设定中如期交付,因此需要服务网关的存在。数据中心会分析 SDK 产物明确的 log 输出;最后一块是构建发布,ACCS 平台包括编译、发布、崩溃上报、数据分析、自动化测试等功能模块。下面基础能力代表着更底层的元素,如链路模拟、物理连接控制、人机交互等。

回到刚才所说的 Wayang 的特性,需要有一个 client 对应一个 demo。Client 表演者知道需要做什么,然后让 demo 去做相应的事情。基于这个情况,声网做了进一步的提升。通过 API driven test,声网设立了一个独立的 soloWayang app,里面的 test iterator 生成器可以不停地把测试 API 持续调用。通过基于 test farm 并发测试,在所有设备上跑 soloWayang,所有相应的 API 都会被测试以确保发现和处理问题。

在测试环节里面,会有非常多数据产生,包括 SDK data、demo data、test data 和 server data。如何去将这些数据做合理有效的预先挖掘?

传统模式下,数据的价值在于出现问题后去分析数据。逆转一下思维的话,如果能够对数据进行提前收集和预分析,就可以在问题暴露之前主动地去发现和解决风险。声网数据分析平台通过 Beats、Logstash 对不同平台的数据进行清洗,将无效信息剔除。Kibana 通过相应的过滤,能够把相应问题列举出来。举个例子,某个晚上跑了四百台设备,发现某台设备出现对应的 log 异常,通过 Kibana 可以进行预警,及时发现这个问题是否真的只有一台设备存在,或者在数台机器里都存在共性。以前通过人工的方式去挖掘几台设备的数据是否有相应的问题,很难联想到是不是与某一个系统有关、与某一个芯片有关,还是跟某一个特定的网络场景有关。通过数据分析平台的合理过滤,能够帮助我们通过种种证据的汇总来有效发现问题,尽早解决问题。

Q:针对于手机 APP 去做测试,如果需要上百部手机同时连起来,做一个性能测试环境。但一台电脑的支持能力是有限的,可能同时连接十几台手机就达到极限了,怎么去做横向扩展做性能环境?

A:如果是针对安卓手机的话, 我们有一台早期的节点同时连接了 30 台安卓设备证明是可行的,建议再确定一下节点和外设的配置。更多的机器连接可以通过采用集群的方式来部署 test farm。另外,可以在相应的 test app 应用中设计独立的性能测试组件,有利于实现性能测试的横向扩展。

点击获取视频和 PPT 资料

CODING DevOps 线下沙龙回顾二:SDK 测试最佳实践的更多相关文章

  1. CODING DevOps 线下沙龙回顾一:DevOps 代码质量实战

    11 月 22 日,由 CODING 主办的 DevOps 技术沙龙系列「质量」专场在上海圆满结束.在活动现场,四位来自腾讯等知名企业的技术大咖们分享了研发质量与效能的实战经验,与观众们共同探讨如何采 ...

  2. 2021年首届.NET线下沙龙上海站 - 2021 .NET Meetup in Shanghai

    .NET Conf 2020 刚刚在苏州落下帷幕, .NET 开发者们的热情不减,来自五湖四海的朋友一起参加疫情之下的 .NET 盛会. 2021年上海第一场线下活动就要来了,快来加入我们一起学习.N ...

  3. 腾讯WeTest&TesterHome深圳线下沙龙

    腾讯官方的一站式品质开放平台「腾讯WeTest」携手知名测试社区「TesterHome」以及3家金融相关企业为我们带来的金融专场. 本次活动内容主要以金融公司的测试落地和测试技术为主,我们希望你是一个 ...

  4. CODING 携手优普丰,道器合璧打造敏捷最佳实践

    随着全球进入到信息化时代,越来越多的企业迫切地寻求新的商业模式,要求迭代.探索.不断加速创新以响应快速变化的市场.如今一系列新兴概念如敏捷开发.极限编程.微服务.自动化.DevOps 等大行其道,然而 ...

  5. Google Developing for Android 二 - Memory 最佳实践 // lightSky‘Blog

    Google Developing for Android 二 - Memory 最佳实践   |   分类于 Android最佳实践 原文:Developing for Android, II Th ...

  6. 《DevOps故障排除:Linux服务器运维最佳实践》读书笔记

    首先,这本书是Linux.CN赠送的,多谢啦~ http://linux.cn/thread-12733-1-1.html http://linux.cn/thread-12754-1-1.html ...

  7. 技术沙龙|京东云区块链进校园-京东云&深圳大学线下沙龙分享回顾

    在刚刚结束的京东云&深圳大学技术沙龙活动中,多位京东云的技术大咖针对京东云BDS产品技术细节.开源计划,与深圳大学的同学和参会者进行了深入探讨,干货满满反响深刻,获得了在场同学与参会者的一致好 ...

  8. 你在为谁工作——IT帮深圳分站2019年3月线下活动回顾

    对于工作,在每个人的心中,它所占的份量都是不一样的.有的人活着是为了工作,有的人工作是为了更好的生活. 在3月24日下午,北京.上海与深圳三地我们同步举办了关于工作这个话题的沙龙活动. 我们深圳分站参 ...

  9. [转]DevOps实战:百度持续交付体系与最佳实践大解密!

    本文转自:http://dbaplus.cn/news-21-471-1.html “互联网+”时代,软件产品要想满足快速增长的用户需求,高效.快速的迭代转型必不可少,面对时刻发生改变的互联网及业务模 ...

随机推荐

  1. python3 Redis未授权检测脚本

    `import sys import getopt import socket def get_target(): opts, args = getopt.getopt(sys.argv[1:], ' ...

  2. IDEA连接码云

    IDEA连接码云: 1.安装Gitee插件 2.下载git.exe https://git-scm.com/download/win 3.安装git 如果是Win10专业版,可能会出错,GitBash ...

  3. Linux如何安装Docker?

    使用yum安装(centos7) Docker要求Centos系统的内核版本高于3.10,安装Docker前需要验证你的服务器内核版本是否支持Docker. 通过 uname -r 命令来查看你的服务 ...

  4. Jmeter(三十) - 从入门到精通 - Jmeter Http协议录制脚本工具-Badboy3(详解教程)

    1.简介 Badboy为方便自动化数据灵活性,以及脚本的重用,减少工作量:为此提供了脚本参数化的功能,这一篇文章宏哥以度娘搜索的关键字"北京-宏哥"进行参数化为例,宏哥带领你们实战 ...

  5. 六. Vue CLI详解

    1. Vue CLI理解 1.1 什么是Vue CLI 如果你只是简单写几个Vue的Demo程序, 那么你不需要Vue CLI,如果你在开发大型项目那么你需要它, 并且必然需要使用Vue CLI. 使 ...

  6. Django 的F查询与Q查询,事物

           F查询 Django 提供 F() 来做这样的比较.F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值 示例1: 查询出卖出数大于库存数的商品 from ...

  7. Spring Boot 项目瘦身指南,瘦到不可思议!129M->1.3M

    之前在 从使用传统Web框架到切换到Spring Boot后的总结 中提到关于 Spring Boot 编译打包,Spring Boot 应用程序不用额外部署到外部容器中,可以直接通过 Maven 命 ...

  8. PyQt(Python+Qt)学习随笔:利用QWidget部件的palette以及ColorGroup、colorRole局部调整部件的特定范围颜色

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 在<PyQt(Python+Qt)学习随笔:QWidget部件的 ...

  9. Windows下MySQL无法启动万能解决方案

    MySQL启动报错 window10上安装了MySQL之前使用都是执行net start mysql 启动,执行net stop mysql关闭. 某天开始启动报错"MySQL 服务无法启动 ...

  10. 关于大视频video播放的问题以及解决方案(m3u8的播放)

    在HTML5里,提供了<video>标签,可以直接播放视频,video的使用很简单: <video width="320" height="240&qu ...