一、前言

  最近工作和生活说忙也忙,说不忙也不忙,但就是已经感觉很长时间没有get新的技术技能了,就是一丢丢的那种也没有,哈哈哈,今天就来讲一下最近get到的小技能吧。

  工作中,由于某个需求需要几百条数据去验证某个接口,肯定不能手动加啦,基于测试周期紧张,直接考虑用jmeter的循环控制器辅助实现。

二、接口背景介绍

  业务说明:点击创建按钮,弹出创建界面,输入必填项后,点击确定,返回创建数据成功。

1、创建接口

  就是需要用该接口创建数据,对于接口的说明如下:

  1)接口请求方法:PUT

  2)必传的入参需要变量的字段有:userCode,userId,userName,remarkid

  3)其余字段根据实际业务,可以传固定值

思路tip:首先要确认变量字段,其次确认变量字段来源,最后确认如何能获取到变量。当前的实例中,除了remarkid,其余3个变量字段是从另外一个查询接口读取的,详细见第2点。

2、查询用户接口

  在创建界面,输入用户名称时会调用【查询用户】接口,该接口返回的数据就是【创建】接口中所需要的入参字段,返回的json格式如下:

三、Loop Controller介绍

  很早之前就已经在工作上用到过这个组件,今天突然发现我居然没有针对这个组件写详细的博客,太尴尬了,那现在就简单了解下这个组件的用法吧。

  Loop Count:循环次数,分为永远、自定义次数——勾选Forever后,自定义次数置灰不允许输入,未勾选,则可以

  按字面意思,其实它就是循环该控制器下的请求,一般跟计数器配合使用,具体根据实际场景来。

  如果非常熟悉Jmeter工具的,想必也知道线程组也可以设置循环次数,这两者其实可以理解为父子关系,比如循环控制器设置循环2次,线程组设置循环4次,则执行的结果如下:  线程一共循环运行了4轮,每轮会循环请求接口2次

四、方法1— Loop Controller循环调用接口

1、脚本结构如下

2、使用强大的JSON提取器,提取返回的字段

3、用户查询接口返回结果如下

  在察看结果树的Debug中可以看到提取的userCode,userId,userName,其中userCode_matchNr表示匹配到的总数

4、创建接口入参使用变量值

  查询接口是提取了返回字段的所有值,要引用变量的写法就相当于 ${userCode_1},那总不能在入参里写死_1吧,因为要循环创建的,得想办法让userCode_x,后面的_x是可以每次自增的,所以要结合counter计数器函数。

  而__V就是要把它们嵌套起来,__V属于嵌套函数,有兴趣可以网上百度,如果不懂的话直接复制那串改一下变量就行。

  remarkid在业务上是不允许重复的,所以这里使用Random函数,即随机数函数,让它随机生成一串数字即可。

"userCode":"${__V(userCode_${__counter(\,)},)}","userName":"${__V(username_${__counter(\,)},)}","userId":"${__V(userId_${__counter(\,)},)}","remarkid":"${__Random(1000,9000,)}"

5、循环控制器循环次数使用变量值

  循环控制器中的自定义次数考虑到灵活性,使用查询接口匹配到的总数(变量_matchNr),一共提取3个字段,所以用其中任意字段都行,引用格式: ${username_matchNr}

6、执行

  完成以上步骤,就可以执行创建数据啦,执行结果我就不贴了。

五、方法2—Loop Controller循环调用JDBC

  跟方法1的步骤是一样的,只是方法2是通过调用jdbc request,即sql循环插入数据,这里就不贴图啦,具体看脚本结构,然后在jdbc里写条insert语句,将相应字段替换成引用变量即可。

  注:执行insert,Query Type需要选择【Prepared Update Statement】

六、方法3—BeanShell写入excel,手动生成sql语句

1、BeanShell PostProcessor

  这种其实也是通过sql插入,只不过是手动插入,在用户查询请求下添加BeanShell PostProcessor,脚本如下:

//指定需要写入到哪个文件
FileWriter fs=new FileWriter("C:/Users/13710/Desktop/9000.csv",true);
//创建一个字符缓存输出流
BufferedWriter out = new BufferedWriter(fs); //另一种获取变量值的写法
//int b = Integer.valueOf("${username_matchNr}");
//System.out.println("接口返回的总数为:"+b); for(int i=1;i<= ${username_matchNr};i++){
username= vars.get("username_"+i);
userId = vars.get("userId_"+i);
userCode = vars.get("userCode_"+i);
out.write(username+","+userCode+","+userId);
out.write(System.getProperty("line.separator"));
System.out.println("输出的值是:"+username);
} out.close();
fs.close();

2、执行后自动生成.csv文件

  可以看到excel里有3列,因为beanshell脚本拿到3个变量字段写到了excel里了

3、运用强大的excel功能生成sql语句

  D4列是自己先写一条sql哈,写好后往下拖动就会自动生成其他的,其中需要变的均引用表格变量,格式:"&A1&"

温馨tip:如果公式中的字符串过长,要用CONCATENATE函数

例子1(这个没超的):   =CONCATENATE("INSERT INTO contact(name, post,id)VALUES ("&A1&", '"&B1&","&C1&"');")

例子2(分成了4个字符串,因为公式中每一个字符串都不能超过255字符):

4、将D4列直接复制到数据库里执行即可

Jmeter-记一次自动化造数引发的BeanShell写入excel实例的更多相关文章

  1. C#将数据以XML格式写入Excel

    本文转载:http://www.cnblogs.com/eflylab/archive/2008/09/21/1295580.html c#将数据导入Excel另类方法 今天公司突然给个Excel模版 ...

  2. Jmeter发送jdbc请求进行大批量造数

    创建批量造数脚本,一个简单的结构如下图所示, 1.线程组(10个线程重复运行2次,相当于造20个数) 2.用户定义变量(这是全局变量,用于后面随机筛选用) 3.数据库连接配置 4.计数器(用于主键递增 ...

  3. Jmeter+ant+Jenkins接口自动化框架搭建

    摘自:https://testerhome.com/topics/13389 一.背景  上一篇讲了Jmeter 接口自动化-脚本数据分离实例,我们知道怎么利用Jmeter去编写接口自动化脚本,但是接 ...

  4. 转:利用ant与jmeter实现负载测试自动化

    性能测试一直以来都是测试领域一个令人争议的话题.测试的参考标准.评判依据及测试的方法选择都很难有一个统一的说法.但无论如何,对于需要能够承受一定压力而运行的程序来说,进行其进行功能和性能测试是一个必不 ...

  5. 通过DbVisualizer 工具运行DB2存储过程实现INSERT语句主键自增造数

    1.需求简介 最近开发人员需要进行一批数据进行生产上SQL语句耗时过长问题的验证与优化.所以在性能测试库中批量建造数据,由于交易本身业务逻辑过于复杂以及需要各种授权,最后决定采用插表的方式完成. 2. ...

  6. mysql存储过程造数

    性能测试时,数据库表通常需要很多数据,此时我们可以用存储过程来造数,以下代码mysql.Oracle都可以用 首先,先查看数据库表的设计,可以看到每张表有多少字段,分别都是什么类型,哪个字段是自动增长 ...

  7. 基于Jmeter跟Jenkins的自动化性能测试的一站式解决方案(转)

    www.MyException.Cn  网友分享于:2015-08-26  浏览:0次   基于Jmeter和Jenkins的自动化性能测试的一站式解决方案 作者: Yu, Qingguo Shen, ...

  8. MySql、PostgreSql、SqlServer三种数据库的造数存储过程实例

    主要实例:把临时表tmp_table数据插入到目标表target_table 一.MySql造数存储过程实例 mysql造数 -- 第一步,创建临时表 CREATE TEMPORARY TABLE I ...

  9. Jmeter任在运行,线程数上不去

    问题 jmeter在运行,但是线程数上不去(本来模型设计了100个总线程,但运行时线程只能上到5,根据图上观察总共也只能运行5个线程) 之前更新了random csv插件 解决办法 查看jmeter. ...

随机推荐

  1. Golang 实现 Redis(11): RDB 文件解析

    RDB 文件使用二进制方式存储 Redis 内存中的数据,具有体积小.加载快的优点.本文主要介绍 RDB 文件的结构和编码方式,并借此探讨二进制编解码和文件处理方式,希望对您有所帮助. 本文基于 RD ...

  2. MySQL存储过程入门了解

    0.环境说明: mysql版本:5.7 1.使用说明 ​ 存储过程是数据库的一个重要的对象,可以封装SQL语句集,可以用来完成一些较复杂的业务逻辑,并且可以入参出参(类似于java中的方法的书写). ...

  3. Linux下使用ssh测试端口是否开启

    当服务器上不允许使用telnet时,可以使用ssh测试远程服务器端口是否开启 具体命令如下 -v 显示连接debug信息 -p port 指定端口 ssh -v -p 80 root@192.168. ...

  4. 印尼医疗龙头企业Halodoc的数据平台转型之数据平台V2.0

    1. 摘要 数据平台已经彻底改变了公司存储.分析和使用数据的方式--但为了更有效地使用它们,它们需要可靠.高性能和透明.数据在制定业务决策和评估产品或 Halodoc 功能的性能方面发挥着重要作用.作 ...

  5. 1.Spring开发环境搭建——intellj

    1.在intellj中新建项目,选择JDK版本(1.8版本) 2.选择相关信息填写,注意Java版本要和上面步骤选择的版本一致. 3.选择springBoot版本,勾选Spring Web选项. 4. ...

  6. 腾讯产品快速尝鲜,蓝鲸智云社区版V6.1灰度测试开启

    这周小鲸悄悄推送了社区版V6.1(二进制部署版本,包含基础套餐.监控日志套餐),没过一天就有用户来问6.1的使用问题了.小鲸大吃一鲸,原来你还是爱我的. ![请添加图片描述](https://img- ...

  7. Java的标识符与关键字

    目录 Java关键字 总表:java关键字共53个(其中包含两个保留字const,goto) Java标识符 定义 组成 命名规则 视频课程 Java关键字 Java关键字是电脑语言里事先定义的,有特 ...

  8. MySQL数据库5

    内容概要 pyhton操作MySQL SQL注入问题 修改表SQL语句补充 视图.触发器.储存过程 事务 流程控制 函数 索引与慢查询优化 内容详情 pyhton操作MySQL python中支持操作 ...

  9. python基础学习9

    python基础学习 内容概要 字符编码的简介 字符编码的发展史 字符编码的实际应用 文件操作简介 文件读写模式 文件操作模式 文件操作方法 内容详情 字符编码的简介 # 字符编码主要研究的对象是文本 ...

  10. React中http-proxy-middleware代理使用

    React项目npm run start启动本地服务后浏览器访问http://localhost:3000 start命令也可自定义port指定本地运行端口(eg: PORT=3002) 对于单点登录 ...