利用tidevice+mysql+grafana实现ios性能测试

利用tidevice+mysql+grafana实现ios性能测试

1.什么是tidevice?

tidevice是一个可以和ios设备进行通信的工具,提供以下功能:

  • 截图
  • 获取手机信息
  • ipa包的安装和卸载
  • 根据bundleID 启动和停止应用
  • 列出安装应用信息
  • 模拟Xcode运行XCTest,常用的如启动WebDriverAgent测试(此方法不依赖xcodebuild)
  • 获取指定应用性能(CPU,MEM,FPS)
  • 文件操作
  • 其他
    支持运行在Mac,Linux,Windows上
    官方地址:https://github.com/alibaba/taobao-iphone-device

2.环境准备

Python3.6+

Mysql (docker)

grafana(docker)

3.实现思路

  • 使用tidevice选定连接的被测手机和被测app
  • 启动app和程序,将开启app后每秒的设备性能信息采集将采集到的数据存储到mysql
  • grafana设置mysql数据源
  • 配置grafana展示图表
  • 配置展示图表的刷新时间

4.具体步骤

  1. 数据库建立相应的测试库和测试表,主要是我们要收集的fps,cpu,memory,network等4个表,表的结构就是时间戳和相应的数据 比如fps表:
  1. 连接手机,指定要测试的应用(以 fun club为例子)

`

#使用 tidevice applist来查看手机app列表

复制代码
t = tidevice.Device()
perf = tidevice.Performance(t,list(tidevice.DataType))
#print(list(tidevice.DataType))
appid='com.xxx.xxx.xxxxxxx'  #填写自己需要测试的app包名即可
  1. 设定程序的运行时常,启动指定的app,查看回调函数输出的数据格式
  1. 从返回的字典数据里,分别提取对应的cpu,network,memory,fps数据和时间戳,然后插入数据库相对应的表。以fps为例子

    def callback(_type: tidevice.DataType, value: dict):
    print("R:", _type.value, value)
    if _type.value =='fps':
    fpsdata = value
    fps = fpsdata.get('fps')
    time = timeStamp(fpsdata.get('timestamp'))
    db = pymysql.Connect(user='root', password='123456', host='localhost', database='mytest')
    cursor = db.cursor()
    sql="INSERT INTO mytest.my_fps (fps, time)VALUES ('%s', '%s')" %(fps,time)
    try:
    cursor.execute(sql)
    db.commit()
    except:
    db.rollback()
    db.close()

  2. 检查数据库对应的表是否有数据插入(以fps为例)

  1. 启动grafana 设置mysql数据源
  1. Add Panel 选择折线图 进行相关配置,以fps为例
  1. 设置grafana的时间以及定时刷新的频率
  1. 配置好4个图表,grafana设置图标刷新时间为1秒

10.设定好程序运行的时常 启动app 首页静止, 查看折线图

11.funclub进入ludo游戏,查看折线图数据(21:06开始)

12.在对应的时间打标签

我的博客(https://vwo50.club)有分享更多好玩的计算机知识,欢迎访问 vwo50博客站

相关推荐
过期动态27 分钟前
MySQL中的约束
android·java·数据库·spring boot·mysql
曾凡宇先生1 小时前
mysql局域网授权
数据库·mysql
努力努力再努力wz2 小时前
【MySQL 进阶系列】拒绝滥用root:从 mysql.user 到权限校验,带你彻底理解用户管理与授权机制!
android·c语言·开发语言·数据结构·数据库·c++·mysql
Hical_W4 小时前
用 Hical + MySQL 5 分钟搭建 CRUD API(C++20 协程版)
数据库·mysql·c++20
想唱rap4 小时前
传输层协议之UDP
java·linux·网络·c++·网络协议·mysql·udp
MonkeyKing4 小时前
消息发送与转发流程
ios
猪脚踏浪5 小时前
mysql 用户授权
mysql
移动端小伙伴6 小时前
我受够了 Xcode 的 SPM 网络问题,写了个脚本一劳永逸
ios
YaBingSec6 小时前
网络安全靶场WP:Grafana 任意文件读取漏洞(CVE-2021-43798)
android·笔记·安全·web安全·ssh·grafana
努力努力再努力wz7 小时前
【MySQL 进阶系列】C/C++ 如何通过客户端库访问 MySQL?从连接原理到 API 调用流程详解(附完整demo代码)
服务器·c语言·数据结构·数据库·c++·b树·mysql