6bbec5a53d
As per 2025.1 testing runtime, Python 3.12 is the max python version to test. Adding the test job as well update the document to support it. Also, remove the python_requires flag from setup.cfg which stop installing it on python version lower than the min supported. Let's allow to install and as long as it work for older python it is ok. User can get to know the supported python versions from classifier also. Change-Id: I7fafdeccbc549fade23db755e35948ea83ffa530 |
||
---|---|---|
doc/source | ||
releasenotes/notes | ||
tempest_stress | ||
.gitignore | ||
.gitreview | ||
.stestr.conf | ||
.zuul.yaml | ||
AUTHORS | ||
babel.cfg | ||
bindep.txt | ||
ChangeLog | ||
CONTRIBUTING.rst | ||
HACKING.rst | ||
LICENSE | ||
MANIFEST.in | ||
README.rst | ||
requirements.txt | ||
setup.cfg | ||
setup.py | ||
test-requirements.txt | ||
tox.ini |
Tempest Field Guide to Stress Tests
OpenStack is a distributed, asynchronous system that is prone to race condition bugs. These bugs will not be easily found during functional testing but will be encountered by users in large deployments in a way that is hard to debug. The stress test tries to cause these bugs to happen in a more controlled environment.
Stress tests are designed to stress an OpenStack environment by running a high workload against it and seeing what breaks. The stress test framework runs several test jobs in parallel and can run any existing test in Tempest as a stress job.
Environment
This particular framework assumes your working Nova cluster understands Nova API 2.0. The stress tests can read the logs from the cluster. To enable this you have to provide the hostname to call 'nova-manage' and the private key and user name for ssh to the cluster in the [stress] section of tempest.conf. You also need to provide the location of the log files:
- target_logfiles = "regexp to all log files to be checked for errors"
- target_private_key_path = "private ssh key for controller and log file nodes"
- target_ssh_user = "username for controller and log file nodes"
- target_controller = "hostname or ip of controller node (for nova-manage)
- log_check_interval = "time between checking logs for errors (default 60s)"
To activate logging on your console please make sure that you activate use_stderr in tempest.conf or use the default logging.conf.sample file.
Running default stress test set
Installation
You first need to clone this repo.:
$ git clone https://github.com/openstack/tempest-stress $ cd tempest_stress
Install:
$ python setup.py install
Install Tempest
Configuration
To Run stress tests, two configuration files are needed:
- tempest.conf - As per Tempest configuration guidelines here: configuration
- stress_tests.conf - same location as tempest.conf
later one is being used to define all config options specific to stress tests.
Run
Run all tests:
$ run-tempest-stress -a -d 30
Run specific test:
$ run-tempest-stress -t ./tempest_stress/etc/server-create-destroy-test.json -d 30
This sample test tries to create a few VMs and kill a few VMs.
For more information please refer run-tempest-stress CLI help:
$ run-tempest-stress -h
Additional Tools
Sometimes the tests don't finish, or there are failures. In these
cases, you may want to clean out the nova cluster. We have provided some
scripts to do this in the tools
subdirectory. You can use
the following script to destroy any keypairs, floating ips, and
servers:
tempest_stress/tools/cleanup.py