想到平时想用adb 我就忍不住去翻开笔记,脑子记不住,不好使,不知道大家有没有这个想法呢,不管你有没有,反正我有了,ttm,太烦人了,于是乎,我就开始给自己写个需求文档,

这就是我写的,产品需求,合理不,管他合不合理,我看着能舒服就可以,

其实做出来的真实的效果图差很远,待会会给你们展示的,这里我要说的是电量和帧率展示这个版本没有坐进来,没有考虑pass值不存在的情况,因为有些APP或许没有,

既然有了需求,那么开始写代码吧。我选择python3.6.1 (备注:这里不支持python2.7)

下面来展示下代码,先看获取值的代码

import os,time,platform,time
def starttime_app(packagename,packagenameactivicy):#启动耗时
cmd='adb shell am start -W -n %s'%packagenameactivicy
me=os.popen(cmd).read().split('\n')[-7].split(':')#获取启动时间
cmd2='adb shell am force-stop %s'%packagename
os.system(cmd2)
return me
def makesure_system():
if platform.system =='Windows':
find='findstr'
else:
find='grep'
def liulang(packagename):
cmd='adb shell cat /data/system/packages.list | findstr %s'%packagename
cm=os.popen(cmd).read().split()[1]
cmd1='adb shell cat /proc/net/xt_qtaguid/stats | findstr %s'%cm
me1_shou=os.popen(cmd1).read().split()[5]#接受
me2_shou=os.popen(cmd1).read().split()[7]#上传
cmd2='adb shell cat /proc/net/xt_qtaguid/stats | findstr %s'%cm
me1_xia=os.popen(cmd1).read().split()[5]#接受
me2_xia=os.popen(cmd1).read().split()[7]#上传
liulang_sum_1=(int(me1_shou)+int(me2_shou))#过程产生流量计算为执行后的流量-执行前的流量,
liulang_sum_xia=(int(me1_xia)+int(me2_xia))
liulang_sum=int(liulang_sum_xia)-int(liulang_sum_1)
me1=int(me1_xia)-int(me1_shou)
me2=int(me2_xia)-int(me2_shou)
return me1 ,me2,liulang_sum
def caijicpu(packagename):#这里采集的cpu时候可以是执行操作采集 就是-n -d 刷新间隔
cpu='adb shell top -n 1| findstr %s'%packagename
re_cpu=os.popen(cpu).read().split()[2]
return re_cpu
def getnencun(packagename):#Total 的 PSS 信息内存
cpu='adb shell dumpsys meminfo %s'%packagename
re_cpu=os.popen(cpu).read().split()[118]
return re_cpu
def huoqufps(packagename):
cmd ='adb shell dumpsys gfxinfo packagename '#获取fps
def adb_monkey(packagename,s_num,throttle,pct_touch,pct_motion,pct_trackball,pct_nav,pct_syskeys,pct_appswitch,num,logfilepath):
cmden='adb shell monkey -p %s -s %s --throttle %s --pct-touch %s --pct-motion %s --pct-trackball %s --pct-trackball %s --pct-syskeys %s --pct-appswitch %s --ignore-crashes --ignore-timeouts --monitor-native-crashes -v -v -v %s >%s'%(packagename,s_num,throttle,pct_touch,pct_motion,pct_trackball,pct_nav,pct_syskeys,pct_appswitch,num,logfilepath)
os.popen(cmden)
def huoqushebeizhuangtai():
cmd1='adb get-state'
devices_status=os.popen(cmd1).read().split()[0]
return devices_status
if __name__ == '__main__':
print(getnencun('com.tencent.mobileqq'))

目前所有的数据的采集全部使用adb 来采集的,采集后呢,我这里使用了zuilow的分割办法来取值。

from ab_python import starttime_app,adb_monkey,huoqushebeizhuangtai,caijicpu,liulang,getnencun
import tkinter ,threading
from time import sleep
from tkinter import messagebox,ttk
from tkinter import *
from py_excel import qidongceshi,getcpu
def qidongapp():
start_tim=[]
cishu=[]
status_shebei=huoqushebeizhuangtai()
if status_shebei =='device':
packname=baoming_t.get('0.0',END)
acti=activ_t.get('0.0',END)
cish=cishu_ac.get()
if len(acti)<=1 or len(packname)<=1:
messagebox.showinfo('提醒','包命或者包名activity不能为空')
else:
if len(cish)<=1:
messagebox.showinfo('提醒','次数不能为空')
else:
i=0
e1['state']= 'normal'
e1.delete(1.0,tkinter.END)
sum=0
for i in range(int(cish)):
start_time=starttime_app(packagename=packname,packagenameactivicy=acti)
start_tim.append(int(start_time[1])) cishu.append(i)
if start_time is None:
messagebox.showwarning('警告','请检查您输入的包或者包的启动activity')
break
text='第%s次启动时间:%s'%(i+1,start_time[1])
sum+=int(start_time[1])
e1['state']= 'normal'
e1.insert(tkinter.END,text)
e1.insert(tkinter.END,'\n')
e1.see(END)
btn_start['state']= 'disabled'
e1.insert(tkinter.END,('平均用时:%s'%(sum/int(cish))))
qidongceshi(cishu=cishu,start=start_tim)
messagebox.showinfo('提示','测试报告已经生成,请到当前目录查看')
e1['state']= 'disabled'
btn_start['state']= 'normal'
messagebox.showinfo('通知','测试已经完成')
else:
messagebox.showerror('警告','设备连接异常')
def monkey_app():
status_shebei=huoqushebeizhuangtai()
if status_shebei =='device':
try:
packname=baoming_t1.get('0.0',END).split()[0]
zhongzi=zhongzi_t.get('0.0',END).split()[0]
time=time_t.get().split()[0]
touch=touch_t.get('0.0',END).split()[0]
huadong=huadong_t.get('0.0',END).split()[0]
guiji=guiji_t.get('0.0',END).split()[0]
xitong=xitong_t.get('0.0',END).split()[0]
acti=acti_t.get('0.0',END).split()[0]
event=event_t.get('0.0',END).split()[0]
log=log_t.get('0.0',END).split()[0]
danghang=danghang_t.get('0.0',END).split()[0]
if len(packname)<=5:
messagebox.showwarning('提醒','请正确填写包名')
if int(touch)+int(huadong)+int(guiji)+int(danghang)+int(xitong)+int(acti) >100:
messagebox.showerror('提醒','您输入的所有的事件的比例和不能超过100%') # btn_monkey['state']= 'disabled'
adb_monkey(packagename=packname,s_num=zhongzi,throttle=time,pct_touch=touch,pct_motion=huadong,pct_trackball=guiji,pct_nav=danghang,pct_syskeys=xitong,pct_appswitch=acti,num=event,logfilepath=log)
# messagebox.showinfo('通知',('测试完毕,日志存放:%s'%log))
# btn_monkey['state']= 'normal'
except :
messagebox.showwarning('警告','必须填写monkey相关数据') else:
messagebox.showwarning('警告','设备连接异常 请重新连接设备!')
def cpu_app():
status_shebei=huoqushebeizhuangtai()
if status_shebei =='device':
xingneng_bao=xingneng_baoming.get('0.0',END).split()[0]
xing=xing_t.get()
if len(xingneng_bao)<=5:
messagebox.showwarning('警告','请检查您的包名')
cishu_list=[]
cpu_list=[]
rescv_list=[]
send_list=[]
total_list=[]
pass_list=[]
i=0
for i in range(int(xing)):
nen_cun=getnencun(xingneng_bao) rescv,send,liulang_sum=liulang(xingneng_bao)
cpu_caiji=caijicpu(xingneng_bao)
neicun_t['state']= 'normal'
pass_list.append(int(nen_cun))
neicun_t.insert(tkinter.END,('Pass值:%s'%nen_cun))
neicun_t.insert(tkinter.END,'\n')
neicun_t.see(END)
neicun_t['state']= 'disabled'
cpu_t['state']= 'normal'
cpu_list.append(int(cpu_caiji.split('%')[0]))
cpu_t.insert(tkinter.END,('CPU占有率:%s'%cpu_caiji))
cpu_t.insert(tkinter.END,'\n')
cpu_t.see(END)
cpu_t['state']= 'disabled'
liulang_t['state']= 'normal'
total_list.append(int(liulang_sum))
rescv_list.append(int(rescv))
send_list.append(int(send))
liulang_t.insert(tkinter.END,('总流量:%sk,上传流量:%sk,下载流量:%sk'%(liulang_sum,rescv,send)))
liulang_t.insert(tkinter.END,'\n')
liulang_t.see(END)
liulang_t['state']= 'disabled'
xingneng_btn['state']= 'disabled'
i+=1
cishu_list.append(int(i))
getcpu(cishu=cishu_list,start_cpu=cpu_list,recv_list=rescv_list,send_list=send_list,total_list=total_list,Pass_list=pass_list)
xingneng_btn['state']= 'normal'
messagebox.showinfo('提醒','测试完毕,测试报告已经生成!')
else:
messagebox.showwarning('警告','设备连接异常 请重新连接设备!')
def teread():
for i in range(1):
t=threading.Thread(target=cpu_app,args=())
t.start()
def teread_start():
for i in range(1):
t=threading.Thread(target=qidongapp,args=())
t.start()
if __name__ == '__main__':
try:
status_shebei=huoqushebeizhuangtai()
if status_shebei =='device':
root=tkinter.Tk()
root.title('雷子的安卓adb小工具')
# root.geometry("1000x900")
# root.resizable(width=False, height=False)
tkinter.Label(root,text='性能参数展示',fg='red',font=("黑体", 15, "bold"),).grid(row=0,column=3)
cpu_t=tkinter.Text(root,height=5,width=30)
cpu_t.grid(row=1,column=2)
liulang_t=tkinter.Text(root,height=5,width=40)
liulang_t.grid(row=1,column=4)
liulang_t.see(END)
neicun_t=tkinter.Text(root,height=5,width=30)
neicun_t.grid(row=3,column=2)
neicun_t.see(END)
suji_ev=[50,100,150,200,300]#这里还原可以增加可以选择的次数
xing_t=ttk.Combobox(root,values=suji_ev,width=5)
xing_t.current(0)
xing_t.grid(row=1,column=6)
tkinter.Label(root,text='cpu').grid(row=2,column=2)
tkinter.Label(root,text='参数次数').grid(row=1,column=5)
tkinter.Label(root,text='流量').grid(row=2,column=4)
tkinter.Label(root,text='内存').grid(row=6,column=2)
tkinter.Label(root,text='包名:').grid(row=7,column=1)
xingneng_baoming=tkinter.Text(root,height=1,width=30)
xingneng_baoming.grid(row=7,column=2)
xingneng_btn=tkinter.Button(root,text='开始测试',font=("黑体", 15, "bold"),command=teread)
xingneng_btn.grid(row=7,column=3)
tkinter.Label(root,text='启动时间测试',fg='red',height=2,font=("黑体", 15, "bold")).grid(row=8,column=3)
tkinter.Label(root,text='测试包名').grid(row=9,column=1)
baoming_t=tkinter.Text(root,height=1,width=30)
baoming_t.grid(row=9,column=2)
tkinter.Label(root,text='测试包Activity').grid(row=9,column=3)
activ_t=tkinter.Text(root,height=1,width=30)
activ_t.grid(row=9,column=4)
tkinter.Label(root,text='测试次数').grid(row=9,column=5)
num=[10,20,30,50,100]
cishu_ac=ttk.Combobox(root,values=num,state='readonly',width=5)
cishu_ac.current(0)
cishu_ac.grid(row=9,column=6)
tkinter.Label(root,text='启动时间展示').grid(row=10,column=1)
e1 = tkinter.Text(root,width=30,height=10, state="disabled")
e1.grid(row=10,column=2,padx=20,pady=30)
btn_start=tkinter.Button(root,text='测试',font=("黑体", 15, "bold"),command=teread_start)
btn_start.grid(row=10,column=3)
tkinter.Label(root,text='Monkey 测试',fg='red',font=("黑体", 15, "bold")).grid(row=11,column=3)
tkinter.Label(root,text='测试包名:').grid(row=12,column=1)
baoming_t1=tkinter.Text(root,height=1,width=30)
baoming_t1.insert('0.0',0)
baoming_t1.grid(row=12,column=2)
tkinter.Label(root,text='随机种子数:').grid(row=12,column=3)
zhongzi_t=tkinter.Text(root,height=1,width=30)
zhongzi_t.grid(row=12,column=4)
zhongzi_t.insert('0.0',0)
tkinter.Label(root,text='时间间隔:').grid(row=12,column=5)
suji_event=[500,1000,1500,2000,3000]
time_t=ttk.Combobox(root,values=suji_event,width=5)
time_t.current(0)
time_t.grid(row=12,column=6)
tkinter.Label(root,text='导航事件百分比:').grid(row=13,column=1)
danghang_t=tkinter.Text(root,height=1,width=30)
danghang_t.insert('0.0',0)
danghang_t.grid(row=13,column=2)
tkinter.Label(root,text='触摸事件百分比:').grid(row=13,column=3)
touch_t=tkinter.Text(root,height=1,width=30)
touch_t.grid(row=13,column=4)
touch_t.insert('0.0',0)
tkinter.Label(root,text='滑动事件百分比:').grid(row=14,column=1)
huadong_t=tkinter.Text(root,height=1,width=30)
huadong_t.grid(row=14,column=2)
huadong_t.insert('0.0',0)
tkinter.Label(root,text='轨迹球事件百分比:').grid(row=14,column=3)
guiji_t=tkinter.Text(root,height=1,width=30)
guiji_t.grid(row=14,column=4)
guiji_t.insert('0.0',0)
tkinter.Label(root,text='系统按键百分比:').grid(row=15,column=1)
xitong_t=tkinter.Text(root,height=1,width=30)
xitong_t.grid(row=15,column=2)
xitong_t.insert('0.0',0)
tkinter.Label(root,text='activity之间的切换百分比:').grid(row=15,column=3)
acti_t=tkinter.Text(root,height=1,width=30)
acti_t.grid(row=15,column=4)
acti_t.insert('0.0',0)
tkinter.Label(root,text='事件量:').grid(row=16,column=1)
event_t=tkinter.Text(root,height=1,width=30)
event_t.insert('0.0',0)
event_t.grid(row=16,column=2)
tkinter.Label(root,text='日志存放路径:').grid(row=16,column=3)
log_t=tkinter.Text(root,height=1,width=30)
log_t.grid(row=16,column=4)
log_t.insert('0.0','F:\\monekey.txt')
btn_monkey=tkinter.Button(root,text='启动Monkey测试',font=("黑体", 15, "bold"),command=monkey_app)
btn_monkey.grid(row=17,column=3)
root.mainloop()
else:
print(status_shebei)
print('设备未连接或者连接异常')
except Exception as e:
print(e)
print('请检查您是否连接设备')

图形界面呢,我使用python原生的tkinter,这里值得是问我,你开线程,开一个开多个行吗,没有问题,可以去修改试试就知道,下面的关于Excel报告的Excel我就不展示了,xlsxwriter库,可以去看看官方很多例子。

展示效果图。

展示测试报告

代码放在GitHub,欢迎star  传送门

辛苦了有心人士可以给下,激励我前进

有疑问可以加我qq:952943386或者我的qq群194704520

个人公众号

python_adb 图形界面获取app测试数据,并展示部分测试报告v1.0版本的更多相关文章

  1. centos7命令行和图形界面的相互切换(附centos7安装配置教程)

    一.最近安装了centos7,发现在命令行和图形界面的相互切换命令上,与centos以往版本有很大不同,先整理如下,加深记忆. 1,centos7默认安装后,跟其他版本一样,启动默认进入图形界面: 2 ...

  2. Linux强大屏幕截图方法,理论能截取任何图形界面,包括登录界面

    众所周知,屏幕截图可以使用“Print Screen”按键,但是,此按键的响应是靠系统的后台服务实现的,Linux在某些场景下,是不响应此按键的. 这里介绍一种更强大的截图方法,它是靠转储X图形环境的 ...

  3. Android SDK 环境的搭建 --图形界面模式和命令行模式

    Android 开发首先就是要搭建开发环境,没有用过Eclipse(ADT)开发过,直接用的Android Studio,其中最主要的就是 Android SDK的安装和搭建,所以这里只是总结下And ...

  4. python在linux制作图形界面(snack)

    snack是一个用于在linux制作图形界面(GUI)的模块,该模块由c编写,而且redhat的系统都自带这个模块. 1.获取模块 虽然redhat系统会自带这个模块,但是直接去import snac ...

  5. 使用xml及java代码混合的方式来设置图形界面

    参考<疯狂android讲义>第2版2.1节 设置android的图形界面有三种方法: 1.使用纯xml文件 2.使用纯java,代码臃肿复杂,不建议使用 3.使用xml与java混合,前 ...

  6. Quartz(GUI)图形界面程序----Quartz Web

    下载.设置和运行Quartz(GUI)图形界面程序----Quartz Web 一.获取Quartz Web程序(Quartz GUI).早期的 Quartz 框架开发者意识到一个 GUI 对于某类用 ...

  7. [自制操作系统] BMP格式文件读取&图形界面系统框架/应用接口设计

    本文将介绍在本人JOS中实现的简单图形界面应用程序接口,应用程序启动器,以及一些利用了图形界面的示例应用程序. 本文主要涉及以下部分: 内核/用户RW/RW调色板framebuffer共享区域 8bi ...

  8. Java第5次实验提纲(Java图形界面编程)

    1. Swing与NetBeans 使用NetBeans编写简单界面.见GUI实验参考文件中的0.第06次实验(图形程序设计.事件处理与Swing).doc 题目1: Swing用户界面组件与事件处理 ...

  9. 获取APP应用的包名信息

    语言: python 3.7 需求:获取APP的包名和程序入口信息,以便在 Appium 脚本中配置 appPackage 和 appActivity 参数. 场景一 资源:已有APP应用的apk安装 ...

随机推荐

  1. 【算法系列学习】HDU 5527 Too Rich贪心

    http://www.cnblogs.com/AOQNRMGYXLMV/p/4934747.html #include<iostream> #include<cstdio> # ...

  2. Linux下安装Oracle的两种方式------有图形界面安装和静默安装

    本文参考文章 http://blog.csdn.net/zonej/article/details/50680857 http://blog.csdn.net/tongzidane/article/d ...

  3. NSString类

    创建一个字符串 ) NSString *s = @"aaaa"; ) NSString *s1=[NSString new]; s1=@"bbb"; )格式化创 ...

  4. win10 64位下装Virtual Box安装Linux(centOS)配置联网

    第一步:安装VritualBox 百度"VritualBox"下载安装即可: 第二步:下载Linux镜像系统并安装 这里写出我参照的博客,很详细,我就不累赘了! 原文地址:http ...

  5. hdu 4552 怪盗基德的挑战书

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4552 思路: 其实可以用KMP+DP解决 我这里给出后缀数组的解题方法 思路: 初始化ans=n(n为 ...

  6. AngularJS的this详解

    [this详解]                   1.谁最终调用函数,this指向谁.             ① this指向的,永远只可能是对象!!!!!!             ② thi ...

  7. IE haslayout

    我们都知道浏览器有bug,而IE的bug似乎比大多数浏览器都多.IE的表现与其他浏览器不同的原因之一就是,显示引擎使用一个称为布局(layout)的内部概念.   因为布局是专门针对显示引擎内部工作方 ...

  8. 【JAVAWEB学习笔记】11_XML&反射

    解析XML总结(SAX.Pull.Dom三种方式) 图一 XML的解析方式 图二 XML的Schema的约束 反射的简单介绍: 反射 1.什么是反射技术? 动态获取指定类以及类中的内容(成员),并运行 ...

  9. 【JAVAWEB学习笔记】24_filter实现自动登录和解决全局的编码问题

    过滤器Filter 学习目标 案例-自动登录 案例-解决全局的编码 一.过滤器Filter 1.filter的简介 filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目标 ...

  10. 12、借助Jacob实现Java打印报表(Excel、Word)

    12.使用Jacob来处理文档 Word或Excel程序是以一种COM组件形式存在的.如果能够在Java中调用相应组件,便能使用它的方法来获取文档中的文本信息.Jacob是一个JAVA到微软的COM接 ...