一、框架介绍
1、HttpRunner
是一款面向 HTTP(S) 协议的通用测试框架,只需编写维护一份YAML/JSON脚本,即可实现自动化测试、性能测试、线上监控、持续集成等多种测试需求。
2、Locust
Locust是一款易于使用的分布式用户负载测试工具。它用于对网站(或其他系统)进行负载测试,并确定系统可以处理多少并发用户。HttpRunner 通过复用Locust ,可以在无需对 YAML/JSON 进行任何修改的情况下,直接运行性能测试。
3 httprunner使用手册
附httprunner中文使用文档地址:https://cn.httprunner.org/
二、环境安装
1 安装httprunner: pip install httprunner==2.2.5
2 安装har2case: pip install har2case
3 检查安装是否成功:hrun -h/-v;har2case -h/-v
4 安装locust: pip install locustio
三、在 HttpRunner 安装成功后,系统中会新增如下 5 个命令:
1 httprunner: 核心命令
2 hrun: httprunner 的缩写,功能与 httprunner 完全相同
3 locusts: 基于 Locust 实现性能测试
4 har2case: 辅助工具,可将标准通用的 HAR 格式(HTTP Archive)转换为YAML/JSON格式的测试用例
四、用例生成
(1)利用fiddler/charles对接口数据进行抓包,将结果导出为XX.har文件
data:image/s3,"s3://crabby-images/ce20c/ce20cb2c5bd519e2a5d315861b24d032fec8c119" alt=""
data:image/s3,"s3://crabby-images/e8f0d/e8f0d7f9d8a8730996223819f8a2004513074011" alt=""
(2)将导出的XX.har文件转化为json文件/yaml文件
转化为json文件:har2case xx.har
转化为yaml文件:har2case xx.har -2y/--to-yml
(3) 转化成功后的yaml文件如下:
data:image/s3,"s3://crabby-images/146d7/146d7c641ec53fa0e9bc1b1696bba6ef95e6e4fd" alt=""
status_code:请求的状态码
headers.Content-Type:将响应头的内容格式做验证
content.msg:响应内容的关键字作为验证
----------------------------------------------------------------------
config:作为整个测试用例集的全局配置项,包括变量(variables,name)
test:对应单个测试用例
name 这个test的名字(用例的名称)
request 这个test具体发送http请求的各种信息, 如下:
url 请求的路径 (若config中有定义base_url, 则完整路径是用 base_url + url )
method 请求方法 POST, GET等等
headers:请求头
请求体:json格式的数据
validate(断言): 完成请求后, 所要进行的验证内容. 所有验证内容均通过该test才算通过,否则失败.
参数化:
testcases:
-
name: call demo_testcase with data 1
testcase: testcases/test_login.yml
parameters:
# username: ["admin1","admin"]
-username:
- ["admin1"]
- ["admin"]
测试用例(testcase)嵌套testcases
data:image/s3,"s3://crabby-images/05903/059031364b16acd717d9de5235b58f0031d6b8aa" alt=""
变量取值:
data:image/s3,"s3://crabby-images/51f8b/51f8bece253b7a746266c1bf48b62413f24e828f" alt=""
响应头和响应体的提取:
data:image/s3,"s3://crabby-images/f5967/f5967e8a32157ea95cbf194d1c606619b0d23f61" alt=""
data:image/s3,"s3://crabby-images/cc495/cc4953e5067b49279b31578f5373c59bc9e6f0bb" alt=""
提取HTML的内容(正则表达式)
data:image/s3,"s3://crabby-images/69ca0/69ca0e91749024286e53b5f952555f9818f68b5a" alt=""
上传文件场景
data:image/s3,"s3://crabby-images/d766a/d766a10caeacdc63f996b52693743485fa8234c6" alt=""
四、生成项目文档:
(1)进入D盘
(2)输入命令:hrun --startproject 项目名称
testcases:存放用例
testsuites:存放套件
reports:自动生成报告并放到该目录
data:image/s3,"s3://crabby-images/a07bd/a07bdb623b6508535bae42cb3f63daf8e9aa6adc" alt=""
3、 进入到目录,查看对应的文件和目录
可以看到生成的3个目录和一个py文件,api debugtalk.py testcases suite
4、将转化好的XX.har文件放置在项目文件夹testcases目录中
5 、运行用例
(1)运行单个用例:指定具体的xx.yml或xx.json文件
hrun 文件路径/hrun 文件路径 --log-level info
data:image/s3,"s3://crabby-images/f03dc/f03dcedb0768df5c9a37db1769a9273acb7a3cab" alt=""
(2)运行多个用例:hrun 文件的testcases目录
data:image/s3,"s3://crabby-images/6ea94/6ea9497d3b699348fa2c909309d0c25f84c32558" alt=""
(3) 运行testsuites目录:运行testsuites目录中所有的yml用例
data:image/s3,"s3://crabby-images/ee57e/ee57e136b65710733628e88cda53d81901114d18" alt=""
参数化:多个参数三种类型参数化
data:image/s3,"s3://crabby-images/db345/db3454c834e6f93e04f1eb520a7991e7abfecbeb" alt=""
六、查看报告
在项目文件夹report中,生成了html格式的测试报告,包括log日志记录(包含request and response data)
data:image/s3,"s3://crabby-images/fa49e/fa49e9bf3c4e5c646a9ddd5a214d2f4343e58e24" alt=""
data:image/s3,"s3://crabby-images/6739a/6739a46d4305d483d90c40987540c6d6190de06b" alt=""
data:image/s3,"s3://crabby-images/7d6a4/7d6a41b1ade812831a74b33d88a031ec5a30b68e" alt=""
注意事项:
data:image/s3,"s3://crabby-images/c763e/c763ec901a8b1470cff76dad8e9bf3c2d0d1456d" alt=""
hrun xx.yaml --log-level debug
data:image/s3,"s3://crabby-images/bc140/bc1407347d8f2dac38fd559959dae950b13faa2e" alt=""
(3) 将运行过程中的中间数据作为日志保存:hrun xx.yaml --log-file xx.log
data:image/s3,"s3://crabby-images/625eb/625eb9d968db6fbe37a8ab28cab489788d95d019" alt=""
data:image/s3,"s3://crabby-images/1faa0/1faa0acf332ac5885b3d0da46fcbe31a144add05" alt=""
七、接口的性能测试---locusts
1 执行性能测试用例:locusts -f 文件路径(相对路径) --processes
(在 Locust 中需使用多核处理器的能力,--processes 参数,可以一次性启动 1 个 master 和多个 salve。若在 --processes 参数后没有指定具体的数值,则启动的 slave 个数与机器的 CPU 核数相同。)
data:image/s3,"s3://crabby-images/48df7/48df77b2b4d216cbc38fa80ede41abe91574aea6" alt=""
2 用例运行完成后,在浏览器中输入地址 http://localhost:8089/,可查看到locust页面
Number of total users to simulate:并发用户数
Hatch rate (users spawned/second):多少秒启动这些并发
Host:接口的主机地址
data:image/s3,"s3://crabby-images/fba27/fba27809822bce66c14bc003c600205f956d7470" alt=""
data:image/s3,"s3://crabby-images/26f60/26f60364fe761b6de9bca1e031b8ee3d004b22dd" alt=""
locustos在执行请求动作
data:image/s3,"s3://crabby-images/892bb/892bb352c910b35ff5d00f5f6567381d58b7928a" alt=""
3 查看性能测试报告:
data:image/s3,"s3://crabby-images/0aad4/0aad46bde277578896fb201336d582c96936d24c" alt=""
(2) 每秒完成的请求数(RPS:Requests Per Second)
data:image/s3,"s3://crabby-images/dc136/dc1363c8999aee0370caaef36b0c05b9873bc360" alt=""
(3)响应时间(Response Times),单位ms
data:image/s3,"s3://crabby-images/27652/27652bfdbb26fe00930586a0dc171d28d3c38ec3" alt=""
(4)不同时间的虚拟用户数:稳定值(一定时间后)
data:image/s3,"s3://crabby-images/90778/907781a5cc17037e2292c38ae3342ea74d48fc50" alt=""
(5)查看cpu并发压力:类似负载均衡--CPU usage(cpu的使用率)
data:image/s3,"s3://crabby-images/ab642/ab642bfb1b3aaa45cf13bc5a450f223bd62e7eea" alt=""
6、参数说明
host:http://10.0.10.27:10080
请求路径(name):/api/login
data:image/s3,"s3://crabby-images/6477d/6477de4a7bfcf8042f74882e184fc3823b59dc41" alt=""
7 脚本执行结果
从测试结果可以看出,实际上每秒并没有触发10个请求(RPS值不到10),因为在locustfile.py文件里面有个等待机制
min_wait = 1000 最小等待时间1秒
max_wait = 5000 最大等待时间5秒
把max_wait改成1000就可以达到 10 RPS了
locustfile.py
当启动locusts的时候,会在当前目录自动生成一个locustfile.py文件。这个才是locust的脚本文件
data:image/s3,"s3://crabby-images/0acf9/0acf9c166227e0b19a4e6ba7a695a7ca5e3b3a92" alt=""
使用locust执行locustfile.py脚本文件
locust -f locustfile.py
测试结果 RPS=9.9 接近10
网友评论