博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android App性能测试之二:CPU、流量
阅读量:5104 次
发布时间:2019-06-13

本文共 1955 字,大约阅读时间需要 6 分钟。

CPU---监控值的获取方法、脚本实现和数据分析

1、获取CPU状态数据

adb shell dumpsys cpuinfo | findstr packagename

自动化测试脚本见cpustatus.py

数据分析:做曲线图,可看出随着用户使用,CPU使用率逐渐增高,达到40%多,40%多是否是合理的值呢?

     需要取经验值,再测20-30分钟,看CPU使用率是不是恒定的,如果是恒定的,并且这个值又在当前系统支持下的一个合理的范围,那么就是合理的。如果CPU使用率一直上升不下降到80%多,那么这个软件就有问题,应该去找开发人员解决。

 

流量--监控值的获取方法、脚本实现和数据分析

1、获取当前进程ID 指令

adb shell ps | findstr packagename

2、获取进程ID 流量数据

adb shell cat/proc/id/net/dev

 Receive  代表APP接受的数据  Transmit 代表App发出的请求的数据

流量 = Receive + Transmit

lo:代表本地(localhost),不用统计

eth0, eth1:代表有两个网卡,都会有流量的输出,需要统计流量值。

滑动页面,使它有流量消耗,前后流量的差值(两次获取流量数据)就是流量消耗值。

3、代码见traffic.py ,代码有问题,还没解决

电量--监控值的获取方法

 获取电量

adb shell dumpsys battery   (看level值)

首先保证手机是非充电状态

切换非充电状态

adb shell dumpsys battery set status 1

代码power.py

内存--监控值的获取方法

获取内存

adb shell top

VSS - Virtual Set Size  虚拟耗用内存

RSS - Resident Set Size 实际使用物理内存

数据的采集:

adb shell top -d 1  #数据每一秒刷新一次

把数据重定向到meminfo

adb shell top -d 1 > meminfo

#/usr/bin/python#encoding:utf-8import csvimport osimport time

#控制类class Controller(object):    def __init__(self, count):        #定义测试的次数        self.counter = count        #定义收集数据的数组        self.alldata = [("timestamp", "power")]
    #单次测试过程    def testprocess(self):        #执行获取电量的命令        result = os.popen("adb shell dumpsys battery")        #获取电量的level        for line in result:            if "level" in line:                power = line.split(":")[1]
        #获取当前时间        currenttime = self.getCurrentTime()        #将获取到的数据存到数组中        self.alldata.append((currenttime, power))
    #多次测试过程控制    def run(self):        #设置手机进入非充电状态        os.popen("adb shell dumpsys battery set status 1")        while self.counter >0:            self.testprocess()            self.counter = self.counter - 1            #每5秒钟采集一次数据            time.sleep(5)
    #获取当前的时间戳    def getCurrentTime(self):        currentTime = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())        return currentTime
    #数据的存储    def SaveDataToCSV(self):        csvfile = file('meminfo.csv', 'wb')        writer = csv.writer(csvfile)        writer.writerows(self.alldata)        csvfile.close()
if __name__ == "__main__":    controller = Controller(5)    controller.run()    controller.SaveDataToCSV()

转载于:https://www.cnblogs.com/toudoubao/p/6844777.html

你可能感兴趣的文章
Docker 容器的数据管理
查看>>
驱动相关Error
查看>>
补坑:Prufer 编码总结
查看>>
mysql单节点大事务限制是哪个参数_java面试题汇总 转自多处
查看>>
ORACLE- PLSQL 游标的几种使用情况
查看>>
Maven依赖
查看>>
声笔飞码超字模式效率分析
查看>>
元旦快乐(2016-01-01)
查看>>
WCF服务部署到IIS上,然后通过web服务引用方式出现错误的解决办法
查看>>
jq地区联动
查看>>
paip.cache 缓存架构以及性能提升总结
查看>>
Atitit.atiDataStoreService v2 新特性
查看>>
Atitit.在线充值功能的设计
查看>>
解决CListCtrl闪烁及水平滚动条不能跟踪拖动的问题
查看>>
Thinkphp中使用display()方法显示视图模板,使用show()方法是显示文本内容
查看>>
搭建-以外网访问本地主机
查看>>
本地存储(cookie&sessionStorage&localStorage)
查看>>
JavaScript escape encodeURI encodeURIComponent() 函数
查看>>
UtraEdit 支持Lua高亮
查看>>
Javascript语法基础
查看>>