如何在Gatling中将提取的数据写入文件

时间:2014-02-11 13:28:18

标签: performance-testing scala-collections gatling

我正在使用Gatling进行负载测试。在创建客户配置文件时,将生成客户ID。我能够提取客户ID并保存到会话变量中。

但如何将这些值存储到文本文件中。

请帮帮我。

4 个答案:

答案 0 :(得分:2)

有几种方法可以实现这一目标。

如果您熟悉Scala,您可以:

如果这对您来说太复杂,最简单的方法是使用logback:

  • 使用特殊名称
  • 在模拟中声明记录器
  • 配置logback,以便此记录器在专用的FileAppender
  • 中输出
  • 使用仅记录消息的模式

关于第二个解决方案,请查看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
  })
}