Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/rahulchandradasrcd/rest-booking-api-performance-testing-using-jmeter


https://github.com/rahulchandradasrcd/rest-booking-api-performance-testing-using-jmeter

Last synced: about 1 month ago
JSON representation

Awesome Lists containing this project

README

        

# Rest-Booking-API-Performance-Testing-Using-JMeter
This project demonstrates Performance Testing using JMeter, providing a collection of tests to validate various endpoints of the API.

## Features
* Tests for GET, POST, PUT, DELETE requests
* Collection of tests covering different API endpoints

## Technology used:
- JMeter

## Overview
This repository contains a JMeter project for performance testing of the [Restful-Booker](https://restful-booker.herokuapp.com/apidoc/index.html) Website.

## Usage
1. Clone the repository to your Local Machine From:
````
https://github.com/rahulchandradasrcd/rest-booking-api-performance-testing-using-jmeter.git
````
2. Open JMeter and load the test plan.
3. Configure the necessary settings and parameters in the test plan.
4. Run all Test plan.

## Run in CMD (Non GUI mode) on your project folder
1. To run the test plan through CMD (Non GUI mode), use the following command:
````
jmeter -n -t Test_100.jmx -l report\Test_100.jtl
````
This command runs JMeter in non-GUI mode (-n), specifies the test plan file (-t), and writes the results to a JTL file (-l).

2. To run the test plan through CMD (GUI mode), use the following command:
````
jmeter -g report\Test_100.jtl -o report\Test_100.html
````
This command runs JMeter in GUI mode (-g), making report to htl file (-l), and writes the report results to a html file (-l).

## Testing
The sample test plan includes the following components:
1. Thread Group:
* Thread Count: 10
* Ramp-Up Time: 10 second
* Explanation:
* Thread Count: Represents the number of virtual users (threads) executing the test concurrently.
* Ramp-Up Time: Represents the time taken for all threads to start executing.
2. HTTP Proxy Server:
* Used for recording the script of sample pages.
3. Logic Controllers:
* Loop Controllers:-
* Loop Count: 01
4. Config Eelements:
* http header manager
* json extractor
5. Listeners:
* view result trees
* summary report
* aggrigate report
6. Save and Run the test plan
7. Execution:
* Run all the test plan sequentially
* you can start your execution with 100 thread group until error rate is 1.0%
8. Point to explore:
* Running through CMD (Non GUI mode).
* Running through CMD (GUI mode) for generating html report.
## Report
1. 2000 Concurrent Request with 01 Loop Count; Avg TPS for Total Samples is ~ 200 And Total Concurrent API requested: 12000.
![2000](https://github.com/user-attachments/assets/1c45d7b5-fdfb-422a-a025-4d5fcb03fafa)
2. 2500 Concurrent Request with 01 Loop Count; Avg TPS for Total Samples is ~ 121 And Total Concurrent API requested: 15000.
![2500](https://github.com/user-attachments/assets/38330642-497a-41f1-8bb9-ef833760589c)
3. 2600 Concurrent Request with 01 Loop Count; Avg TPS for Total Samples is ~ 260 And Total Concurrent API requested: 15600.
![2600](https://github.com/user-attachments/assets/f9953858-541e-499c-b666-0bbf24f54099)
4. 2700 Concurrent Request with 01 Loop Count; Avg TPS for Total Samples is ~ 217 And Total Concurrent API requested: 16200.
![2700a](https://github.com/user-attachments/assets/2e122aa8-25fe-4fa9-8109-fd2b1990c38e)
5. 2800 Concurrent Request with 01 Loop Count; Avg TPS for Total Samples is ~ 195 And Total Concurrent API requested: 16800.
![2800](https://github.com/user-attachments/assets/d307d2c4-7202-445c-b8d3-4da3aecc017a)
6. 2900 Concurrent Request with 01 Loop Count; Avg TPS for Total Samples is ~ 157 And Total Concurrent API requested: 17400.
![2900](https://github.com/user-attachments/assets/e34a8694-0a18-440d-8b1a-3e839532ff65)
### While executed 2900 concurrent request, found 3160 request got connection timeout and error rate is 18.16%.
### Summary: Server can handle almost concurrent 16900 API call with almost zero (0) error rate.