java web 性能测试_WEB 自动化性能测试

介绍

从浏览器打开一个网站,需要 dns 解析、tcp 三次握手、发送请求、dom 渲染、js 加载等以一系列操作,最终在用户面前展示完整的页面.

如果打开页面加载或者白屏的时间较长,用户会立即关掉或者放弃浏览,用户流量自然会丢失.

所以在 web 项目中 web 页面的加载时间测试是必不可少的.

相关参数

全部页面加载时间

全部页面载入时间指从最初启动浏览开始,直到所有元素都被加载完成后,在 2 秒后仍然没有网络活动的时间.

0-2 秒:用户体验最好,打分 100

2-8 秒:用户可以容忍,从第 2 秒开始,每超过 1 秒减 5 分

8-15 秒:用户不能忍受,从第 2 秒开始,每超过 1 秒减 5 分

页面加载时间

从页面开始加载到页面 onload 事件触发的时间。一般来说 onload 触发代表着直接通过 HTML 引用的 CSS,JS,图片资源已经完全加载完毕.

白屏时间

输入网址到数据返回时间,此时页面还没有进行 dom 渲染

首字节时间

从开始加载到收到服务器返回数据的第一字节的时间

DNS 时间

进行域名解析所需要的时间

TCP 时间

客户端建立连接的时间

DOM 渲染时间

DOM 节点渲染时间,此时页面还不能执行操作事件

js 加载时间

js、css、图片加载,此时用户可以对页面进行操作事件

访问 web 页面过程

10678806f3495127c8cb6f231637f12f.png

查看性能加载数据

使用 chrome 浏览器中的控制台,使用 window.performance.timing 函数可以查看页面的加载数据.

64e6387e4e77c11be35db129cd8cf11a.png

自动化工具

有了可以查看 web 页面的 js 函数,就可以利用一些自动化手段测试 web 页面并且自动化生产性能数据.

主要使用 selenium+spring boot+rest-assured+highcharts 等技术完成自动化测试

a4cd374bf2861a5861c62d125d734f94.png

selenium

使用 selenium 的 headless 模式可以无感的打开一个网页并进行自动化测试,这种模式可以降低 cpu 和内存的消耗

spring boot

spring boot 是 java 的 web 应用框架,使用 velocity 模版接受请求参数,可以动态渲染 web 页面.

rest-assured

rest-assured 是 java 的一个接口测试框架,用于给服务端传递参数.

highcharts

highcharts 是 HTML5 交互性图表库,有丰富的柱状图、饼图等

展示效果

526a07bde35daf86a65006bd7265e85d.png

git 地址 https://github.com/xinxi1990/webtest

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值