业务实践分享:美团点评团队云真机平台实践

发布时间:2020-08-10 15:20:20 作者:赵钰莹
来源:ITPUB博客 阅读:138

随着美团点评业务越来越多,研发团队越来越庞大,对测试手机的需求显著增长。这对公司来说是一笔不小的开支,但现有测试手机资源分配不均,利用率也非常有限,导致各个团队开发、测试过程中都很难做到多机型覆盖。怎么样合理、高效利用这些测试手机资源,是摆在我们面前的一道难题。


现有的方案

为了解决这些问题,业内也出现了一些手机管理和在线调试使用的工具或平台,比较常见的有:

其中OpenSTF是开源项目,其他的平台大多也都是基于OpenSTF原理实现的。因此,我们对OpenSTF项目进行了深入研究。

遇到的问题

我们首先按照OpenSTF官方的方案进行了搭建,并进行了小规模的应用,但渐渐的我们发现了它的一些问题:

我们的方案

架构设计

根据业务场景的需要,并吸取了OpenSTF结构优点,我们采用Agent/Server模型的模块化设计方案。下面分别介绍主要模块的功能:

通过模块化设计,项目结构比OpenSTF更加清晰。下面是整个系统的设计图:

业务实践分享:美团点评团队云真机平台实践

架构的优势

Agent模块我们直接复用了OpenSTF的provider大部分功能,包括minicap、minitouch等。在此基础上,我们也扩展了一部分OpenSTF缺失的功能,比如:

在Server模块中,我们引入了动态代理的机制,并且重新开发了Web部分,采用了Vue 2.0 + iView来实现,数据库采用了MySQL。

相比OpenSTF原生架构,总结下来有以下优势:

除了这些基础的功能之外,我们还开发了一些特色的功能,下面我们来详细介绍。

特色功能

与客户端自动化相结合

为了合理、高效利用测试手机资源,我们与客户端自动化进行了结合,主要有两个方面:

业务实践分享:美团点评团队云真机平台实践

预约功能

当一台手机处于繁忙状态时,用户必须要等待手机空闲后才能使用,由于手机空闲时间不确定,就会给用户带来很大的不便。为了解决这个问题,我们开发了手机预约的功能,用户可以预约处于繁忙状态的手机,当手机空闲时,自动帮预约用户占用15分钟,并通过即时通讯工具通知预约人。

画质调节

远程调试平台的核心是实时获取屏幕图像,由于屏幕传输需要比较大的网络带宽,在网络不佳的情况下就会出现卡顿现象。因此,我们针对不同的网络做了一些流畅度的优化,下面来介绍一下其中的细节。

屏幕获取的原理是通过minicap来高速截图,每秒最高可达60张,然后将这些截图显示在Web上。因此,我们考虑从两个方面来优化网络带宽的占用, 第一个是调节截图的质量 ,minicap本身支持调节画质( OpenSTF固定设置了80%的压缩比 ),关键代码如下:




var

 rate =  

Number

(match[

6

])

     if  (rate >  2  && rate <  100 ) {
      log.info(rate)
       if  (rate >  30 ) {
        options.screenJpegQuality =  80
      } else   if  (rate >  15 ) {
        options.screenJpegQuality =  50
      } else  {
        options.screenJpegQuality =  20
      }

      frameProducer.restart()
      framerate = rate
    }

第二个是调节每秒发送的图片张数 ,也就是帧率,我们可以在Agent端控制发送图片的数量,关键代码如下:




# 首先修改帧率发送部分:


function   wsFrameNotifier (frame)   {  
   if  (latesenttime ==   || Date.now()-latesenttime >  1000 /framerate) {  
    latesenttime = Date.now()  
     return  send(frame, {  
      binary:  true   
    })  
  }  
}
# 再加入调整帧率的代码:
case   'rate' :  
   var  rate =  Number(match[ 6 ])  
   if  (rate >  2  && rate <  100 ) {  
    framerate = rate  
  }  
   break

那么,帧率和图片压缩比调节到多少才能满足不同网络环境的需要呢?我们先来看一组数据:

图片压缩比 图片尺寸
100% 69.82KB
80% 46.78KB
50% 41.87KB
20% 37.84KB
10% 35.84KB

表中是使用minicap做的图片压缩实验,从数据中我们可以看到当图片质量降低到80%时图片大小降低比较明显,而图片质量并没有明显的下降。继续降低图片质量,图片大小降低有限。我们再来看另外一组数据:

帧率 图片压缩比 实际流量
60 100% 4.02M/S
60 80% 2.74M/S
60 50% 2.41M/S
30 80% 1.43M/S
30 50% 1.22M/S
30 20% 1.10M/S
15 50% 0.63M/S
15 20% 0.55M/S
15 10% 0.52M/S

表中是各种帧率和压缩比组合产生的实际流量数据。

从数据中我们可以看到最高帧率和压缩比的组合下,流量达到了4M/S,而80%压缩比时流量减小到了2.7M/S,降低非常明显。考虑到实际网络情况,我们将 60帧、80%压缩作为了高画质选项

而图片质量从80%降低到50%时图片大小下降并不明显,此时降低帧率就成了很好的选择。当帧率降低到30帧时流量降低了一半,1.2M/S的流量能够满足大部分网络状况使用,30帧也能保证操作的流畅度,于是 30帧、50%压缩比成为了中画质的选项

低画质主要是为了保证在较差的网络环境能够正常使用,500K/S的流量是红线。我们将 15帧、20%压缩比作为低画质选项 ,此时图片质量和帧率较低,但能够保证基本的使用体验。

业务实践分享:美团点评团队云真机平台实践

除了通过降低图片质量和帧率来减小手机屏幕图像传输的流量外,将图像使用H264等编码压缩成视频传输也是一种有效降低流量的办法,相对于图片,图像的压缩率将会更高,用户的操作体验也会更好。但是图像压缩编码原理比较复杂,相关技术我们还在研究当中。

App Mock

在做App测试过程中经常需要抓包,一般情况下,我们通过修改WiFi的代理然后用抓包工具就可以实现。但是这样做的效率比较低,多个工具切换也非常不便。借助集团的Mock平台,我们开发了一键Mock功能,能够快速完成相应App的Mock操作。带来的好处是我们可以一边操作App,一边查看App发出的请求,大大提高了测试的效率。

业务实践分享:美团点评团队云真机平台实践

App Inspector

App Inspector功能可以让用户在平台上使用真机的同时查看页面控件树及页面元素,并且支持Xpath,更加方便高效的查找页面元素,给UI自动化测试提供了很大便利。

业务实践分享:美团点评团队云真机平台实践

这个功能我们是借助Uiautomator实现的。基本原理是写一个Uiautomator用例,用来获取当前页面的Hierarchy,然后将用例打包成一个JAR放到Agent端。当在Web端触发获取控件树时,Agent将JAR包推送到手机上并运行,此时会在手机端生成一个XML文件。然后再使用cat命令获取XML内容并在前端解析。用例核心代码如下:




public

 


class

 

launch

 

extends

 

UiAutomatorTestCase

 

{


     public   void   testDumpHierarchy ()   throws  UiObjectNotFoundException  {
        File file =  new  File( "/data/local/tmp/local/tmp/uidump.xml" );
        UiDevice uiDevice = getUiDevice();
        String filename =  "uidump.xml" ;
        uiDevice.dumpWindowHierarchy(filename);
    } }

当然,你也可以用adb命令来获取Hierarchy:



adb shell uiautomator 

dump

 /data/

local

/tmp/uidump.xml

但这种方式不能获取动态页面,比如视频播放页面。

数据报表

为了更好的了解平台的运营情况,我们做了详细的数据统计,主要从使用次数、使用时间、设备数量、使用分布等方面进行统计。目前我们管理的手机近300台,平均每个月有超过500名研发人员在使用我们的平台,每天的使用次数达到280次,每天总使用时长超过60小时。

业务实践分享:美团点评团队云真机平台实践

业务实践分享:美团点评团队云真机平台实践

其他小功能

除了以上几个比较大的功能点,我们也做了一些贴心的小功能,比如:检测手机网络是否设置代理、检测手机已安装的应用版本及安装时间、快速安装最新版本的测试包、支持App内的Schema跳转等等。这些小功能为研发人员节省了很多时间,提升了他们的工作效率。

业务实践分享:美团点评团队云真机平台实践 未来规划

iOS手机支持

目前,云真机平台只支持Android手机,对iOS手机的支持正在进行中。我们已经初步完成了主要功能的开发,预计很快上线。

产品优化

我们计划继续扩展产品功能,比如支持Log日志展示和性能数据采集等。目前云真机平台已经在美团点评内部平稳运行超过两年,我们会继续不断迭代版本、打磨产品,提供更好的使用体验。

作者简介

东初,大众点评平台质量工具组负责人。7年互联网行业测试、开发经验,2015年加入原大众点评。先后主导了云真机平台、单元测试平台、web安全实验平台等项目的开发,致力于用工具来提升研发团队的工作效率。

李帅,大众点评高级测试开发工程师。2015年加入原大众点评,主要负责云真机平台的开发以及客户端底层组件的测试。热衷于钻研测试领域的前沿技术,并推动了多项新技术落地。


【本文转载自美团技术团队微信公众号,转载授权可联系原作者】

推荐阅读:
  1. Zabbix + Cloud Alert 实践分享
  2. 美团点评SQL优化工具 SQLAdvisor 安装和使用

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

业务 分享 实践

上一篇:cocos2d-x环境搭建记录

下一篇:python中有哪些拼接字符串的方式

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》