python+adb+monkey实现Rom稳定性测试详解


Posted in Python onApril 23, 2020

我为什么做这项工作?

其实这项工作是另一位同事在做,过程中发下了一些问题,但是种种原因log和数据都没有收集到,无法进行分析。然后我就接手了,负责复现她发现的问题并提供log和数据给开发分析。

需要测试的是一个什么样的功能?

需求是这样的:开发在Framework层增加了app应用权限管控(Android11中基本权限、自动以权限、AIDL),服务端可以通过下发指令到手机,控制app可以访问及不能访问的权限。同时安装app也需要对签名做校验。

该如何开始这项工作呢?

不用多言,自动化是必须的,但是如何实施呢? 首先,client端是需要接收指令的,是个指令不能人工操作下发,好在我们有web管理页面,通过按键精灵录屏可实现不停的向

client下发指令(本来想用selenuim,但是时间关系就使用按键精灵吧),这样就解决了后台人工不干预的需求。但是Client端呢?

因为我们做的是app的权限拦截,那就必须有app啊,我们选了30个常用的app和一些测试demo,那么问题来了,这些app的安装卸载总不能手工进行吧。答案是肯定的,可以通过python+adb install/uninstall,进行安装和卸载。安装就不说了,无非就是通过python获取apk路径然后执行adb install 命令。卸载是需要传入包名的,如何获取系统已经安装应用的包名呢? pm list package -3 + awk 命令就可以将apk的包名过滤出来了,然后在使用adb uninstall卸载就行了。到此 apk的安装卸载自动化就完成了,那么新的问题又来了

应用要使用某项权限肯定要先启动啊,如何一一的启动这些app呢?

这里可能会有人想到使用am命令,但问题是am启动应用需要知道MainActivity的名称,虽然通过工具可以一一获取到,但是这项工作未免太耗时。所以这里我们不使用am来启动应用,换成monkey启动应用,这样只需要传入包名即可。

OK,安装卸载、应用启动的思路都有了,下面就需要收集log和数据了,可以使用python函数subprocess.Popen()函数将logcat命令传入(logcat过滤log方法不再详述),这样测试过程就可以一直输入log。因为我复现的是黑屏问题,所以测试过程中还需要收集Cpu和Memory信息,同样的使用python定时执行命令dumpsys meminfo / cpuinfo来获取。

脚本执行结果:

1、第一次执行,在dump的内存信息中发现了 我们的一个本地层进程出现内存泄露,我们怀疑是这个泄露引起的黑屏,我们的开发进行了修改。

2、第二轮测试中,同样的发现了黑屏,但已经不是内存泄露引起的了,而是Binder挂了(我们修改过系统的Binder),而且只有360手机卫士和腾讯手机管家这样的安全应用在设备上长时间运行才会出现这个问题,所以选择什么样的app也需要根据功能和业务而定,不能盲目。

PS:这项测试工作我觉得是个很好的积累,所以就写下来;以后再遇到类似的可以拿出来参考。

补充知识:Shell脚本实战之生成日志文件

1.代码如下

#!/bin/bash
today=$(date +%y%m%d)
#the cause to use the command ls is in that to bulit a new #file,not in that the command ls.
ls /usr/bin -al > $today.log

以上这篇python+adb+monkey实现Rom稳定性测试详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
深入解析Python中的list列表及其切片和迭代操作
Mar 13 Python
Python去除、替换字符串空格的处理方法
Apr 01 Python
基于scrapy的redis安装和配置方法
Jun 13 Python
python dataframe向下向上填充,fillna和ffill的方法
Nov 28 Python
Python 监测文件是否更新的方法
Jun 10 Python
使用Flask-Cache缓存实现给Flask提速的方法详解
Jun 11 Python
详解Python二维数组与三维数组切片的方法
Jul 18 Python
python多进程下的生产者和消费者模型
May 07 Python
使用python编写一个语音朗读闹钟功能的示例代码
Jul 14 Python
Python 中的函数装饰器和闭包详解
Feb 06 Python
pytorch 预训练模型读取修改相关参数的填坑问题
Jun 05 Python
Python函数中apply、map、applymap的区别
Nov 27 Python
通过python调用adb命令对App进行性能测试方式
Apr 23 #Python
python 将视频 通过视频帧转换成时间实例
Apr 23 #Python
Windows下Anaconda和PyCharm的安装与使用详解
Apr 23 #Python
如何实现在jupyter notebook中播放视频(不停地展示图片)
Apr 23 #Python
Django调用百度AI接口实现人脸注册登录代码实例
Apr 23 #Python
Anaconda和ipython环境适配的实现
Apr 22 #Python
Django框架获取form表单数据方式总结
Apr 22 #Python
You might like
坏狼php学习 计数器实例代码
2008/06/15 PHP
zf框架的registry(注册表)使用示例
2014/03/13 PHP
利用Fix Rss Feeds插件修复WordPress的Feed显示错误
2015/12/19 PHP
详谈php静态方法及普通方法的区别
2016/10/04 PHP
php 二维数组时间排序实现代码
2016/11/19 PHP
CSS心形加载的动画源码的实现
2021/03/09 HTML / CSS
JQuery 插件模板 制作jquery插件的朋友可以参考下
2010/03/17 Javascript
js监控IE火狐浏览器关闭、刷新、回退、前进事件
2014/07/23 Javascript
jQuery实现购物车表单自动结算效果实例
2015/08/10 Javascript
Jquery on方法绑定事件后执行多次的解决方法
2016/06/02 Javascript
用JS实现轮播图效果(二)
2016/06/26 Javascript
js实现简单的碰壁反弹效果
2016/08/30 Javascript
hammer.js实现图片手势放大效果
2017/08/29 Javascript
js将当前时间格式化为 年-月-日 时:分:秒的实现代码
2018/01/20 Javascript
js console.log打印对象时属性缺失的解决方法
2019/05/23 Javascript
vue中echarts图表大小适应窗口大小且不需要刷新案例
2020/07/19 Javascript
python获取各操作系统硬件信息的方法
2015/06/03 Python
使用Python读写及压缩和解压缩文件的示例
2016/07/08 Python
matplotlib作图添加表格实例代码
2018/01/23 Python
python爬取淘宝商品详情页数据
2018/02/23 Python
python3用PIL把图片转换为RGB图片的实例
2019/07/04 Python
Python Web版语音合成实例详解
2019/07/16 Python
python3中的eval和exec的区别与联系
2019/10/10 Python
3行Python代码实现图像照片抠图和换底色的方法
2019/10/10 Python
Python实现一个简单的递归下降分析器
2020/08/01 Python
纪伊国屋新加坡网上书店:Kinokuniya新加坡
2017/12/29 全球购物
微软加拿大官方网站:Microsoft Canada
2019/04/28 全球购物
PHP解析URL是哪个函数?怎么用?
2013/05/09 面试题
什么是Deployment descriptors;都有什么类型的部署描述符
2015/07/28 面试题
上海期货面试题
2014/01/31 面试题
linux面试题参考答案(5)
2016/11/05 面试题
《美丽的公鸡》教学反思
2014/02/25 职场文书
安全教育第一课观后感
2015/06/17 职场文书
2015国庆节感想
2015/08/04 职场文书
七年级上册生物的课件
2019/08/07 职场文书
小学四年级作文之最感动的一件事
2019/11/01 职场文书