需要解决如下几个问题
1、100个线程(用户)分别执行新增-查询-删除 流程
2、按顺序正确的调用对应的接口
3、不同线程间不能互相影响
解决方案如下
1、临界部分控制器
该控制器可控制每个线程按顺序执行接口。
需要注意【锁名称】,如果【锁】设置不对,测试结果也是不对。
临界部分控制器会先根据【锁名称】锁定控制器下的所有子元素,等到所有子元素都执行完‘锁’才会释放。
因此,当【锁名称】为一个固定的值时,所有线程就变成了串行(即第一个线程请求完才开始第二个线程),而不是并行。这就达不到性能测试的目的。
要解决这个问题,就需要将锁名称设置为动态的,这样每个线程就有了不同的【锁名称】,就可以并行执行了。
我选择使用线程数为锁名称:global_lock_${__threadNum}
__threadNum
函数的作用是返回当前线程组产生的线程的线程编号
2、随机变量
为了不让不同线程间互相影响,起码要每个线程新增的数据不同。
我使用了随机变量来生成数据(也可以考虑使用上面提到的__threadNum
函数)。
如上图,最终生成的变量名为aaa,值的格式为aaa000。其中000会被1到100之间随机生成的数字替换(比如aaa045)。
3、json提取器
删除时需要传入数据id,因为新增接口没有返回id,因此需要先查询,再根据新增时的参数提取数据对应的id,最后调用删除接口。
这里主要总结一下json提取器如何获取指定的值。
语法为:$.lists[?(@.pointNumber=="${aaa}")].id
。
其中?(@.pointNumber=="${aaa}")
为固定格式,${aaa}
是新增时随机变量生成的值。
结果
脚本如下:
结果树:
聚合报告: