开源测试工具 ppts - 网页性能分析工具

少年 · 2019年09月22日 · 最后由 少年 回复于 2020年07月22日 · 6117 次阅读

ppts

performance-puppeteer-tests

Github 源码:https://github.com/ShaoNianyr/ppts

基于 node 以及 puppeteer 开发的一款网页性能分析工具,对网页的加载收集关键性的指标,包括白屏时间,首屏时间,可交互时间等等,并可以指定次数去加载,计算平均值,方差等等。这里的指定次数为非并发,而是单次加载完成以后重新去加载,支持清除浏览器缓存的重新加载,也支持指定手机型号模拟手机 web 端的加载。更多详情见用法。

最新版本: v1.4.0

版本新特性:
v1.4.0: 当输出格式为 json 时,支持通过 webhook 发送测试数据给群机器人
v1.3.0: 改变打开 url 的方式
v1.2.0: 支持手机模式和有无缓存等模式
v1.1.1: 支持对网页性能指标的测量

安装

ppts npm 包安装 :

npm install -g ppts --registry=https://registry.npm.taobao.org

对网页加载的性能指标的检测

计算结果:
    |  min  |  median  |  max  |  average  |  standardDeviation  |
      最小值    中间值    最大值    平均值            方差

性能指标:
    jsHeapUsedSize             占用的堆的大小
    jsHeapTotalSize            堆占用的总内存
    firstPaint                 白屏时间 (页面从空白到开始显示内容的时间)
    firstMeaningfulPaint       首屏时间 (用户看到第一屏的时间)
    domContentLoaded           可交互时间 (用户可以开始与页面交互操作的时间)
    loadEventEnd               加载完成时间 (整个页面完成加载的时间)

用法

使用如下指令对 url 进行性能测试 :

ppts <url>

更多用法使用 -h (--help) 可以获取。

➜ ppts -h

    Usage: cli <url> [options]

    Description:
        performance-puppeteer-tests

    Author:
        Shaonian <licetianyr@163.com>

    Options:
        -r, --repeat [n]                     指定加载次数 (default: 5)
        -w, --width [width]                  浏览器首屏的宽度 (default: "1920")
        -H, --height [height]                浏览器首屏的高度 (default: "1080")
        -o, --output-format [output-format]  输出报告格式 (default: "table")
        -c, --custom-path [custom-path]      载入配置文件(default: null)
        --phone [device-name]                是否启用手机模式(default: null)
        --cache                              是否启用浏览器缓存 (default: false)
        --webhook [webhook-url]              是否启用webhook通知(default: null)
        --output-file [output-file]          输出报告文件(default: txt)
        --wait-until [wait-until]            加载完成的标志(default: load)
        --no-headless                        浏览器无头模式(default: true)
        --no-sandbox                         适配Linux无沙盒模式(default: false)
        -h, --help                           output usage information

指定运行次数 (不指定默认为 5 次)

ppts -r 100 https://www.baidu.com

关闭无头模式(此模式下会弹出浏览器显示加载详情,不指定默认开启无头模式)

ppts https://www.baidu.com --no-headless false

开始无沙盒模式 (适配 Linux 系统性 Chrome 的运行,不指定默认关闭无沙盒模式)

ppts https://www.baidu.com --no-sandbox true

支持挂载复杂的动作脚本 (比如提交表单,鼠标点击等等,提供 demo login.js 的登录脚本,测试幕布网登录成功后的页面加载速度,不指定默认无挂载。)

ppts -c './extend_custom/login.js' https://mubu.com

开启浏览器缓存(不指定默认清除浏览器缓存)

ppts https://www.baidu.com --cache true

设置 webhook(不指定默认不开启 webhook,此处以企业微信群机器人为例)

ppts https://www.baidu.com --output-format json --webhook your-webhook-url

开始手机模式并指定型号 (不指定默认为 PC 端运行)

ppts https://www.baidu.com --phone 'iPhone X' --no-headless false


开启手机模式下支持模拟的手机型号

Blackberry PlayBook
Blackberry PlayBook landscape
BlackBerry Z30
BlackBerry Z30 landscape
Galaxy Note 3
Galaxy Note 3 landscape
Galaxy Note II
Galaxy Note II landscape
Galaxy S III
Galaxy S III landscape
Galaxy S5
Galaxy S5 landscape
iPad
iPad landscape
iPad Mini
iPad Mini landscape
iPad Pro
iPad Pro landscape
iPhone 4
iPhone 4 landscape
iPhone 5
iPhone 5 landscape
iPhone 6
iPhone 6 landscape
iPhone 6 Plus
iPhone 6 Plus landscape
iPhone 7
iPhone 7 landscape
iPhone 7 Plus
iPhone 7 Plus landscape
iPhone 8
iPhone 8 landscape
iPhone 8 Plus
iPhone 8 Plus landscape
iPhone SE
iPhone SE landscape
iPhone X
iPhone X landscape
iPhone XR
iPhone XR landscape
JioPhone 2
JioPhone 2 landscape
Kindle Fire HDX
Kindle Fire HDX landscape
LG Optimus L70
LG Optimus L70 landscape
Microsoft Lumia 550
Microsoft Lumia 950
Microsoft Lumia 950 landscape
Nexus 10
Nexus 10 landscape
Nexus 4
Nexus 4 landscape
Nexus 5
Nexus 5 landscape
Nexus 5X
Nexus 5X landscape
Nexus 6
Nexus 6 landscape
Nexus 6P
Nexus 6P landscape
Nexus 7
Nexus 7 landscape
Nokia Lumia 520
Nokia Lumia 520 landscape
Nokia N9
Nokia N9 landscape
Pixel 2
Pixel 2 landscape
Pixel 2 XL
Pixel 2 XL landscape

PS:技术交流 QQ 群 552643038

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
共收到 12 条回复 时间 点赞

ppts 安装需要 node 环境,版本最好是最新的,有使用问题或技术问题可以直接到 Github 上提 issues,或此处留言。如果对你的使用有帮助,请点赞或 Star 一下 ~

ppts v1.4.0: 当输出格式为 json 时,支持通过 webhook 发送测试数据给群机器人

少年 关于如何量化及规范化网页的响应速度 中提及了此贴 11月05日 09:09

很好的一个工具。但是对比了 Chrome inspect 调试 发现数据有些出入

妞妞 回复

每次数据本来就是在浮动的,这个是做了统计。出入比较大的话,考虑一下配置模式,默认是 no cache,同时无头和有头模式本身也存在一定的偏差,这个可以看 puppeteer 文档深入了解一下。

看起来超级棒的一个工具!但是有个疑问,请问这个工具支持网页登录等动作吗?因为有些网址需要登录后才能访问,真心求教🎃

爱吃米饭 回复

支持,看文中有写 ~ 下面这个就是登陆幕布网后的测试。

少年 回复

当时有过猜测这里是处理登录的😂
那么这些处理动作的脚本,都需要用 js 语言来编写吗?
盼答复~

少年 #10 · 2020年07月20日 Author
爱吃米饭 回复

用 puppeteer 来写,也可以说是 js,可以下载 puppeteer-record 来录制脚本。大概长这样:

少年 回复

好的,谢谢,我去研究一下~

你好,请教一下,在 Chrome 的 console 控制台打印的 performance.timing,每个页面都一样,这是什么原因呢😂

少年 #13 · 2020年07月22日 Author

Navigated url 不会随着你的点击跳转变化,到了新的页面,手动刷新,才会更新 Navigated url。

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册