mvn compile exec:java
If you don't have maven installed, you can run a Docker image that contains maven and Java 21:
#Windows
docker run -it --rm --name test-project -v %cd%:/usr/src/mymaven -w /usr/src/mymaven maven:3.9.9-eclipse-temurin-21-alpine mvn compile exec:java
#Linux
docker run -it --rm --name test-project -v $(pwd):/usr/src/mymaven -w /usr/src/mymaven maven:3.9.9-eclipse-temurin-21-alpine mvn compile exec:java
Ctrl+C
to stop.
There are two Gatling tests. One test hits a simple endpoint that returns HTTP responses without invoking other Akka components. A second test sends randomly generated create user requests. This second test invokes an event-sourced entity via an endpoint component. Bash scripts are provided for running both tests.
./bin/gatling-test-simple-users.sh [hosthane]
The hostname
is an optional parameter. Default hostname for local testing on host localhost
, port 9000
.
./bin/gatling-test-create-users.sh [hostname]
The hostname
is an optional parameter. Default hostname for local testing on host localhost
, port 9000
.
- Make sure your application is running and accessible either locally or on the Akka platform before starting the test.
- The test results will be generated in the
target/gatling
directory after the test run completes.
The Gatling simulation defaults to running the app locally.
Use the following command to get the current service host"
akka routes get multi-region-demo
Example response:
Route: multi-region-demo
Host: damp-mode-6178.aws-us-east-2.apps.akka.st
Allow CORS origins: *
Allow CORS methods: GET,HEAD,POST,PUT,PATCH,DELETE,OPTIONS
Paths:
/ multi-region-demo
Status:
HostValidation: True
Last Transition: Thu Oct 31 08:29:27 2024
Ready: True
Last Transition: Mon Nov 4 08:49:55 2024
Copy/paste the above Host:
and assign is to a variable, then run the Gatling script.
export host=https://github.com/mckeeh3/multi-region-demo.git
./bin/gatling-test-create-users.sh $host
A configuration file is used to change the behavior of tests.
The configuration file is located in src/test/resources/create-users-simulation.conf
.
Here are the setting provided in the configuration file.
# Percent of requests that create users
percentCreate = 10
# Percent of requests that update users
percentUpdate = 30
# Percent of requests that read users
percentRead = 60
# Simulated user pause time after performing an operation
pauseDuration = 500ms
# Requests per second ramp up from 0 to this value over 1 minute
reachRps = 1000
# Hold the RPS at this value for this duration, e.g. 3m, 500s, 1000ms
holdFor = 3m
Edit the configuration settings to adjust Gatling tests.
At the conclusion of a Gatling test the following message is given that provides the location of the test run report.
Reports generated, please open the following file: file:///.../index.html
Copy the URL to view in a browser or view in an IDE.
Two scripts are included in this project for creating and viewing user entities.
Use the create-user.sh
script to create a user.
Create user with locally running service. This script takes the provided userId
and uses it for the user name and user email as <userId>@gmail.com
./bin/create-user.sh user456
Create user with Akka platform service.
./bin/create-user.sh $host user456
Use the create-user-long.sh
script to set the userId, user name, and email.
./bin/create-user-long.sh user654 "Jane Doe" [email protected]
./bin/create-user-long.sh $host user654 "Jane Doe" [email protected]
Use the get-user,sh
script to view existing user entities.
./bin/get-user.sh user456
./bin/get-user.sh $host user456
Shell scripts are provided for doing view queries.
Query a single user by Id.
./bin/get-user-by-id-from-view.sh user-id-1234
./bin/get-user-by-id-from-view.sh $host user-id-1234
Query a single user by email.
./bin/get-user-by-email-from-view.sh [email protected]
./bin/get-user-by-email-from-view.sh $host [email protected]
Query users with a streaming response. CTRL-c to stop.
./bin/get-all-users-from-view.sh
./bin/get-all-users-from-view.sh $host