耗时三天京东大佬整理的jmeter结果数据写入到指定文件,学完涨薪3k没问题

背景:
在日常的功能测试或者性能测试的时候,需要把结果中指定的数据保存到指定的文件,进行使用,发现 jmeter 自带的文件写入,没有自己需要的,默认只支持 XML 的结果保存,那么接下来我们围绕 beanshell 来实现这个功能。

视频教程:b站最牛Jmeter接口测试和Jmeter接口自动化测试全集_哔哩哔哩_bilibili

下面从两个方面来实现:
一、保存接口返回指定的数据

二、从数据库用 SQL 语句取数据,保存结果到指定文件中.

一、保存接口返回指定的数据
接口:登录

需求:提取 token 值

新建 HTTP 请求

image.png

请求返回的结果,这里直接用 JSON 显示:

image.png

新建 JSON 提取器

image.png

调试,看有没有获取到值

添加 debug sampler

image.png

运行,查看 debug sampler 响应数据里面 token 有没有取到值

image.png

添加 beanshell 取样器

image.png

上代码

//指定需要写入到哪个文件,格式:TXT,csv

FileWriter file = new FileWriter("D:\apache-jmeter-5.0\token_num.txt",true);

//创建一个字符缓存输出流

BufferedWriter out = new BufferedWriter(file);

//写文件内容

//vars.get:获取 jmeter 中的变量值

out.write(vars.get("token")+"\n");

//关闭写数据流

out.close();

//关闭文件

file.close();

image.png

运行,可以循环多次写入数据

image.png

image.png

二、从数据库用 SQL 语句取数据,保存结果到指定文件中
需求:用 SQ 语句查询出数据,保存结果到文件中

添加 SQL 语句的配置元件

image.png

 image.png

添加 SQL 语句取样器

image.png

image.png

--提取 token 的值,并指定 token 输出的左边界值,这里取出 5 行数据

SELECT CONCAT('"token_num":',token,'') FROM cb_account LIMIT 5

image.png

添加正则表达式,提取 SQL 执行之后返回的结果值

image.png

引用名称:token_num

正则表达式:"token_num":(.+)

模板:$1$

匹配数字:-1 (取出所有的值)

image.png

调试,看有没有获取到值

添加 debug sampler

image.png

运行,可以看到获取到了所有的查询结果

image.png

 image.png

可以看到在引用变量后面加上数字,从 2 开始,那么下面要怎么做呢?

添加 beanshell 取样器

image.png

 

代码:

//指定需要写入到哪个文件,格式:TXT,csv

FileWriter fstream = new FileWriter("D:\apache-jmeter-5.0\token_num.csv",true);

//创建一个字符缓存输出流

BufferedWriter out = new BufferedWriter(fstream);

//返回的结果有值从数字 2 开始,一共有 5 次,那么我们这里就小于等于 6

for(int num=2; num<=6; num++){

//拼接变量名称

 


token_num = "token_num"+"_"+num;

System.out.println(token_num);

//把拼接的名称赋值给 token_num

vars.put("token_num",token_num);

System.out.println(vars.get(token_num));

//vars.get()获取到变量名称,并和上面返回的 token_num_(2,3,4,5,6)名称一致,取到变量的值

out.write(vars.get(token_num)+"\n");
}

out.close();

fstream.close();

image.png

运行查看结果:

image.png

 总结:在测试行业摸爬滚打也有十几年了,在学习的途中也是收藏了很多的学习资源,下面是软件测试到测试开发全职业生涯全套学习资料

【需要的可以点击下方官方推广小卡片扫码备注000免费领取】

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值