-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathCase0016ScenarioDurationSimulation.java
More file actions
76 lines (68 loc) · 3.64 KB
/
Case0016ScenarioDurationSimulation.java
File metadata and controls
76 lines (68 loc) · 3.64 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
package pl.gemiusz;
import io.gatling.javaapi.core.ScenarioBuilder;
import io.gatling.javaapi.core.Session;
import io.gatling.javaapi.core.Simulation;
import io.gatling.javaapi.http.HttpProtocolBuilder;
import java.time.Duration;
import java.util.UUID;
import static io.gatling.javaapi.core.CoreDsl.*;
import static io.gatling.javaapi.http.HttpDsl.http;
public class Case0016ScenarioDurationSimulation extends Simulation {
HttpProtocolBuilder httpProtocol =
http
.baseUrl("https://postman-echo.com");
ScenarioBuilder scn1 =
scenario("GeMi_ScenarioDurationSimulation_1")
.exec(session -> {
Session session1 = session
.set("GeMi_ScenarioDurationSimulation_1_start", System.nanoTime())
.set("uuidString", UUID.randomUUID().toString());
return session1;
})
.exec(
http("GeMi_ScenarioDurationSimulation_get_1_1")
.get("/get?foo=#{uuidString}")
.check(jmesPath("args.foo").isEL("#{uuidString}"))
).exec(
http("GeMi_ScenarioDurationSimulation_get_1_2")
.get("/get?foo=#{uuidString}")
.check(jmesPath("args.foo").isEL("#{uuidString}"))
)
.pause(Duration.ofMillis(100))
.exec(
http("GeMi_ScenarioDurationSimulation_get_1_3")
.get("/get?foo=#{uuidString}")
.check(jmesPath("args.foo").isEL("#{uuidString}"))
).exec(session -> {
long howLong = System.nanoTime() - session.getLong("GeMi_ScenarioDurationSimulation_1_start");
System.out.println("Scenario GeMi_ScenarioDurationSimulation_1 take: " + howLong + " ns");
return session;
});
ScenarioBuilder scn2 =
scenario("GeMi_ScenarioDurationSimulation_2")
.exec(session -> {
Session session1 = session
.set("GeMi_ScenarioDurationSimulation_2_start", System.nanoTime())
.set("uuidString", UUID.randomUUID().toString());
return session1;
})
.exec(
http("GeMi_ScenarioDurationSimulation_get_2_1")
.get("/get?foo=#{uuidString}")
.check(jmesPath("args.foo").isEL("#{uuidString}"))
)
.pause(Duration.ofSeconds(1))
.exec(
http("GeMi_ScenarioDurationSimulation_get_2_2")
.get("/get?foo=#{uuidString}")
.check(jmesPath("args.foo").isEL("#{uuidString}"))
).exec(session -> {
long howLong = System.nanoTime() - session.getLong("GeMi_ScenarioDurationSimulation_2_start");
System.out.println("Scenario GeMi_ScenarioDurationSimulation_2 take: " + howLong + " ns");
return session;
});
{
setUp(scn1.injectOpen(constantUsersPerSec(1).during(Duration.ofSeconds(5))).protocols(httpProtocol),
scn2.injectOpen(constantUsersPerSec(1).during(Duration.ofSeconds(5))).protocols(httpProtocol));
}
}