scala - 如何连接列表中创建的资源,以便稍后在测试中删除它们作为清理的一部分?
问题描述
我正在执行以下代码以从执行加特林 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,但列表显示了相同的项目。是否有更好的数据结构或选项供我使用?请提供建议,因为我是 gatling 和 scala 的初学者。
解决方案
使用 List 和 var 全局引用是错误的策略,因为它不是线程安全的。
您应该使用 vals 和 a 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))
)
推荐阅读
- vue.js - 如何直接在组件中访问“布局”或“页面”功能?
- c++ - C++ 分而治之的算法问题
- node.js - 使用 Postman 将数据发送到 Google Cloud Function
- rust - 盒子如何
解构自己? - ios - 如何修复 Swift 中的“线程 1:致命错误:在隐式展开可选值时意外发现 nil”错误?
- laravel - 登录 laravel 网站
- postgresql - 使用 boto3 将枚举类型插入 aurora postgres
- verilog - 有效断言在 req-ack 事务中出现一次
- node.js - 快速会话 req.session 不持久
- visual-studio-code - 在 VSCode 中移动火车