主要有两种情况:
同一线程组,不同的请求之间,需要关联。
请求B失败了(因为需要关联),那么从请求B之前的请求,比如请求A,并且从响应数据中,
寻找需要关联的内容,比如token、sessionid等,关联之后,作为请求B的请求数据,再次提交B请求
在请求A上右键--添加---后置处理器---边界提取器
把请求B参数中的实际的token,用关联的token变量来替换
再次运行,关联成功,请求B成功。
2.不同线程组,不同的请求之间,有依赖关系。
测试计划结构如下:
由上图可以看出,线程组1中,有登陆接口;线程组2中,有加入购物车接口。
加入购物车请求,需要cookie,如果拿不到,就代表没有登陆,也就无法加入购物车。
一般来说,添加HTTP Cookie Manager就可以。由上图可以看到,已经添加了,跟两个线程组是并列的。
但是,运行之后,先执行的加入购物车接口,再执行的登陆接口,这就导致加入购物车时还没有登陆。
为什么没有按照顺序执行线程1和线程2呢?
这是因为,如果测试计划下有多个线程组时,他们不是顺序执行,是同时执行,不一定是谁先谁后。
那么,怎么样让他们按照严格的顺序来执行呢?
在测试计划下,勾选“独立运行每个线程组”,就可以让这俩按照顺序执行了。
勾选之后,再次运行,严格按照顺序执行了。
但是,加入购物车请求时,仍提示去登陆。为什么呢?
这是因为,线程组1登陆请求的cookie,它是一个线程变量,是局部变量,作用域是它所在的线程组。
那么,怎么让它作用于它之外的线程组呢?
思路:把这个线程变量的值使用vars.get()取出来,然后利用props.put()放到全局变量中。
需要注意:放入之后,需要重启jmeter,属性才能生效(线程变量无需重启)。
重启之后,另一个线程组就可以访问这个全局变量了。
操作如下:
在线程组1中,对于登陆请求,添加后置处理器---BeanShell PostProcessor,代码如下:
上图可以看出,调整了HTTP Cookie Manager的位置,把它移动到线程1下面,但无需配置cookie
在线程组2下面,也添加了一个HTTP Cookie Manager,用来获取属性(全局变量)cookie22中的值。
利用函数__P 或者 __property,取出属性(也就是这个全局变量)cookie22的值。
注意:这里,不能使用${}这种格式来取值,因为这是属性,不是变量,所以这里只能使用函数了
然后,在HTTP Cookie管理器中,添加这个cookie(JSESSIONID),并粘贴上函数字符串
运行,加入购物车成功。