How to print values on console

I have a problem with using .exec to print something on console, I have a script

import scala.concurrent.duration._

import io.gatling.core.Predef._
import io.gatling.http.Predef._
import io.gatling.jdbc.Predef._

class logingood extends Simulation {

val httpProtocol = http
.baseUrl(“https://webapi.wage.iteodev.com”)
.inferHtmlResources()
.userAgentHeader(“Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36”)
.proxy(Proxy(“localhost”, 8888).httpsPort(8888))

val headers_0 = Map(
“Accept” → “application/json, text/plain, /”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”)

val headers_1 = Map(
“Access-Control-Request-Headers” → “authorization”,
“Access-Control-Request-Method” → “GET”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”)

val headers_2 = Map(
“Accept” → “application/json, text/plain, /”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”,
“authorization” → “Bearer ${authToken}”)

val headers_3 = Map(“Sec-Fetch-Mode” → “no-cors”)

val headers_7 = Map(
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”,
“content-type” → “application/x-www-form-urlencoded; charset=UTF-8”)

val uri1 = “https://api.wage.iteodev.com/signalr
val uri2 = “https://frontend.iteodev.com/static/media/download-app-headline.a2c2b312.svg

val scn = scenario(“logingood”)
.exec(http(“request_0”)
.post("/api/oauth/token")
.headers(headers_0)
.formParam(“username”, “test@evxmail.net”)
.formParam(“password”, “Zaq1@wsx”)
.formParam(“grant_type”, “password”)
.check(jsonPath("$…access_token").exists.saveAs(“authToken”))
.resources(http(“request_1”)
.options("/api/account")
.headers(headers_1),
http(“request_2”)
.get("/api/account")
.headers(headers_2),
http(“request_3”)
.get(uri2)
.headers(headers_3),
http(“request_4”)
.options("/api/conversations/")
.headers(headers_1),
http(“request_5”)
.get("/api/conversations/")
.headers(headers_2),
http(“request_6”)
.options("/api/notifications")
.headers(headers_1),
http(“request_7”)
.get(uri1 + “/negotiate?clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D”)
.check(regex("""[a-zA-Z0-9=/+]{152}""").find.saveAs(“MyConnectionToken”))
.exec( session => {
println(“Content of MyConnectionToken:”)
println(session(“MyConnectionToken”).as[String])
session
})
.headers(headers_7),
http(“request_8”)
.get("/api/notifications")
.headers(headers_2),
http(“request_9”)

.get(uri1 + “/start?transport=serverSentEvents&clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionToken=${MyConnectionToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D”)
.headers(headers_7)))

setUp(scn.inject(atOnceUsers(1))).protocols(httpProtocol)
}

But when I run it I got following error

How can I use this?

And second question - this script is generated by gatling recorder from har file, should I divide it to smller .exec blocks? If yes how to do this properly?

2 things:

First, exec(function) is misplaced. You can’t chain it with an HTTP request inside a resources block.

Then, what you’re trying to doomed to fail. Requests in a resources block are executed concurrently to a certain degree. It’s likely that request_9 is sent before response of request_7 is received.
The recorder tries its best to guess resources blocks but it you need sequential execution, you must move requests out of resources block.
Starting from request_7, requests should be in their own exec(), not in resources.

You cannot print in exec.
Please use session to print the value.
Read about session concepts in gatling.

I changed it to:

val scn = scenario(“logingood”)
.exec(http(“request_0”)
.post("/api/oauth/token")
.headers(headers_0)
.formParam(“username”, “test@evxmail.net”)
.formParam(“password”, “Zaq1@wsx”)
.formParam(“grant_type”, “password”)
.check(jsonPath("$…access_token").exists.saveAs(“authToken”))
.resources(http(“request_1”)
.options("/api/account")
.headers(headers_1),
http(“request_2”)
.get("/api/account")
.headers(headers_2),
http(“request_3”)
.get(uri2)
.headers(headers_3),
http(“request_4”)
.options("/api/conversations/")
.headers(headers_1),
http(“request_5”)
.get("/api/conversations/")
.headers(headers_2),
http(“request_6”)
.options("/api/notifications")
.headers(headers_1)))

.exec(http(“request_7”)
.get(uri1 + “/negotiate?clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D”)
.check(regex("""[a-zA-Z0-9=/+]{152}""").find.saveAs(“MyConnectionToken”))
.headers(headers_7),
http(“request_8”)
.get("/api/notifications")
.headers(headers_2),
http(“request_9”)
.get(uri1 + “/start?transport=serverSentEvents&clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionToken=${MyConnectionToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D”)
.headers(headers_7))

But I got

W dniu środa, 16 października 2019 13:39:34 UTC+2 użytkownik Jakub Obrocki napisał:

Misplaced parens.

Actually I don’t have any print in my scenario, now my problem is that my test doesn’t compile

W dniu środa, 16 października 2019 13:39:34 UTC+2 użytkownik Jakub Obrocki napisał:

I’m not sure about that, if yes, where? I think all paerns are placed properly

W dniu środa, 16 października 2019 13:39:34 UTC+2 użytkownik Jakub Obrocki napisał:

No you don’t.

import io.gatling.core.Predef._
import io.gatling.http.Predef._

class logingood extends Simulation {

  val httpProtocol = http
    .baseUrl("[https://webapi.wage.iteodev.com](https://webapi.wage.iteodev.com)")
    .inferHtmlResources()
    .userAgentHeader("Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36")
    .proxy(Proxy("localhost", 8888).httpsPort(8888))

  val headers_0 = Map(
    "Accept" -> "application/json, text/plain, */*",
    "Origin" -> "[https://frontend.iteodev.com](https://frontend.iteodev.com)",
    "Sec-Fetch-Mode" -> "cors")

  val headers_1 = Map(
    "Access-Control-Request-Headers" -> "authorization",
    "Access-Control-Request-Method" -> "GET",
    "Origin" -> "[https://frontend.iteodev.com](https://frontend.iteodev.com)",
    "Sec-Fetch-Mode" -> "cors")

  val headers_2 = Map(
    "Accept" -> "application/json, text/plain, */*",
    "Origin" -> "[https://frontend.iteodev.com](https://frontend.iteodev.com)",
    "Sec-Fetch-Mode" -> "cors",
    "authorization" -> "Bearer ${authToken}")

  val headers_3 = Map("Sec-Fetch-Mode" -> "no-cors")

  val headers_7 = Map(
    "Origin" -> "[https://frontend.iteodev.com](https://frontend.iteodev.com)",
    "Sec-Fetch-Mode" -> "cors",
    "content-type" -> "application/x-www-form-urlencoded; charset=UTF-8")

  val uri1 = "[https://api.wage.iteodev.com/signalr](https://api.wage.iteodev.com/signalr)"
  val uri2 = "[https://frontend.iteodev.com/static/media/download-app-headline.a2c2b312.svg](https://frontend.iteodev.com/static/media/download-app-headline.a2c2b312.svg)"

  val scn = scenario("logingood")
    .exec(
      http("request_0")
        .post("/api/oauth/token")
        .headers(headers_0)
        .formParam("username", "[test@evxmail.net](mailto:test@evxmail.net)")
        .formParam("password", "Zaq1@wsx")
        .formParam("grant_type", "password")
        .check(jsonPath("$..access_token").exists.saveAs("authToken"))
        .resources(
          http("request_1")
            .options("/api/account")
            .headers(headers_1),
          http("request_2")
            .get("/api/account")
            .headers(headers_2),
          http("request_3")
            .get(uri2)
            .headers(headers_3),
          http("request_4")
            .options("/api/conversations/")
            .headers(headers_1),
          http("request_5")
            .get("/api/conversations/")
            .headers(headers_2),
          http("request_6")
            .options("/api/notifications")
            .headers(headers_1)
        )
    )
    .exec(
      http("request_7")
        .get(uri1 + "/negotiate?clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D")
        .headers(headers_7)
        .check(regex("""[a-zA-Z0-9=\/+]{152}""").find.saveAs("MyConnectionToken"))
    )
    .exec { session =>
      println("Content of MyConnectionToken:")
      println(session("MyConnectionToken").as[String])
      session
    }
    .exec(
      http("request_8")
        .get("/api/notifications")
        .headers(headers_2)
    )
    .exec(
      http("request_9")
        .get(uri1 + "/start?transport=serverSentEvents&clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionToken=${MyConnectionToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D")
        .headers(headers_7)
    )

  setUp(scn.inject(atOnceUsers(1))).protocols(httpProtocol)
}

But I removed some code, here is actual:

import scala.concurrent.duration._

import io.gatling.core.Predef._
import io.gatling.http.Predef._
import io.gatling.jdbc.Predef._

class logingood extends Simulation {

val httpProtocol = http
.baseUrl(“https://webapi.wage.iteodev.com”)
.inferHtmlResources()
.userAgentHeader(“Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36”)
.proxy(Proxy(“localhost”, 8888).httpsPort(8888))

val headers_0 = Map(
“Accept” → “application/json, text/plain, /”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”)

val headers_1 = Map(
“Access-Control-Request-Headers” → “authorization”,
“Access-Control-Request-Method” → “GET”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”)

val headers_2 = Map(
“Accept” → “application/json, text/plain, /”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”,
“authorization” → “Bearer ${authToken}”)

val headers_3 = Map(“Sec-Fetch-Mode” → “no-cors”)

val headers_7 = Map(
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”,
“content-type” → “application/x-www-form-urlencoded; charset=UTF-8”)

val uri1 = “https://api.wage.iteodev.com/signalr
val uri2 = “https://frontend.iteodev.com/static/media/download-app-headline.a2c2b312.svg

val scn = scenario(“logingood”)
.exec(http(“request_0”)
.post("/api/oauth/token")
.headers(headers_0)
.formParam(“username”, “test@evxmail.net”)
.formParam(“password”, “Zaq1@wsx”)
.formParam(“grant_type”, “password”)
.check(jsonPath("$…access_token").exists.saveAs(“authToken”))
.resources(http(“request_1”)
.options("/api/account")
.headers(headers_1),
http(“request_2”)
.get("/api/account")
.headers(headers_2),
http(“request_3”)
.get(uri2)
.headers(headers_3),
http(“request_4”)
.options("/api/conversations/")
.headers(headers_1),
http(“request_5”)
.get("/api/conversations/")
.headers(headers_2),
http(“request_6”)
.options("/api/notifications")
.headers(headers_1)))

.exec(http(“request_7”)
.get(uri1 + “/negotiate?clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D”)
.headers(headers_7),
http(“request_8”)
.get("/api/notifications")
.headers(headers_2),
http(“request_9”)
.get(uri1 + “/start?transport=serverSentEvents&clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionToken=${MyConnectionToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D”)
.headers(headers_7))

setUp(scn.inject(atOnceUsers(1))).protocols(httpProtocol)
}

W dniu środa, 16 października 2019 13:39:34 UTC+2 użytkownik Jakub Obrocki napisał:

Does anybody have an idea why following code

import scala.concurrent.duration._

import io.gatling.core.Predef._
import io.gatling.http.Predef._
import io.gatling.core.structure.{ChainBuilder, ScenarioBuilder}
import io.gatling.commons.validation._

class logingood extends Simulation {

val httpProtocol = http
.baseUrl(“https://webapi.wage.iteodev.com”)
.inferHtmlResources()
.userAgentHeader(“Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36”)
.proxy(Proxy(“localhost”, 8888).httpsPort(8888))

val headers_0 = Map(
“Accept” → “application/json, text/plain, /”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”)

val headers_1 = Map(
“Access-Control-Request-Headers” → “authorization”,
“Access-Control-Request-Method” → “GET”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”)

val headers_2 = Map(
“Accept” → “application/json, text/plain, /”,
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”,
“authorization” → “Bearer ${authToken}”)

val headers_3 = Map(“Sec-Fetch-Mode” → “no-cors”)

val headers_7 = Map(
“Origin” → “https://frontend.iteodev.com”,
“Sec-Fetch-Mode” → “cors”,
“content-type” → “application/x-www-form-urlencoded; charset=UTF-8”)

val uri1 = “https://api.wage.iteodev.com/signalr
val uri2 = “https://frontend.iteodev.com/static/media/download-app-headline.a2c2b312.svg

val scn = scenario(“logingood”)
.exec(http(“request_0”)
.post("/api/oauth/token")
.headers(headers_0)
.formParam(“username”, “test@evxmail.net”)
.formParam(“password”, “Zaq1@wsx”)
.formParam(“grant_type”, “password”)
.check(jsonPath("$…access_token").exists.saveAs(“authToken”))
.resources(http(“request_1”)
.options("/api/account")
.headers(headers_1),
http(“request_2”)
.get("/api/account")
.headers(headers_2),
http(“request_3”)
.get(uri2)
.headers(headers_3),
http(“request_4”)
.options("/api/conversations/")
.headers(headers_1),
http(“request_5”)
.get("/api/conversations/")
.headers(headers_2),
http(“request_6”)
.options("/api/notifications")
.headers(headers_1)))

.exec(http(“request_7”)
.get(uri1 + “/negotiate?clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D”)
.headers(headers_7),
http(“request_8”)
.get("/api/notifications")
.headers(headers_2),
http(“request_9”)
.get(uri1 + “/start?transport=serverSentEvents&clientProtocol=1.5&Authorization=Bearer%20${authToken}&connectionToken=${MyConnectionToken}&connectionData=%5B%7B%22name%22%3A%22livechat%22%7D%5D”)
.headers(headers_7))

setUp(scn.inject(atOnceUsers(1))).protocols(httpProtocol)
}

throws following error

GATLING_HOME is set to “C:\Gatling”
JAVA = ““C:\Program Files\Java\jdk-12\bin\java.exe””
09:34:03.518 [ERROR] i.g.c.ZincCompiler$ - C:\Gatling\user-files\simulations\logingood.scala:74:21: type mismatch;
found : io.gatling.http.request.builder.HttpRequestBuilder
required: io.gatling.core.structure.Execs[]
.headers(headers_7),
^
09:34:03.527 [ERROR] i.g.c.ZincCompiler$ - C:\Gatling\user-files\simulations\logingood.scala:77:21: type mismatch;
found : io.gatling.http.request.builder.HttpRequestBuilder
required: io.gatling.core.structure.Execs[
]
.headers(headers_2),
^
09:34:03.528 [ERROR] i.g.c.ZincCompiler$ - C:\Gatling\user-files\simulations\logingood.scala:80:21: type mismatch;
found : io.gatling.http.request.builder.HttpRequestBuilder
required: io.gatling.core.structure.Execs[_]
.headers(headers_7))
^
09:34:03.620 [ERROR] i.g.c.ZincCompiler$ - three errors found
09:34:03.626 [ERROR] i.g.c.ZincCompiler$ - Compilation crashed
sbt.internal.inc.CompileFailed: null
at sbt.internal.inc.AnalyzingCompiler.call(AnalyzingCompiler.scala:253)
at sbt.internal.inc.AnalyzingCompiler.compile(AnalyzingCompiler.scala:122)
at sbt.internal.inc.AnalyzingCompiler.compile(AnalyzingCompiler.scala:95)
at sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile$4(MixedAnalyzingCompiler.scala:91)
at scala.runtime.java8.JFunction0$mcV$sp.apply(JFunction0$mcV$sp.java:23)
at sbt.internal.inc.MixedAnalyzingCompiler.timed(MixedAnalyzingCompiler.scala:186)
at sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile$3(MixedAnalyzingCompiler.scala:82)
at sbt.internal.inc.MixedAnalyzingCompiler.$anonfun$compile$3$adapted(MixedAnalyzingCompiler.scala:77)
at sbt.internal.inc.JarUtils$.withPreviousJar(JarUtils.scala:215)
at sbt.internal.inc.MixedAnalyzingCompiler.compileScala$1(MixedAnalyzingCompiler.scala:77)
at sbt.internal.inc.MixedAnalyzingCompiler.compile(MixedAnalyzingCompiler.scala:146)
at sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileInternal$1(IncrementalCompilerImpl.scala:343)
at sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileInternal$1$adapted(IncrementalCompilerImpl.scala:343)
at sbt.internal.inc.Incremental$.doCompile(Incremental.scala:120)
at sbt.internal.inc.Incremental$.$anonfun$compile$4(Incremental.scala:100)
at sbt.internal.inc.IncrementalCommon.recompileClasses(IncrementalCommon.scala:180)
at sbt.internal.inc.IncrementalCommon.cycle(IncrementalCommon.scala:98)
at sbt.internal.inc.Incremental$.$anonfun$compile$3(Incremental.scala:102)
at sbt.internal.inc.Incremental$.manageClassfiles(Incremental.scala:155)
at sbt.internal.inc.Incremental$.compile(Incremental.scala:92)
at sbt.internal.inc.IncrementalCompile$.apply(Compile.scala:75)
at sbt.internal.inc.IncrementalCompilerImpl.compileInternal(IncrementalCompilerImpl.scala:348)
at sbt.internal.inc.IncrementalCompilerImpl.$anonfun$compileIncrementally$1(IncrementalCompilerImpl.scala:301)
at sbt.internal.inc.IncrementalCompilerImpl.handleCompilationError(IncrementalCompilerImpl.scala:168)
at sbt.internal.inc.IncrementalCompilerImpl.compileIncrementally(IncrementalCompilerImpl.scala:248

at sbt.internal.inc.IncrementalCompilerImpl.compile(IncrementalCompilerImpl.scala:74)
at io.gatling.compiler.ZincCompiler$.doCompile(ZincCompiler.scala:210)
at io.gatling.compiler.ZincCompiler$.delayedEndpoint$io$gatling$compiler$ZincCompiler$1(ZincCompiler.scala:215)
at io.gatling.compiler.ZincCompiler$delayedInit$body.apply(ZincCompiler.scala:39)
at scala.Function0.apply$mcV$sp(Function0.scala:39)
at scala.Function0.apply$mcV$sp$(Function0.scala:39)
at scala.runtime.AbstractFunction0.apply$mcV$sp(AbstractFunction0.scala:17)
at scala.App.$anonfun$main$1$adapted(App.scala:80)
at scala.collection.immutable.List.foreach(List.scala:392)
at scala.App.main(App.scala:80)
at scala.App.main$(App.scala:78)
at io.gatling.compiler.ZincCompiler$.main(ZincCompiler.scala:39)
at io.gatling.compiler.ZincCompiler.main(ZincCompiler.scala)
Java HotSpot™ 64-Bit Server VM warning: Ignoring option AggressiveOpts; support was removed in 12.0
Choose a simulation number:
W dniu środa, 16 października 2019 13:39:34 UTC+2 użytkownik Jakub Obrocki napisał: