python_adb 图形界面获取app测试数据,并展示部分测试报告v1.0版本
想到平时想用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版本的更多相关文章
- centos7命令行和图形界面的相互切换(附centos7安装配置教程)
一.最近安装了centos7,发现在命令行和图形界面的相互切换命令上,与centos以往版本有很大不同,先整理如下,加深记忆. 1,centos7默认安装后,跟其他版本一样,启动默认进入图形界面: 2 ...
- Linux强大屏幕截图方法,理论能截取任何图形界面,包括登录界面
众所周知,屏幕截图可以使用“Print Screen”按键,但是,此按键的响应是靠系统的后台服务实现的,Linux在某些场景下,是不响应此按键的. 这里介绍一种更强大的截图方法,它是靠转储X图形环境的 ...
- Android SDK 环境的搭建 --图形界面模式和命令行模式
Android 开发首先就是要搭建开发环境,没有用过Eclipse(ADT)开发过,直接用的Android Studio,其中最主要的就是 Android SDK的安装和搭建,所以这里只是总结下And ...
- python在linux制作图形界面(snack)
snack是一个用于在linux制作图形界面(GUI)的模块,该模块由c编写,而且redhat的系统都自带这个模块. 1.获取模块 虽然redhat系统会自带这个模块,但是直接去import snac ...
- 使用xml及java代码混合的方式来设置图形界面
参考<疯狂android讲义>第2版2.1节 设置android的图形界面有三种方法: 1.使用纯xml文件 2.使用纯java,代码臃肿复杂,不建议使用 3.使用xml与java混合,前 ...
- Quartz(GUI)图形界面程序----Quartz Web
下载.设置和运行Quartz(GUI)图形界面程序----Quartz Web 一.获取Quartz Web程序(Quartz GUI).早期的 Quartz 框架开发者意识到一个 GUI 对于某类用 ...
- [自制操作系统] BMP格式文件读取&图形界面系统框架/应用接口设计
本文将介绍在本人JOS中实现的简单图形界面应用程序接口,应用程序启动器,以及一些利用了图形界面的示例应用程序. 本文主要涉及以下部分: 内核/用户RW/RW调色板framebuffer共享区域 8bi ...
- Java第5次实验提纲(Java图形界面编程)
1. Swing与NetBeans 使用NetBeans编写简单界面.见GUI实验参考文件中的0.第06次实验(图形程序设计.事件处理与Swing).doc 题目1: Swing用户界面组件与事件处理 ...
- 获取APP应用的包名信息
语言: python 3.7 需求:获取APP的包名和程序入口信息,以便在 Appium 脚本中配置 appPackage 和 appActivity 参数. 场景一 资源:已有APP应用的apk安装 ...
随机推荐
- Vmware Vsphere WebService之vijava 开发一-vcenter连接、及集群信息获取
开始是通过java代码调用vsphere提供的原始接口,从而控制vcenter的操作.当第一个版本做完之后发现代码执行的速度特别慢,后来在网上看到有人用vijava(对vsphere原始接口封装)编程 ...
- sass入门学习篇(一)
先简单的介绍一下sass,如果你了解less,sass就没什么太大问题 Sass 是对 CSS 的扩展,让 CSS 语言更强大.优雅. 它允许你使用变量.嵌套规则. mixins.导入等众多功能, 并 ...
- Mobile game analysis
Let's take a look at a very popular mobile game "Garena 传说对决" . It would be very interesti ...
- 使用 PHPStorm + Xdebug 实现断点调试(二)
一.配置 Xdebug 配置 Xdebug 相关参数,在 php.ini 文件中新增如下配置,如果没安装的,请参考<PHP 安装 Xdebug扩展>: [xdebug] xdebug.re ...
- 【外文翻译】使用Timer类去调度任务 ——java
使用Timer类去调度任务 --java 原文地址:https://dzone.com/articles/using-timer-class-to-schedule-tasks 原文作者:Jay Sr ...
- CF798 C. Mike and gcd problem
/* CF798 C. Mike and gcd problem http://codeforces.com/contest/798/problem/C 数论 贪心 题意:如果一个数列的gcd值大于1 ...
- express4.x的使用
①.安装 npm install -g express ②.创建应用 express [目录] 会在目录下生成 node_modules, 存放所有的项目依赖库.(每个项目管理自己的依赖,与Ma ...
- 通过Servlet实现汉字验证码
package com; import java.awt.Color;import java.awt.Font;import java.awt.Graphics;import java.awt.Gra ...
- 微信小程序,前端大梦想(六)
微信小程序,前端大梦想(六) 微信小程序之联合百度API实现定位 定位功能对于我们都不陌生,在移动端的应用中更是不可或缺的功能,小程序中也提供了对应的API帮助我们完成定位的实现,但是目前小程序的定位 ...
- 路由-when-resolve
文件列表:luyou.html,app.js,home.html,user.html,wy.json luyou.html <!DOCTYPE html> <html ng-app= ...