-
-
Notifications
You must be signed in to change notification settings - Fork 2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Karate-Gatling - large delay between the first active user(s) and the first request(s) #1395
Comments
@theathlete3141 I'm inclined to mark this as won't fix since it is only for the first request, it could be the warm-up time of the JS engine. also I don't consider this a priority, there's plenty of backlog on the 1.0 release. any investigation from anyone will be greatly appreciated. |
This issue has two parts:
The warm-up time of the JS engine sounds like a good suggestion for the cause behind the first part, in which case the solution could be to delay the user activation until everything is initialised. The second part seems a little more concerning. In this example the user spawn rate is low (10 per second) and the response time is short (< 1 second). Therefore the Gatling example behaves as expected in that the number of active users is always ~10:
In the Karate-Gatling example however, even after the apparent warm up period has ended and the first request has finally been made, it looks like we sometimes have active users sitting around not doing anything. |
@theathlete3141 yes this is a concern but I'm confident it could be an optimization we have missed. I don't remember if some changes I made to injecting an executor service into the feature-runtime is in 0.9.9.RC1 the other thing is maybe HTML reports and step-results collection may be happening in memory. a long pending optimization we haven't done is that the apache http client is still synchronous one data point would be useful. do you see the same behavior in 0.9.6 ? |
@theathlete3141 I know this was just for demonstration, but I'm curious if you see the same behavior over a longer test run, say a minute? Also do you see the same delay with |
TLDR: same issue are seen when using a longer test run, and also when using a different user inject method. Issues not present using version 0.9.6. Running KarateSimulation with a Karate mock server using Running KarateSimulation with a Karate mock server using Using Karate 0.9.6 and running KarateSimulation with a Karate mock server using |
great. I'll try take a look over the weekend but any investigation in the meantime will help |
@theathlete3141 can you do one more experiment. start the karate mock in a separate JVM (separate process like you do the python one) let me know if there is a difference. public static void main(String[] args) {
MockServer server = MockServer
.feature("classpath:com/intuit/karate/core/mock/_simple.feature")
.http(8080).build();
server.waitSync();
} |
ok, so with the karate mock running in a different process, here are my findings. 60 second test mock: Feature:
Scenario: pathMatches('/test')
* def response = { success: true } gatling: package example
import io.gatling.core.Predef._
import io.gatling.http.Predef._
import scala.concurrent.duration._
class GatlingSimple extends Simulation {
val protocol = http.baseUrl("http://localhost:8080")
val example = scenario("example")
.exec(
http("GET /test")
.get("/test")
.check(status.is(200))
)
setUp(
example.inject(rampUsers(100) during (60 seconds)).protocols(protocol)
)
} karate / Feature:
Scenario:
* url 'http://localhost:8080'
* path 'test'
* method get
* status 200
* match response == { success: true } karate-gatling: package example
import com.intuit.karate.core.MockServer
import com.intuit.karate.gatling.PreDef._
import io.gatling.core.Predef._
import scala.concurrent.duration._
import scala.util.Properties
class KarateSimple extends Simulation {
val example = scenario("example")
.exec(karateFeature("classpath:example/simple.feature"))
setUp(
example.inject(rampUsers(100) during (60 seconds))
)
} so I think we are good. closing. do see if you can find what weird threading or thread-local weirdness is happening when the mock is run by the scala JVM |
@ptrthomas I don't think this issue is related to how the mock server is being run. It appears to be related to user arrival rate. In your simulation above your user count and duration are such that there are only a couple of users per second, whereas in my tests it was of the order of 10 per second. Taking your above example but putting the mock server setup back in the simulation class
Running with
I see the same pattern of active users, requests and responses as you reported above. If I ramp up the same number of users over a shorter duration (
Or ramp more users over the same duration (
Then this delay becomes much more obvious and like that as shown in my original examples. Example project attached. Just in case the 0.9.9.RC1 tagged version doesn't match the HEAD of develop, I have also tried the above against the source to include your recent commit. |
@theathlete3141 yes I tried with a higher no of users per second, things smooth out after the first 10 or so seconds. the considering this a and before you say so - yes pure gatling behaves differently: https://stackoverflow.com/a/63178818/143475 |
@theathlete3141 one more point - it does seem the new karate mock does not perform well for the first few seconds. if you request to re-open kindly focus on testing against a non-karate mock to demo that there is a significant lag or overhead |
…first request(s) in Karate-Gatling
I found that this issue occurs even using a real url (http://date.jsontest.com). I've attached example project (using 0.9.9.RC2). Karate simulation against a live server:
Against a mock server:
The equivalent using Gatling:
However, I believe that I've found the issue and will submit a PR. |
#1395 - fix delay between the first active user(s) and the first request(s) in Karate-Gatling
@theathlete3141 thanks for the PR, I'll keep this closed as this pertains to an in-dev version |
Using karate version 0.9.9.RC1
Using a basic feature file
With a basic mock server
With a basic simulation:
Looking in the index.html test report, I found that there was a large delay between the first active user(s) and the first request(s).
Attached is an example project which demonstrates four test cases:
example.zip
For a non-Karate mock server I used python http server. In a separate terminal window run (assuming using python3)
Which will run the contents of that directory on localhost:8000. When running the tests, ignore the 404s seen here as the requests are not expected to succeed.
Then in a new terminal window run the four test cases:
In test cases 2 and 4 against the non-Karate mock server, ignore the errors where it fails to parse html as xml.
Attached are screenshots of the reports from test cases 1 and 3 which demonstrate the effect that making requests with Karate has on the results. As well as the initial pause seen in test case 1, the number of requests per second once it finally starts going is unexpectedly uneven.
data:image/s3,"s3://crabby-images/5301c/5301c94ba9a19c1cfd8ccb0a3dfc7b1abf1377a5" alt="karatesimulation-20201210144917763_index html"
data:image/s3,"s3://crabby-images/51bfc/51bfc681692bd9a5124348a0241559ffb2699cc6" alt="gatlingsimulation-20201210144959296_index html"
This delay is only seen in test cases 1 and 2. Having ran these tests a number of times, often the delay is a little longer in test case 1 than 2 which could indicate that the issue is in part related to the Karate mock server. However no delay is seen in test case 3 so the issue must (mostly) be to do with the Karate aspect of Karate-Gatling rather than the Karate mock server.
Ignore the fact that the response times of these initial requests in each test case are very slow - this appears to be an unrelated issue, and seems to be to do with Gatling rather than Karate.
The text was updated successfully, but these errors were encountered: