JMeter接口自动化发包与示例
JMeter接口自动化发包与示例
近期需要完成对于接口的测试,于是了解并简单做了个测试示例,看了看这款江湖上声名远播的强大的软件-Jmeter靠不靠谱。
官网:https://jmeter.apache.org/index.html
1简介
- Apache-Jmeter是一个使用java语言编写且开源,可拓展性较强的测试框架,设计初期用于web应用的压力性能测试较多,但现在功能已经非常丰富,不仅是压力,而目前的接口自动化都可以使用该工具完成
- 本次需求只依据业务,简单设置定时任务,往指定的接口发送接口数据,对接口返回数据做assert断言判断结果,体验一下该软件与postman有何差异。
2结构
Jmeter左上角点击文件-新建,即生成一个测试计划,相当于一个project,并创建以下层级结构
-
聚合报告
查看该测试计划的执行结果报告,每个执行的接口都统计在这,如果是做压力测试的话,就可以得出很多次执行的一个接口的性能情况。
-
查看结果树
查看每个测试接口的执行情况,包括该接口实际发送的包以及接口的响应都可以在这看到。
-
Http信息头管理器
消息头信息可以在这里定义,没定义就是按照默认的头发包。
-
setUp线程组
该线程组在整个项目的自动化时,可以将部分鉴权接口、参数生成与配置等放入该模块,以便确保该模块优先执行。
-
线程组
-
前置预处理程序
这里我选择beanshell预处理程序,构造后面接口发的数据,可以看到脚本上边有个tips(scripts variable:ctx vars props prev sampler log),即Jmeter提示在编写脚本的时候可以使用ctx、vars等类去调用相应的API,这些值比如ctx的具体用法可到官网:http://jmeter.apache.org/api/org/apache/jmeter/threads/JMeterContext.html,常见的API:
- ctx - ( [JMeterContext ](http://jmeter.apache.org/api/org/apache/jmeter/threads/JMeterContext.html)) - gives access to the context - vars - ( [JMeterVariables ](http://jmeter.apache.org/api/org/apache/jmeter/threads/JMeterVariables.html)) - gives read/write access to variables: vars.get(key); vars.put(key,val); vars.putObject("OBJ1",new Object()); vars.getObject("OBJ2"); - props - (JMeterProperties - class java.util.Properties) - e.g. props.get("START.HMS"); props.put("PROP1","1234"); - prev - ( [SampleResult ](http://jmeter.apache.org/api/org/apache/jmeter/samplers/SampleResult.html)) - gives access to the previous SampleResult (if any) - sampler - (Sampler)- gives access to the current sampler -
业务请求代码
-
后置预处理程序
//一般来说提取响应内容等打印出来 String statusCode = prev.getResponseCode(); log.info(statusCode);
-
-
tearDown线程组
该线程组将是最后处理的线程组,可以将清除测试数据等放在该模块内部执行。
3代码:
-
测试计划:增加用户定义变量如下:
host 192.168.3.10 port 50553 longConPort 60443 devNum 1 projectId 1 Token 1 -
beanshell预处理程序中处理需要往接口中带入的一些随机变量,这里需求是要依据主设备的MAC地址等信息,携带子设备的相关信息通过接口上报给服务器,于是需要在预处理脚本中新增易于维护的MAC地址信息,也便于后续压力测试的时候生成百千万个设备数据时候做改写。以下定义一台主设备,31台子设备的MAC地址代码如下:
/** * 生成的device_mac为00-00-0X-00-00-00,其中X这里定义为了进程号。整个生成规则可自己依据需求定义 * 对应的25个连接中断的MAC地址也可自定义,client_mac为00-00-0X-00-00-01、00-00-0X-00-00-02……00-00-0X-00-00-25 */ pre_mac = ""; //getThreadNum获取当前进程编号,进程号从0开始的,这里结果是1 thread_index = ctx.getThreadNum(); str_index = thread_index + ""; log.info("当前线程编号: " + str_index ); //最后生成六位字符串000001 n = 6 - str_index.length(); for (int i=0; i<n; i++) { pre_mac += "0"; } pre_mac += str_index; //正则,每隔两位数字就在后面插入一个“-”,使其符合mac地址的规范,最后pre_mac变成00-00-01,device_mac00-00-01-00-00-0X为mac地址一共12位, pre_mac = pre_mac.replaceAll("(.{2})", "$1-"); device_mac = pre_mac + "00-00-00"; //将生成的值存入对象vars中,后续在脚本中都可以直接使用//vars.put("client_mac_"+i, client_mac_i)这个参数后面就可以使用${变量名}直接使用; vars.put("device_mac", device_mac); for (int i=1; i<10; i++) { client_mac_i = pre_mac + "00-00-0" + i; vars.put("client_mac_"+i, client_mac_i); log.info(client_mac_i); } for (int i=10; i<31; i++) { client_mac_i = pre_mac + "00-00-" + i; vars.put("client_mac_"+i, client_mac_i); log.info(client_mac_i); } //Token的定义规则,可以用函数生成,也可以在前面的参数中直接加上 deviceToken = "test" + str_index; vars.put("deviceToken", deviceToken); -
http请求格式
依据前面在测试计划中设定的值,在这个页面相应的位置写上引用即可(格式${变量名}),并依据接口文档定义,把需要发的包的数据编辑好附在body中并为该用例添加一个断言即完成一个用例的编写。
-
循环发送
如下图所示
4运行结果
经过上面处理后,下面可以启动测试计划,并观察执行的结果如下图:
5 小结
Jmeter做上述简单接口的测试上与postman相差无几,而Jmeter还有很多定时器、监听器等功能还未使用到,后面使用jmeter做一次完整的性能压力测试之后,也许才能真正体会到它的强大。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
· 2分钟学会 DeepSeek API,竟然比官方更好用!
· .NET 使用 DeepSeek R1 开发智能 AI 客户端
· DeepSeek本地性能调优
· 一文掌握DeepSeek本地部署+Page Assist浏览器插件+C#接口调用+局域网访问!全攻略