Question

I am working on a test script, testing a REST interface in Gatling using Scala.

For a specific REST resource, this is what I would like to achieve:

  1. Get the resource (which will give me JSON data in the body).
  2. Use jsonpath to change a value in the body.
  3. Post the modified body back to the same url

I have managed to success with 1 and 3. The only problem left is to change the json data which seem to be in string format.

Test steps

object WebTestCollection {


    def getAccountDetails() = http("Get account")
      .get("/account")
      .check(jsonPath("$.billingAccount").saveAs("accountjson"))


    def postNewAccountDetails() = http("Post modified account")
      .post("/account").asJSON
      .body("${accountjson}")

}

Part of the scenario

val scn = scenario("Web Usage")
    .feed(testRuns)


        .exec(WebTestCollection.getAccountDetails())
        .exitHereIfFailed

        .exec(session => {
              var account = session.getAttribute("accountjson")
              account.notes = "Performance Test Comment"
              println(account)
              session.setAttribute("accountjson", account)
          }
        )       

        .exec(WebTestCollection.postNewAccountDetails())
        .exitHereIfFailed

I get the following errors

09:59:30.267 [ERROR] c.e.e.g.a.ZincCompiler$ - <snip>/WebScenario.scala:172: value notes is not a member of Any
09:59:30.268 [ERROR] c.e.e.g.a.ZincCompiler$ -            account.notes = "Performance Test Comment"
09:59:30.269 [ERROR] c.e.e.g.a.ZincCompiler$ -                                   ^
09:59:30.664 [ERROR] c.e.e.g.a.ZincCompiler$ - one error found
java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at scala_maven_executions.MainHelper.runMain(MainHelper.java:164)
    at scala_maven_executions.MainWithArgsInFile.main(MainWithArgsInFile.java:26)
Caused by: Compilation failed
    at sbt.compiler.AnalyzingCompiler.call(AnalyzingCompiler.scala:76)
    at sbt.compiler.AnalyzingCompiler.compile(AnalyzingCompiler.scala:35)
    at sbt.compiler.AnalyzingCompiler.compile(AnalyzingCompiler.scala:29)
    at sbt.compiler.AggressiveCompile$$anonfun$4$$anonfun$compileScala$1$1.apply$mcV$sp(AggressiveCompile.scala:71)
    at sbt.compiler.AggressiveCompile$$anonfun$4$$anonfun$compileScala$1$1.apply(AggressiveCompile.scala:71)
    at sbt.compiler.AggressiveCompile$$anonfun$4$$anonfun$compileScala$1$1.apply(AggressiveCompile.scala:71)
    at sbt.compiler.AggressiveCompile.sbt$compiler$AggressiveCompile$$timed(AggressiveCompile.scala:101)
    at sbt.compiler.AggressiveCompile$$anonfun$4.compileScala$1(AggressiveCompile.scala:70)
    at sbt.compiler.AggressiveCompile$$anonfun$4.apply(AggressiveCompile.scala:88)
    at sbt.compiler.AggressiveCompile$$anonfun$4.apply(AggressiveCompile.scala:60)
    at sbt.inc.IncrementalCompile$$anonfun$doCompile$1.apply(Compile.scala:24)
    at sbt.inc.IncrementalCompile$$anonfun$doCompile$1.apply(Compile.scala:22)
    at sbt.inc.Incremental$.cycle(Incremental.scala:52)
    at sbt.inc.Incremental$.compile(Incremental.scala:29)
    at sbt.inc.IncrementalCompile$.apply(Compile.scala:20)
    at sbt.compiler.AggressiveCompile.compile2(AggressiveCompile.scala:96)
    at sbt.compiler.AggressiveCompile.compile1(AggressiveCompile.scala:44)
    at com.typesafe.zinc.Compiler.compile(Compiler.scala:158)
    at com.typesafe.zinc.Compiler.compile(Compiler.scala:142)
    at com.excilys.ebi.gatling.app.ZincCompiler$.apply(ZincCompiler.scala:104)
    at com.excilys.ebi.gatling.app.SimulationClassLoader$.fromSourcesDirectory(SimulationClassLoader.scala:34)
    at com.excilys.ebi.gatling.app.Gatling$$anonfun$12.apply(Gatling.scala:89)
    at com.excilys.ebi.gatling.app.Gatling$$anonfun$12.apply(Gatling.scala:89)
    at scala.Option.getOrElse(Option.scala:108)
    at com.excilys.ebi.gatling.app.Gatling.start(Gatling.scala:89)
    at com.excilys.ebi.gatling.app.Gatling$.fromMap(Gatling.scala:54)
    at com.excilys.ebi.gatling.app.Gatling$.runGatling(Gatling.scala:74)
    at com.excilys.ebi.gatling.app.Gatling$.main(Gatling.scala:49)
    at com.excilys.ebi.gatling.app.Gatling.main(Gatling.scala)
    ... 6 more
Was it helpful?

Solution

Only current Gatling 2 snapshot let you save JsonPath result into something else than String:

jsonPath(expression).ofType[T]

But then, we don't currently have a facility for editing and then re-serializing a JSON AST. We ship JSON parsers (Boon and Jackson) so you can probably achieve this yourself. You can also open a feature request.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top