第一次使用uiautomator2完成测试任务,总结一下遇到的问题及解决方案。
准备测试环境:
1.一部OPPO手机
2.fiddler 抓包工具
3.脚本编程环境:python3+uiautomator2
4.adb
fiddler 抓包工具安装及配置:
我自己电脑中已经安装了一个版本的fiddler,但是不能获取请求的子请求信息(选中某请求右键->Select->Child Request),重新安装版本为5.0.20192.25091的 Progress Telerik Fiddler。正常安装即可,没有特别注意的地方。
1.fiddler 添加查看请求时间信息。将如下代码添加到路径(Rules->Customize..)下文件类 class Handlers 中:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | function BeginRequestTime(oS: Session) { if (oS.Timers ! = null) { return oS.Timers.ClientBeginRequest.ToString(); } return String.Empty; } public static BindUIColumn( "Time Taken" ) function CalcTimingCol(oS: Session){ var sResult = String.Empty; if ((oS.Timers.ServerDoneResponse > oS.Timers.ClientDoneRequest)) { sResult = (oS.Timers.ServerDoneResponse - oS.Timers.ClientDoneRequest).ToString(); } return sResult; } public static BindUIColumn( "Time Happen" ) / / tab的名称,自己想改什么就改什么 function RecordTimeBegin(oS: Session){ var sResult = String.Empty; if ((oS.Timers.ServerDoneResponse > oS.Timers.ClientDoneRequest)) { / / sResult = (oS.Timers.ServerDoneResponse - oS.Timers.ClientDoneRequest).ToString(); sResult = oS.Timers.ServerGotRequest.ToString(); } return sResult; } / / 显示每行请求的发起时间:时分秒毫秒 public static BindUIColumn( "BeginTime" , 80 ) function BeginTimingCol(oS: Session){ return oS.Timers.ClientDoneRequest.ToString( "HH:mm:ss.fff" ); } / / 显示每行请求的响应时间:时分秒毫秒 public static BindUIColumn( "EndTime" , 80 ) function EndTimingCol(oS: Session){ return oS.Timers.ServerDoneResponse.ToString( "HH:mm:ss.fff" ); } / / 显示每行请求的服务端耗时时间:时分秒毫秒 public static BindUIColumn( "TimeTaken/ms" , 120 ) function TimeTaken(oS: Session): String{ var sResult = "0" ; / / 获得时间戳的ms值 var t1_ms = oS.Timers.ClientBeginResponse.ToUniversalTime().Millisecond; / / 获得时间戳的minute值 var t1_m = oS.Timers.ClientBeginResponse.ToUniversalTime().Minute; / / 获得时间戳的second值 var t1_s = oS.Timers.ClientBeginResponse.ToUniversalTime().Second; var t1 = t1_m * 60 * 1000 + t1_s * 1000 + t1_ms ; var t2_ms = oS.Timers.ClientDoneRequest.ToUniversalTime().Millisecond; var t2_m = oS.Timers.ClientDoneRequest.ToUniversalTime().Minute; var t2_s = oS.Timers.ClientDoneRequest.ToUniversalTime().Second; var t2 = t2_m * 60 * 1000 + t2_s * 1000 + t2_ms ; if (t1 > = t2){ var t3 = t1 - t2; sResult = t3.toString(); } return sResult; } |
添加后关闭fiddler,重新打开可看见添加内容如下图。
2.fiddler参数配置
配置fiddler允许监听到https(fiddler默认只抓取http格式的)
打开Fiddler菜单项Tools->TelerikFiddler Options->HTTPS,
勾选CaptureHTTPS CONNECTs,点击Actions,
勾选Decrypt HTTPS traffic和Ignore servercertificate errors两项,点击OK(首次点击会弹出是否信任fiddler证书和安全提示,直接点击yes就行),见图:
配置fiddler允许远程连接
上一步窗口中点击Tools->TelerikFiddler Options->Connections,勾选allow remote computers to connect,默认监听端口为8888(下图Fiddler listens on port就是端口号),若端口被占用可以设置成其他的,配置好后要重新启动fiddler,如下图:
手机参数配置:
1.设代理IP,首先要保证手机和电脑都处于同一个网络;
然后要知道电脑的ip地址(当然这个电脑是安装fiddler的电脑),电脑ip地址可通过cmd,输入ipconfig查询,或网络共享中ipv4找到,我的是192.168.11.117,
再者要知道fiddler的端口号,Tools->TelerikFiddler Options->Connections,port中值就是端口号,一般默认为8888;接下来开始操作手机;
2.打开手机的开发者选项和USB调试,路径为:设置-其他设置-开发者选项。
参考文章:https://blog.csdn.net/u010142437/article/details/79700142
adb安装:
电脑之前安装过,这次先不总结,后续添加下载及安装。
自动化脚本编程环境准备:
1.python3.6.8下载及安装(之前安装的)
2.VS code(之前安装的)
3.uiautomator2安装:
直接用命令 python -m pip install --pre uiautomator2 安装即可。
安装完需要对手机初始化,命令 python -m uiautomator2 init.
手机数据线连接电脑后,查看手机序列号,命令为 adb devices,这里需要注意:保证手机开发者选项和USB调试要打开。
4.安装可视化UI查看器weditor:
直接用命令 pip install --pre weditor 安装。
安装后,打开CMD命令框,运行python -m weditor ,该命令会在PC上打开浏览器,之后输入设备的ip或者序列号,点击Connect即可,映射测试机屏幕。看到出现一个小草的图标,就是连接成功了。
参考文章:https://www.cnblogs.com/yoyoketang/p/1120453
5.编写测试代码,笔记简单,如下:
1 |
由于测试环境不稳定,手机连接时常会中断,so把循环测试改到30,之前100、50都跑不完。
https://www.jianshu.com/p/bc061cf222ae Python+uiautomator2登录考研帮
https://www.cnblogs.com/0weibin/p/3900240.html 使用Fiddler关于“由于目标计算机积极拒绝,无法连接。”的解决方案
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步