全局设置
Add->Config Element->User Defined Variables
-
- 用户自定义变量
- name->value格式
- 后面通过 \${xxx}方式引用变量
Add -> Pre Processor -> BeanShell PreProcessor
-
- 通过代码形式或者shell脚本形式在请求前定义变量
- shell脚本文件 或者 编写Java 脚本定义变量
Add->Config Element-> Http Header Manager
-
- 全局设置请求header信息
- name->value格式
- 后面请求自动会带上此header信息,header中通过\${xxx}可引用变量
请求接口
公共组件
-
- Add -> Logic Controller -> Once Only Controller
- 仅执行一次,入口controller
- 入口事务型controller
- Add -> Logic Controller -> Transaction Controller
- 入口事务型controller
- Add -> Assertions ->Response Assertion
- 断言
- Text Response->Contains-> "code":200
- Add->PostProcessors-> Regular Expression Extrator
- 对请求结果进行正则解析
- Main sample only -> Body
- Name of created varible : 如 dnId
- Regular Expression :data":"(.*?)"
- Template(\$i\$ where i is caputuring group number,starts at 1) : \$1\$
- Match No.(0 for Random): 0
- Add->PostProcessors-> BeanShell PostProcessor
- 接口请求后通过编写代码设置变量
- 代码示例
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import org.apache.logging.slf4j.Log4jLogger; String response = prev.getResponseDataAsString(); log.info("response:"+response); //获取请求返回值。赋予字符串String 变量 JSONObject jsonObject = JSONObject.parseObject(response); if(jsonObject == null){ vars.put("tool",null); return; } String data= jsonObject.get("data").toString(); log.info("data:"+data); String tool,highLightStep; JSONArray objects = JSON.parseArray(data); for (Object object: objects){ Object o = ((JSONObject) object).get("processTool"); if(tool == null || "".equals(tool) || highLightStep == null || "".equals(highLightStep)){ tool = o; highLightStep = ""+((JSONObject) object).get("stepSeq"); } if("BLOVL01".equals(o)){ } } //若获取不到值,赋予默认值 if(tool == null || "".equals(tool) || highLightStep == null || "".equals(highLightStep)){ tool = "BLOVL01"; highLightStep = "118700"; } vars.put("tool",""+o); vars.put("highLightStep",highLightStep);
- String response = prev.getResponseDataAsString(); 获取接口请求response
- vars.put("tool",""+o); 设置全局变量参数 tool
- vars.get("name"); 获取全局变量参数name
- 备注:编写Java程序在jmeter中无法编译,可在idea中编写好后拷贝进来;如果有些jar包没有则需要提前下载好放入到lib目录下
- Add->PostProcessors-> Debug PostProcessor
- 对接口请求后进行调试
- 一般在前步骤设置变量,在该步骤设置调试,在最后查看结果中即可查看变量是否设置成功
- Add->PostProcessors-> JSON Extractor
- 对请求结果进行json解析
- Main sample only
- Name of created varible : 如 dnId
- JSON Path Expressions :\$.data[*].id
- Match No.(0 for Random): 0
- Add -> Listener -> View Results Tree
- 查看结果树
- 可设置在接口请求后
- Add -> Logic Controller -> Once Only Controller
HTTP请求
-
- Add -> Sampler -> Http Requesthttp请求组件ip、端口、入参等设置
- http请求组件
- ip、端口、入参等设置
- Add -> Sampler -> Http Requesthttp请求组件ip、端口、入参等设置
GRPC
-
- 放入jmeter安装目录的lib/ext目录下
- https://github.com/zalopay-oss/jmeter-grpc-request
- 放入jmeter安装目录的lib/ext目录下
- Add -> Sampler -> Grpc Request
- grpc请求组件
- 设置ip、端口、proto契约、method、入参等
- 放入jmeter安装目录的lib/ext目录下
自定义jmeter插件
本地调试jmeter插件项目代码
-
- 新增Configuration,如 idea工具新增Remote JVM Debug
- Host-localhost
- Port-5005
- 在bin目录下执行jmeter启动命令:
- java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -jar ApacheJMeter.jar
- 在idea中通过debug模式启动监听程序,并在需要调试的地方打上断点
- 在jmeter启动页面添加自定义插件并设置好相关参数,点击启动并可以看到断点执行情况了
- 新增Configuration,如 idea工具新增Remote JVM Debug