(图片来源网络,侵删)
Hi,大家好。APP网络环境比较复杂,有2G、3G、4G、5G网络,还有越来越多的公共Wi-Fi。不同的网络环境的差异都会对用户使用APP造成一定影响。另外,当前APP使用场景多变,如进地铁、上公交、进电梯等,使得弱网测试显得尤为重要。如果APP没有对各种网络异常进行兼容处理,那么用户可能在日常生活中遇到APP闪退、ANR、数据丢失等问题,因此APP弱网测试尤为重要。今天给大家讲解APP网络测试要点和弱网测试常用模拟方法,让大家对网络测试有一个全面的认识。一APP网络测试点1各网络环境下的功能测试不同网络环境下的功能测试:不同网络下,检查基本功能点;运营商移动、联通、电信接入点测试(需要使用实际SIM卡);若有智能DNS功能,还需要关注运营商判断/归类;高延时、高丢包、无网、假热点也可归入弱网测试范畴;2网络切换测试部分APP有智能DNS功能,网络切换涉及DNS切换。网络切换检测机制:Android可以监听系统广播。3弱网测试用户体验和异常处理是各个网络场景都需要关注的,弱网场景下需要重点关注。二APP网络测试模拟1什么是弱网测试?低于2G速率的时候都属于弱网,3G也可划分为弱网,一般Wi-Fi不划入弱网测试范畴。2如何进行弱网测试?SIM卡的网络切换:(手机-设置-移动网络设置-网络类型选择),3G、4G卡都可以设置关闭3G/4G,只走2G网络。具体弱网场景测试,常见场景包括:地铁/巴士、电梯、楼梯间、停车场;使用虚拟机模拟网络速度:如用树莓派搭建的弱网测试仪;使用软件进行网络代理:模拟不同的网络带宽、延时率、丢包率;3弱网模拟工具使用(1) Charles/Fiddler弱网模拟①Proxy->Throttle Settings:②Throttle Settings可以指定域名拦截,也可以所有请求拦截。配置参数解析:bandwidth: 带宽,即上行、下行数据传输速度;utilisation :带宽可用率,大部分modern是100%;round-trip latency :第一个请求的时延,单位是ms;MTU :最大传输单元,即TCP包的最大size,可以更真实模拟TCP层,每次传输的分包情况;Releability :指连接的可靠性。这里指的是10kb的可靠率。用于模拟网络不稳定;Stability :连接稳定性,也会影响带宽可用性。用于模拟移动网络,移动网络连接一般不可靠。具体网络设置参考:不同网络环境的网络设置:Fiddler进行弱网环境模拟详见:Fiddler及浏览器开发者工具进行弱网测试(2) Chrome的Webview调试工具弱网模拟使用Chrome的Webview调试工具,缺点是只适用于Web页面的弱网模拟。具体步骤:①应用打开webview调试功能,具体如下:if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {undefinedWebView.setWebContentsDebuggingEnabled(true);}②手机连接电脑,运行APP,进入具体H5页面;③Chrome的DevTools中打开Webview:进入chrome://inspect/#devices,会显示已经连接设备,选中待调试webview的inspect network页面,No throttling下拉框,可以进行网络模拟。(3) IOS手机自带的Network Link Conditioner 弱网模拟iPhone手机打开开发者选项:设置-开发者选项 > Network Link Conditioner 入口,系统已经内置常见网络配置,也可以增加自定义配置。具体配置参数:in Bandwidth :下行带宽,即下行网络速度;In packet loss: 下行丢包率;in delay :下行延迟,单位ms;out bandwidth :上行带宽;out packet loss :上行丢包率;out delay :上行延迟;DNS delay DNS :解析延迟;protocol :支持Any,IPV4、IPV6;interface :支持Any,WI-Fi,cellular(蜂窝网);具体步骤参考:①Settings->Developer:②Developer->Network Link Conditioner:③选择Profile:④选择网络:三网络测试经典问题1弱网下,页面加载过程出现程序闪退?原因:webview超时处理未在UI线程。toast、关闭页面等操作需要在UI线程。2302跳转页面,达到内置超时阀值后,webview自动关闭原因:业务有页面加载超时自动关闭的逻辑,超时机制未考虑302场景。
0 评论