1.APP网络测试要点
2.Charles安装
链接:https://pan.baidu.com/s/1SqidGm7ngOEymoxsacoANw
提取码:c6hc
生成替换文件charles.jar:https://www.zzzmode.com/mytools/charles/
安装完成后替换lib中的charles.jar即可。设置手机代理配置。
3.Charles-procy-Throttle settings中可以模拟不同的网络环境
Bandwidth(Kbps)—>带宽(千位/秒)
由该值控制数据参数速度
download—>下载速度,指的是从网络上下载下来的速度
upload—>上传速度,指的是把数据上传到网络上的速度
Utilisation(%)—>可用率(%)
带宽可用率,大部分modern是100%。
Round-trip latency (ms)—>往返延迟(Ms)
延迟,就是网络请求发起时,延迟多
即TCP包的最大size,可以更真实模拟TCP层,每次传输的分包情况
Reliability (%)—>可靠性(%)-----丢包
指连接的可靠性。这里指的是10kb的可靠率。用于模拟网络不稳定。
Stability (%)—>稳定性(%)------抖动
连接稳定性,也会影响带宽可用性。用于模拟移动网络,移动网络连接一般不可靠。
Unstable quality range (%)—>不稳定质量范围(%)
开启后,Charles界面的"绿色小乌龟"会在点亮状态,则表示已经开启限速了。
MTU (bytes)—>最大传输单位(字节) 一般设置1500
4.弱网测试常见问题
1、现象:用户登录应用时下载初始化数据,下载过程中因网速太慢点击取消并重新登录,数据初始化完成后出现重复,造成数据不一致。
原因:数据下载过程中、下载失败后,未进行数据回滚,中止后重新下载,出现数据重复
解决方案:通过事务处理数据下载逻辑,下载失败后,应用本地数据库进行数据回滚。
2、现象:用户点击数据上传,数据上传过程中网络弱且不稳定,基于联网状态自动触发数据上传,导致出现数据重复写入,形成脏数据
原因:数据上传过程中,由于失败重传机制,会出现连续两次写操作,并且未做唯一识别处理
解决方案:根据数据特性,对可能造成脏数据的地方,通过关键字段,例如创建时间,key-value值等生成hash键,标记记录唯一性,即数据写入时,检查hash键是否存在,如果已经存在,当前重复数据丢弃。
3、现象:在弱网环境下,用户输入用户名和密码点击登录,应用链接超时返回用户名和密码错误提示。
原因:在弱网环境下的连接超时后,按照强网业务逻辑处理,导致返回超时异常。
解决方案:弱网连接超时后,检查应用本地数据库是否有用户登录信息,若存在,获取应用本地用户信息进行登录。
4、现象:在弱网环境下,用户输入用户名和密码后点击登录,登录过程中应用崩溃并且闪退。
原因:弱网环境下数据下载超时,加载数据严重依赖于后来的异步加载。数据还没来得及返回,应用跳转到下个activity,导致崩溃。
解决方案:健壮数据加载流程,通过标记后台数据下载状态加载界面,依赖数据下载完成后,再进行页面跳转。
5、现象:弱网络环境下,用户请求页面响应时间较长,等待的过程中,页面上的部分控件仍然可以操作,当用户点击控件时,出现应用闪退现象;
原因:没有对数据加载流程进行判断,直接暴露控件可控,当出现依赖数据的控件操作时,没有在数据返回前做兼容处理。
解决方案:在数据加载过程中,设置页面对外暴露的控件为“不可操作”,当数据加载完再释放。
6、现象:在弱网环境下,用户第一次输入搜索关键字没有得到响应后,再次输入全新关键字并发送请求,等待搜索结果返回后,当前结果页被之前的关键字搜索结果刷新覆盖
原因:中间的请求返回较慢,显示最终的结果后,之前请求返回的数据应不做处理。
解决方案:对异步请求未完成的任务进行cancel.