Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/robsonbittencourt/gatling-scaffold
Base for load test project using Gatling
https://github.com/robsonbittencourt/gatling-scaffold
gatling grafana load-test
Last synced: 2 months ago
JSON representation
Base for load test project using Gatling
- Host: GitHub
- URL: https://github.com/robsonbittencourt/gatling-scaffold
- Owner: robsonbittencourt
- License: mit
- Created: 2019-04-09T02:00:49.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2021-12-04T16:49:39.000Z (about 3 years ago)
- Last Synced: 2024-01-25T06:09:57.711Z (about 1 year ago)
- Topics: gatling, grafana, load-test
- Language: Shell
- Size: 1000 KB
- Stars: 15
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-gatling - gatling-scaffold - Base for load test project using Gatling, InfluxDB and Grafana. (Tools / Sandbox)
README
# Gatling Scaffold
> Scaffold for load test project using Gatling
## Motivation
[Gatling](https://gatling.io/) is a amazing tool for load test as code.
The goal of this project is to provide a scaffold for building a load test suite using Gatling. Feel free to modify this project according to your needs. If you create something that might be useful to others, please submit a Pull Request.
![grafana-dashboard](media/grafana-dashboard.gif)
This project uses Kotlin to write the tests. It is possible to adapt it to use Java without much effort. [Here's a project](https://github.com/gatling/gatling-gradle-plugin-demo-java) that uses Java.
## Running example test
This project provides two main features for load testing developer. Visualization of data and execution of simulations.
### Visualization of data
```
git clone [email protected]:robsonbittencourt/gatling-scaffold.git
cd gatling-scaffold
docker-compose up
```
The docker-compose of this project will build containers with [InfluxDB](https://www.influxdata.com/time-series-platform/influxdb/) and [Grafana](https://grafana.com/) that will allow us to visualize the simulation data during its execution.After the build and creation of the containers access http://localhost:3000. There is already a dashboard called Gatling Report.
### Execution
```
docker run --rm --net="host"\
-v "$PWD":/gatling-scaffold \
-v "$PWD"/.gradle:/home/gradle/.gradle \
-v "$PWD"/build/reports/gatling:/build/reports/gatling \
-w /gatling-scaffold \
gradle:7.3.1-jdk17 gradle gatlingRun
```This command starts the sample simulation. Follow de execution in your Grafana (http://localhost:3000). After the run you can also view the Gatling report that displays more details. It is generated in ```gatling-scaffold/build/reports/gatling```
![report](media/report.png)
## Creating new simulations
You can rename this project and use it to create your own simulations. These should be placed in the ```src/gatling/kotlin/simulations```.
If you don't know how Gatling works I recommend these links:
- [Gatling Documentation](https://gatling.io/docs/current/general/)
- [Gatling Cheat Sheet](https://gatling.io/docs/current/cheat-sheet/)To execute your new simulation run the Docker command previously shown passing the simulation full qualified class name with the Gradle Task.
```
docker run --rm --net="host"\
-v "$PWD":/gatling-scaffold \
-v "$PWD"/.gradle:/home/gradle/.gradle \
-v "$PWD"/build/reports/gatling:/build/reports/gatling \
-w /gatling-scaffold \
gradle:7.3.1-jdk17 gradle gatlingRun-simulations.AnotherSimulation
```When simulation is not specified, all are run.
## Acknowledgments
This project used as a foundation open source projects and resources that other people have created. This shows when it is important to share our creations whenever possible because when we do this we have the chance to help several people.
- [David Blooman](https://github.com/dblooman) - By the [project](https://github.com/dblooman/gatling-docker) that inspired this
- [Denis Vazhenin](https://github.com/denvazh) - By the [Docker image](https://github.com/denvazh/gatling) used to perform the simulations ([Before Scala is removed](https://github.com/robsonbittencourt/gatling-scaffold/commit/53d80e1194957a3273b2ee876658358fe3f284ec))
- [polarnik](https://github.com/polarnik) - By the [Grafana Dashboard](https://grafana.com/dashboards/9935) which I used as a base