根据 Gatling 文档,我可以在执行场景时使用会话属性。
但是,每次我使用函数文本访问场景中的会话时,我最终都会出现以下异常:
[error] java.lang.UnsupportedOperationException: There were no requests sent during the simulation, reports won't be generated
[error] at io.gatling.charts.report.ReportsGenerator$.generateFor(ReportsGenerator.scala:45)
[error] at io.gatling.app.Gatling.generateReports(Gatling.scala:198)
[error] at io.gatling.app.Gatling.start(Gatling.scala:82)
[error] at io.gatling.app.Gatling$.fromArgs(Gatling.scala:59)
[error] at io.gatling.sbt.GatlingTask.liftedTree1$1(GatlingTask.scala:49)
[error] at io.gatling.sbt.GatlingTask.execute(GatlingTask.scala:48)
[error] at sbt.ForkMain$Run$2.call(ForkMain.java:296)
[error] at sbt.ForkMain$Run$2.call(ForkMain.java:286)
[error] at java.util.concurrent.FutureTask.run(FutureTask.java:266)
[error] at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
[error] at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
[error] at java.lang.Thread.run(Thread.java:745)
[error] Simulation FooBarSimulation failed.
[info] Simulation(s) execution ended.
更具体地说,虽然这个符号给了我正确的结果:
val scn = scenario("Foobar").feed(feeder).exec {
http("foo").httpRequest("GET", "http://example.org")
}.pause(5)
此操作失败,但出现上述异常:
val scn = scenario("Foobar").feed(feeder).exec { session =>
http("foo").httpRequest("GET", "http://example.org")
session
}.pause(5)
方案是模拟的计划。因此,当你说val scn = ...
时,你不是在执行模拟,而是在构建一个AST,然后由加特林执行。
所以当你说
val scn = scenario("Foobar").feed(feeder).exec { session =>
http("foo").httpRequest("GET", "http://example.org")
session
}.pause(5)
http("foo").httpRequest("GET", "http://example.org")
部分是一个没有副作用的语句,并且永远不会使用其值。所以它可能不在那里。就加特林而言,您的场景是
val scn = scenario("Foobar").feed(feeder).exec { session =>
session
}.pause(5)
这绝对不执行任何操作,因此在生成报告时会产生错误。
要实现您想要的,会话操作必须是单独的 exec 语句。喜欢这个:
val scn = scenario("Foobar").feed(feeder)
.exec ( session => session.set("foo", "bar") )
.exec (
http("foo").httpRequest("GET", "http://example.org")
)
}.pause(5)