如何在列表中连接创建的资源,以便稍后可以在测试中删除它们作为清理的一部分?



我正在执行以下代码来获取执行加特林 http 请求并将其附加到列表的响应字段,但在响应中,我看到列表主要显示相同的 itemId。我想知道这是否是因为并发?我正在制作此列表,以便我可以在每次创建操作调用后捕获资源,并在测试结束时,可以迭代此列表以执行项目的清理/删除,就像使用 gatling 的"之后"钩子一样。

在模拟课上:

var responseIdList = List[String]() 
val scenario1 = scenario(" TEST ")
.exec(Create())
.exec(session => {
item = session("itemId").as[String].trim
println("%%%%%%%%%%% item ID =====>>>>>>>>>> " + item)
responseIdList = item :: responseIdList
println("%%%%%%%%%%%  List =====>>>>>>>>>> " + responseIdList)
session}
)
setUp(
scenario1.inject(atOnceUsers(5))
)

加特林动作:

def Create():HttpRequestBuilder= {
http("CREATE API")
.post(Host + "/items")
.header("Authorization", "Bearer "+ token)
.header("Content-Type", "application/json")
.body(StringBody(
"""{ "name" : "Item1"
|}""".stripMargin)).asJson
.check(status.is(200))
.check(jsonPath("$.itemId").saveAs("itemId"))
}

这是执行上述代码后的响应:

%%%%%%%%%%% item ID =====>>>>>>>>>> dc7e4024-c51e-46ce-93be-6ba1dad3679e
%%%%%%%%%%% item ID =====>>>>>>>>>> 0bf84d48-ccea-4f10-93b3-ea464adcc952
%%%%%%%%%%% item ID =====>>>>>>>>>> 072361b2-5c49-4641-a27c-c346c01dde99
%%%%%%%%%%% item ID =====>>>>>>>>>> dc7e4024-c51e-46ce-93be-6ba1dad3679e
%%%%%%%%%%% List =====>>>>>>>>>> List(0bf84d48-ccea-4f10-93b3-ea464adcc952, 072361b2-5c49-4641-a27c-c346c01dde99)
%%%%%%%%%%% List =====>>>>>>>>>> List(0bf84d48-ccea-4f10-93b3-ea464adcc952, 0bf84d48-ccea-4f10-93b3-ea464adcc952, 072361b2-5c49-4641-a27c-c346c01dde99)
%%%%%%%%%%% item ID =====>>>>>>>>>> dc7e4024-c51e-46ce-93be-6ba1dad3679e
%%%%%%%%%%%  List =====>>>>>>>>>> List(0bf84d48-ccea-4f10-93b3-ea464adcc952, 0bf84d48-ccea-4f10-93b3-ea464adcc952, 0bf84d48-ccea-4f10-93b3-ea464adcc952, 0bf84d48-ccea-4f10-93b3-ea464adcc952, 072361b2-5c49-4641-a27c-c346c01dde99)

尽管在模拟场景时创建了 5 个不同的项目 ID,但不知何故列表显示了相同的项目。是否有更好的数据结构或选项供我使用?请提供建议,因为我是加特林和斯卡拉的初学者。

使用 List 和 var 全局引用是一种错误的策略,因为它不是线程安全的。

你应该使用 vals 和java.util.concurrent.ConcurrentLinkedQueue

import java.util.concurrent.ConcurrentLinkedQueue
def Create():HttpRequestBuilder= {
http("CREATE API")
.post(Host + "/items")
.header("Authorization", "Bearer "+ token)
.header("Content-Type", "application/json")
.body(StringBody(
"""{ "name" : "Item1"
|}""".stripMargin)).asJson
.check(status.is(200))
.check(jsonPath("$.itemId").saveAs("itemId"))
}
// EDIT: global threadsafe structure stored in an immutable reference
val responseIdList = new java.util.concurrent.ConcurrentLinkedQueue[String]() 
val scenario1 = scenario(" TEST ")
.exec(Create())
.exec(session => {
// EDIT: local val here instead of global var
val item = session("itemId").as[String].trim
println("%%%%%%%%%%% item ID =====>>>>>>>>>> " + item)
responseIdList.offer(item)
// EDIT: print queue content
println("%%%%%%%%%%%  List =====>>>>>>>>>> " + util.Arrays.toString(responseIdList.toArray))
session}
)
setUp(
scenario1.inject(atOnceUsers(5))
)

最新更新