Reputation: 2067
I have a file with a Json request bodies in a file. I'd like to benchmark a web sending a constant number of requests per second, using the constantUsersPerSec(..).
However, every time a request is sent, I would like it to be taken from a list of requests (randomly, or in a loop, I don't care).
I cannot figure out how to do it with Gatling. Using the following code the request is randomly selected once and the same request is sent over and over again. Which is not what I want
My code:
class GcStressManyRequests extends Simulation{
...
...
val httpProtocol: HttpProtocolBuilder = http
.baseURL(baseUrl)
.contentTypeHeader(contentType)
var requests = Source.fromResource("bodies/requests.txt").getLines().toIndexedSeq
val random = new Random(System.currentTimeMillis())
val scn: ScenarioBuilder = scenario("AE prod requests")
.exec (
http("bid_request")
.post(endpoint)
.body(StringBody(requests(random.nextInt(requests.length))))
.asJSON
.check(status.is(200)))
setUp(
scn.inject(
constantUsersPerSec(400) during (1 minutes),
).protocols(httpProtocol))
}
Upvotes: 3
Views: 2792
Reputation: 4465
I see you have your requests in a text file bodies.txt. For your task I would use a Feeder (check Step 03). With a feeder you can retrieve a random item from a list of items and use it in your calls. The steps you have to undertake to make it work:
Create a feeder:
val random_request = csv("bodies.csv").random
Edit scenario:
val scn: ScenarioBuilder = scenario("AE prod requests")
.feed(random_request) //Puts a random request in your session.
.exec (
http("bid_request")
.post(endpoint)
.body(StringBody(${request})) //Retrieve the request from current session.
.asJSON
.check(status.is(200)))
setUp(
scn.inject(
constantUsersPerSec(400) during (1 minutes),
).protocols(httpProtocol))
Upvotes: 4
Reputation: 2067
For completeness, I'd like to share Domingos Creado's answer on Gatling Google Groups that worked for me.
val scn: ScenarioBuilder = scenario("AE prod requests")
.exec(session => {
val session2 = session.set("therequest", requests(random.nextInt(requests.length)))
session2
})
.exec (
http("bid_request")
.post(endpoint)
.body(StringBody("${therequest}"))
.asJSON
.check(status.is(200)))
Upvotes: 2
Reputation: 1172
Step 1 : Create Input in my case it is stack .The below is just a method you can use your own implementation
var jobsQue: Stack[InputData] = GenerateInput.creatJobsCollection()
Step 2 : Use it
val execScn = scenario("Requests").group("Groups") {
asLongAs(session => jobsQue.length > 0) { exec { session =>
var length = jobsQue.length //Whatever
var reportElement = jobsQue.pop(); //POP it } } }
Hope this is helpful enough to keep you going.
Upvotes: 1