空手道加特林的maxDuration似乎无法正常工作

时间:2020-02-17 08:04:39

标签: karate

我正在使用4个功能文件(SIM_ACTIVE_USERS = 200,SIM_RAMP_UP_PERIOD = 10)运行模拟。我希望使用以下代码在10秒内完成仿真:

class TestGatlingScalaSimulation extends Simulation {

  val log: Logger = LoggerFactory.getLogger(classOf[TestGatlingScalaSimulation])

  /*val environmentVars = System.getenv().asScala
  for ((k,v) <- environmentVars) println(s"key: $k, value: $v")*/

  val properties: mutable.Map[String, String] = System.getProperties.asScala
  //for ((k,v) <- properties) println(s"key: $k, value: $v")
  val activeUsers: Int = properties.getOrElse("SIM_ACTIVE_USERS", "10").asInstanceOf[String].toInt
  val period: Int = properties.getOrElse("SIM_RAMP_UP_PERIOD", "10").asInstanceOf[String].toInt
  val karateFeatureFiles: List[String] = properties.getOrElse("SIM_FEATURE", "karate/example.feature").split(",").map(_.trim).toList

  val protocol: KarateProtocol = karateProtocol()

  protocol.nameResolver = (req, ctx) => req.getHeader("karate-name")

  val scenarios: List[PopulationBuilder] = karateFeatureFiles.map(karateFeatureFile => {
    val create: ScenarioBuilder = scenario(karateFeatureFile).exec(karateFeature(s"classpath:$karateFeatureFile"))
    log.info("Running simulation of feature [{}] with [{}] users ramped up in [{}]", karateFeatureFile, activeUsers.toString, period.toString)
    create.inject(atOnceUsers(activeUsers)).protocols(protocol)
  })

  setUp(
    scenarios
  ).maxDuration(period seconds)
}

但是它只能在7分钟内完成:

BUILD SUCCESSFUL in 7m 0s
6 actionable tasks: 1 executed, 5 up-to-date

这是我运行gradle任务的方式:

./gradlew -Pgatling_simulation=performance.TestGatlingScalaSimulation -DSIM_ACTIVE_USERS=200 -DSIM_RAMP
_UP_PERIOD=10 -DSIM_FEATURE="karate/flight/one.feature,karate/flight/two.feature,karate/flight/three.feature,kara
te/flight/four.feature" gatlingRun

加特林的报告: enter image description here

0 个答案:

没有答案