我正在使用Gatling进行负载测试。在创建客户配置文件时,将生成客户ID。我能够提取客户ID并保存到会话变量中。
但如何将这些值存储到文本文件中。
请帮帮我。
答案 0 :(得分:2)
有几种方法可以实现这一目标。
如果您熟悉Scala,您可以:
如果这对您来说太复杂,最简单的方法是使用logback:
关于第二个解决方案,请查看logback文档:http://logback.qos.ch/documentation.html
答案 1 :(得分:1)
从2.0.0-M1开始,infoExtractor hook接受一个Session参数: https://github.com/excilys/gatling/issues/1004
还有一个内置函数,可在请求失败时将Session内容添加到simulation.log记录中。 https://github.com/excilys/gatling/commit/b7b6299c658d0aa1b88971208eb0c98a9808e37f
如果您只想使用logback进行日志记录,则可以调整此示例。
class MySimulation extends Simulation with Logging {
def logSessionOnFailure(status: RequestStatus, session: Session, request: Request, response: ExtendedResponse): List[String] = {
if (status == KO) logger.error(session)
Nil
}
val httpConf = http
...
.extraInfoExtractor(logSessionOnFailure)
...
}
答案 2 :(得分:1)
另一种可能性(未经测试但可行)是使用响应变换器(在 .post 之后调用 .transformResponse )。在变换器主体中,您将获得一个响应对象,您可以从中提取生成的ID并将其附加到文件,集合等中。然后只返回原始响应作为转换结果。然而,从设计的角度来看,这不是一个非常好的解决方案,因为您的转换会产生副作用。
答案 3 :(得分:0)
在下面的示例中,我将从SOAP响应中保存提取的 NumberIDs ,然后将其保存到 numbersIDs.csv 文件中,以便可以将其输入另一个请求。
//Variables to store the extracted values of the response
var numberIDs : Seq[String] = _
//Java Writer
val numberIDs_writer = {
val fos = new java.io.FileOutputStream("numbersIDs.csv")
new java.io.PrintWriter(fos,true)
}
val scn = scenario("basicSimulation")
.exec(http("Request_One")
.post("/services")
.body(StringBody(inputXMLpayLoad))
.headers(Request_One_Header)
.check(bodyString.saveAs("Request_Response")) //Save the response in a variable called Request_Response
.check((status.is(200)))
//Extract all numberIDs of the SOAP response
.check(regex("""<NumberId>([\d]+)</NumberId>""")
.findAll
.transform { string => numberIDs = string; string }
.saveAs("numberIDs")))
//Save variable numberIDs into the csv file
.foreach("${numberIDs}", "id") {
exec(session => {
numberIDs_writer.println(session("id").as[String])
session
})
}