blob: c0eab392d9816ffa341b43d8260fc7bf6827ac12 [file] [log] [blame]
// Copyright (C) 2019 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.google.gerrit.scenarios
import com.github.barbasa.gatling.git.protocol.GitProtocol
import com.github.barbasa.gatling.git.request.builder.GitRequestBuilder
import io.gatling.core.Predef._
import io.gatling.core.structure.ScenarioBuilder
import java.io._
import com.github.barbasa.gatling.git.{
GatlingGitConfiguration,
GitRequestSession
}
import org.apache.commons.io.FileUtils
import scala.concurrent.duration._
import org.eclipse.jgit.hooks._
class ReplayRecordsFromFeederScenario extends Simulation {
val gitProtocol = GitProtocol()
implicit val conf = GatlingGitConfiguration()
implicit val postMessageHook: Option[String] = Some(
s"hooks/${CommitMsgHook.NAME}")
val feeder = jsonFile("data/requests.json").circular
val replayCallsScenario: ScenarioBuilder =
scenario("Git commands")
.repeat(10000) {
feed(feeder)
.exec(new GitRequestBuilder(GitRequestSession("${cmd}", "${url}")))
}
setUp(
replayCallsScenario.inject(
nothingFor(4 seconds),
atOnceUsers(10),
rampUsers(10) during (5 seconds),
constantUsersPerSec(20) during (15 seconds),
constantUsersPerSec(20) during (15 seconds) randomized
))
.protocols(gitProtocol)
.maxDuration(60 seconds)
after {
try {
//After is often called too early. Some retries should be implemented.
Thread.sleep(5000)
FileUtils.deleteDirectory(new File(conf.tmpBasePath))
} catch {
case e: IOException => {
System.err.println(
"Unable to delete temporary directory: " + conf.tmpBasePath)
e.printStackTrace
}
}
}
}