线程组之间的JMeter传递变量
下面,我们将看看如何在线程组之间共享和传递变量。
在开发高级JMeter脚本时,很可能您将拥有多个线程组。每个线程组将执行不同的请求。
一个很好的例子是我们需要使用Bearer Tokens对用户进行身份验证。一个线程组执行身份验证并保存令牌。另一个线程组需要访问此令牌并在另一个请求中使用它。
因此,我们需要一种在线程组之间传递变量的机制。
在JMeter中传递线程组之间的变量
对于此示例,我们的测试计划将具有两个线程组。第一个线程组向Web服务发出GET请求。然后,我们使用JSON Extractor插件来解析JSON响应。
使用JSONPath,我们提取特定键的值并将其保存为JMeter变量。
这就是我们的JMeter请求的样子:
上述请求的结果以JSON格式生成以下响应
和我们的JSONPath提取第一个url看起来像
JSONPath查询的值保存为first_url
。此变量只能在同一个线程组中访问,我们可以通过使用获取其值${first_url}
。现在,我们如何通过其他线程组访问此变量?
答案是用于BeanShell Assertion
将变量保存为全局属性。通过这种方式,我们可以在线程组之间传递变量。
要添加BeanShell断言,请右键单击Test Plan> Add> Assertion> BeanShell Assertion
在我们的BeanShell断言中,我们可以输入以下代码
${__setProperty(first_url, ${first_url})};
现在在线程组2中,我们可以使用${__property(first_url)}
如下所示直接访问此变量:
如果对软件测试、接口测试、自动化测试、性能测试、LR脚本开发、面试经验交流。感兴趣可以175317069,群内会有不定期的发放免费的资料链接,这些资料都是从各个技术网站搜集、整理出来的,如果你有好的学习资料可以私聊发我,我会注明出处之后分享给大家。
或者,我们可以使用BeanShell PreProcessor来操作变量
在BeanShell PreProcessor中,我们可以通过使用来访问从另一个Thread组传入的变量props.get("name_of_variable")
。然后我们可以执行一些String操作并将结果保存为新变量。
在上面的例子中,我们http://
从Thread Group 1传递的变量中删除了,我们将结果保存为变量host
。
该变量host
现在是线程组2的本地变量,并使用${host}
如下所示直接访问它:
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
集成测试——Spring TestContext框架支持详细解说
概述 集成测试是在单元测试之上,通常是将一个或多个已进行过单元测试的组件组合起来完成的,即集成测试中一般不会出现Mock对象,都是实实在在的真实实现。 对于单元测试,如前边在进行数据访问层单元测试时,通过Mock HibernateTemplate对象然后将其注入到相应的DAO实现,此时单元测试只测试某层的某个功能是否正确,对其他层如何提供服务采用Mock方式提供。 对于集成测试,如要进行数据访问层集成测试时,需要实实在在的HibernateTemplate对象然后将其注入到相应的DAO实现,此时集成测试将不仅测试该层功能是否正确,还将测试服务提供者提供的服务是否正确执行。 使用Spring的一个好处是能非常简单的进行集成测试,无需依赖web服务器或应用服务器即可完成测试。Spring通过提供一套TestContext框架来简化集成测试,使用TestContext测试框架能获得许多好处,如Spring IoC容器缓存、事务管理、依赖注入、Spring测试支持类等等。 Spring TestContext框架支持 Spring TestContext框架提供了一些通用的集成测试支持,主要...
- 下一篇
vue 组件高级用法实例详解
一、递归组件 组件在它的模板内可以递归地调用自己, 只要给组件设置name 的选项就可以了。 示例如下: <div id="app19"> <my-component19 :count="1"></my-component19> </div> Vue.component('my-component19',{ name: 'my-component19', //其实当你利用 Vue.component 全局注册了一个组件,全局的ID会被自动设置为组件的name。 props: { count: { type: Number, default: 1 } }, template: '<div><my-component19 :count="count+1" v-if="count<3"></my-component19></div>' }); var app19 = new Vue({ el: '#app19' }); //前端全栈学习交流圈:866109386 //面向1-3经验年前端开发...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS关闭SELinux安全模块
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Linux系统CentOS6、CentOS7手动修改IP地址
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- Red5直播服务器,属于Java语言的直播服务器