Сценарий случайной выборки скрипта gatling scala

Я использую сценарий ниже, он должен отправить почтовый запрос, содержащий некоторые данные, которые читаются из файла. Я хочу рандомизировать запросы, поэтому иногда он отправляет «R1_BINFile_0», а иногда «R2_Binfile_1». По какой-то причине он не работает и отправляет всегда один и тот же запрос

package computerdatabase

import io.gatling.core.Predef._
import io.gatling.http.Predef._
import scala.concurrent.duration._

class MYSimulation extends Simulation {

  val feeder = csv("CsvConfigFile.csv").circular
  val PATH = sys.env("GATLING_HOME")

  val httpConf = http
    .baseURL("https://HOST") // Here is the root for all relative URLs
    .acceptHeader("text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8") 
    .acceptCharsetHeader("UTF-8")
    .acceptLanguageHeader("en-US,en;q=0.5")
    .acceptEncodingHeader("gzip, deflate")
    .userAgentHeader("Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:16.0) Gecko/20100101 Firefox/16.0")

   val headers_10 = Map("Content-Type" -> "application/octet-stream") 
   val rnd = new scala.util.Random
   val scn = scenario("Scenario1")
      .feed(feeder)
      .doIfOrElse(rnd.nextInt(100) > 50) {
         exec(http("R1")
               .post("https://HOST/web/")
               .headers(headers_10)
               .body(RawFileBody(PATH  + "\\user-files\\data\\" + "${R1_BinFile}" + "_0")))
      } {
         .exec(http("R1")
               .post("https://HOST/web/")
               .headers(headers_10)
               .body(RawFileBody(PATH  + "\\user-files\\data\\" + "${R1_BinFile}" + "_1")))
      }


    setUp(scn.inject(constantUsersPerSec(5) during (100 seconds)).protocols(httpConf))
}

person Liad    schedule 17.11.2015    source источник


Ответы (1)


Проблема в том, что аргумент doIfOrElse выполняется только один раз, поэтому становится константой и каждый раз выбирается одна и та же ветвь. Попробуйте вместо этого передать функцию, которая будет выполняться для каждого запроса:

.doIfOrElse(_ => rnd.nextInt(100) > 50) 

Вы также можете использовать randomSwitch вместо doIfOrElse, что дает более чистый синтаксис для того, к чему вы стремитесь.

person jazmit    schedule 17.11.2015