一、背景和目的:
由于目前App前端业务测试很少关注后端网络接口的异常情况,客户端QA在项目测试时往往局限于关注测试功能,导致测试粒度较粗。即使按照CheckList过功能点,客户端QA对后端接口的覆盖情况也很难做到明确把握。
Fiddler是我们在客户端测试时使用比较普遍的工具,常用于HTTP抓包、构造请求等等。原生的fiddler插件,缺乏对包大小,网络请求时 长、接口访问频次、接口覆盖度等维度进行网络请求的分析,同时提供网速控制的功能,下文介绍开发定制fiddler插件辅助app业务测试。
二、工具实现原理
首先了解一下fiddler的实现http代理请求的原理,方便我们深入的研究。Fiddler实现的原理是截获了windows的winnet接口,在 转发服务器请求和响应的阶段,可以hook住传递的参数,达到监控甚至修改网络数据包的能力。如下图所示,fiddler提供了4个接 口,AutotamperRequestBefore,AutotamperRequestAfter,AutotamperResponseBefore,AutotamperResponseAfter。
我们在自己插件中实现这四个方法即可满足我们自己的测试需求。在我遇到的项目中,我们实现了以下功能。
1、 发现网络请求包的异常问题,例如,接口数据包大小过大,帮助分析接口是否存在冗余数据,从而节省用户使用app的网络流量负担。
2、 发现网络请求时间超时异常问题,例如,发现接口访问时间过大,帮助发现后端潜在的逻辑错误。
3、 发现网络请求访问频次异常问题,例如,app页面缓存机制是否正常;接口是否因为发送时机不对导致频繁发送。
4、业务测试可以分析接口覆盖度,指导后续测试重点,使测试点更完整,避免漏测。
5、修改请求响应延迟,模拟各种网速,如2,3g网络,断网等情况,方便测试各种网络异常case。
程序示例如下:
三、工具的主要功能:
包大小分析:
Packet Size tab 显示根据host.ini中配置的host过滤结果,按照请求的包的大小进行降序排列;用于分析异常的网络请求数据包。
Reset按钮前面的两个数字分别对应测试过程中,请求的总流量和总耗时;
过滤之后的URL按照请求耗时的降序排列,请求耗时为ClientBeginRequest与ClientDoneResponse之间的时间差值。根据网络请求耗时,判断异常请求。