Skip to content

Locust Performance Tests #111

Locust Performance Tests

Locust Performance Tests #111

Workflow file for this run

# This is a basic workflow to help you get started with Actions
name: Locust Performance Tests
# Controls when the workflow will run
on:
# Triggers the workflow on push or pull request events but only for the main branch
push:
branches: [ main ]
pull_request:
branches: [ main ]
schedule:
- cron: '00 12 * * 1'
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
inputs:
workers:
description: 'Number of worker nodes to be used in performance tests'
required: true
locustfile:
description: 'Define the locust performance test file name to be executed'
required: true
# A workflow run is made up of one or more jobs that can run sequentially or in parallel
jobs:
# This workflow contains a single job called "build"
performance-tests:
# The type of runner that the job will run on
runs-on: ubuntu-latest
#env variables
env:
LOCUST_LOCUSTFILE: ${{ github.event.inputs.locustfile || 'dragons_info_load_test.py' }}
WORKERS: ${{ github.event.inputs.workers || 4 }}
# Steps represent a sequence of tasks that will be executed as part of the job
steps:
- uses: AutoModality/action-clean@v1
if: ${{ always() }} # To ensure this step runs even when earlier steps fail
- uses: actions/checkout@v4
- name: Start performance tests
run: docker-compose up --scale worker=${WORKERS} --force-recreate --exit-code-from=master
- name: Print all the execution logs
run: docker-compose logs -f master
if: always()
- name: export test report
if: always()
run: docker cp baselineperformancetest-locust_master_1:./home/locust/report.html .
- name: export artifact
if: always()
uses: actions/upload-artifact@v3
with:
name: locust-report
path: report.html