当前 APP 网络环境比较复杂,网络制式有 2G、3G、4G 网络,还有越来越多的公共 Wi-Fi。不同的网络环境和网络制式的差异,都会对用户使用 app 造成一定影响。另外,当前 app 使用场景多变,如进地铁、上公交、进电梯等,使得弱网测试显得尤为重要。如果 app 没有对各种网络异常进行兼容处理,那么用户可能在日常生活中遇到 APP 闪退、ANR、数据丢失等问题。因此,app 网络测试,特别是弱网测试尤为重要。本文梳理了 app 网络测试要点和弱网测试常用模拟方法,让大家对网络测试有一个全面的认识。

1、各个网络下功能测试
2、网络切换测试
部分 APP 有智能 DNS 功能,网络切换涉及 DNS 切换。
网络切换检测机制:Android 可以监听系统广播
3、弱网测试
用户体验和异常处理是各个网络场景都需要关注的,只是弱网场景下,需要重点关注。
低于 2G 速率的时候都属于弱网,3G 也可划分为弱网,一般 Wi-Fi 不划入弱网测试范畴。
1、SIM 卡的网络切换
手机 - 设置 - 移动网络设置 - 网络类型选择
3G、4G 卡都可以设置关闭 3G/4G,只走 2G 网络。
2、具体弱网场景测试,常见场景包括:地铁 / 巴士、电梯、楼梯间、停车场
3、使用虚拟机模拟网络速度,如用树莓派搭建的弱网测试仪
4、使用软件进行网络代理,模拟不同的网络带宽、延时率、丢包率

配置参数解析:
bandwidth —— 带宽,即上行、下行数据传输速度
utilisation —— 带宽可用率,大部分 modern 是 100%
round-trip latency —— 第一个请求的时延,单位是 ms。
MTU —— 最大传输单元,即 TCP 包的最大 size,可以更真实模拟 TCP 层,每次传输的分包情况。
Releability —— 指连接的可靠性。这里指的是 10kb 的可靠率。用于模拟网络不稳定。
Stability —— 连接稳定性,也会影响带宽可用性。用于模拟移动网络,移动网络连接一般不可靠。
具体网络设置参考:

Fiddler 也可以进行弱网环境模拟,具体参考: Fiddler 弱网模拟
使用 chrome 的 webview 调试工具,缺点是只适用于 web 页面的弱网模拟。
具体步骤:
(1)应用打开 webview 调试功能,具体如下:
if (Build.VERSION.SDK_INT>= Build.VERSION_CODES.KITKAT) {
WebView.setWebContentsDebuggingEnabled(true);
}
(2)手机链接电脑,运行 APP,进入具体 H5 页面;
(3)chrome 的 DevTools 中打开 Webview:进入 chrome://inspect/#devices,会显示已经连接设备,选中待调试 webview 的 inspect
network 页面,No throttling 下拉框,可以进行网络模拟。
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(蜂窝网)
具体步骤参考:


来源: https://www.cnblogs.com/amyzhu/p/8232796.html