1、背景
最近在技术群里面讨论到使用 python 操作 jmeter 的话题
有人提到了 subprocess 启动命令行来操作 jmeter,也有人提到了 jmeterapi,另外也有人提到了 pymeter
除了这些,实际上我之前也基于 docker+subprocess 来操作 jmeter 的项目
jmeterapi 这个库年久失修,就不想搞它了,下面跟我一起试试 pymeter 吧
data:image/s3,"s3://crabby-images/0a818/0a818f4dbe167974515efc6a4a2eba4faccef3a0" alt=""
data:image/s3,"s3://crabby-images/f36f0/f36f067c51eb2eb84b1a827d32b959554e3b92b6" alt=""
2、环境准备
直接参考项目的说明即可
data:image/s3,"s3://crabby-images/a7e28/a7e288b8364cc36c3c829a600b0913bd6e13e61a" alt=""
3、Jmeter 测试
3.1 写测试用例
使用方法比较简单,设置 GUI 类似,只是前后顺序不相同:
- 创建线程组
- 把 sample,断言,抽取等配置加入线程组
- 创建报告收集器
- 把线程组和报告收集器加入测试计划
- 运行测试计划
data:image/s3,"s3://crabby-images/79497/79497a2eec2acdf73e14b53f02cf1ee60254c782" alt=""
3.2 运行和收集结果
3.2.1 pycharm 启动
如果你使用的 PyCharm,会自动识别
data:image/s3,"s3://crabby-images/8b931/8b931b8212f898298041cde21624e239745a2a6c" alt=""
3.2.2 命令行启动
data:image/s3,"s3://crabby-images/5d621/5d621597d92f9a6524fb6f89efeb8e4ead518ae3" alt=""
3.2.3 查看报告
报告会自动生成在 output 文件夹下面,一个 test 函数对应一份报告
使用浏览器打开 index.html 就能看到完整的报告
data:image/s3,"s3://crabby-images/ccaf8/ccaf8308db27571eb7e8cbe150eaa5d01b7a7c01" alt=""
data:image/s3,"s3://crabby-images/58d55/58d55315018fc30bc1e05183fd3f80c0825070fc" alt=""
4、总结
- python 结合 jmeter-dsl 的特性,使用起来很方便
- 常用的部分功能(线程组,部分断言,报告)已经支持
- 目前整体完成度还是偏低,插件,复杂的断言,各种 sample 还未支持
data:image/s3,"s3://crabby-images/d4077/d4077137e7d64ae7b281ec8dacb1e1aaece02e07" alt=""