commit | 5ed74e286e6ca5807b17223e89ea05fb96fa3e8e | [log] [tgz] |
---|---|---|
author | Ievgeniia Zadorozhna <izadorozhna@mirantis.com> | Tue Jul 26 16:56:23 2022 +0300 |
committer | Oleksandr Savatieiev <osavatieiev@mirantis.com> | Thu Aug 11 14:26:23 2022 +0000 |
tree | c2950daf75fb578af4f840bb13f13bba7ff03f37 | |
parent | 97dfde41a471b6faeb363383127a183502c9e4a7 [diff] |
Switched multi-threads testing from iperf3 to iperf Switched multi-threads testing from iperf3 to iperf because the iperf3 was not designed for the multiple threads, see [1] and [2]. So, iperf (v2) will be used for measuring tests with -P option. Made the number of threads as an configurable option (10 by default). * installing iperf package * allowing 5001 port * starting iperf as well as iperf3 at VMs * added 'multiple_threads_number' option (10 by default) * added details which tool was used (iperf3 or iperf) in the final table * changed the default image from Ubuntu18 to Ubuntu20 [1] https: //fasterdata.es.net/performance-testing/network-troubleshooting-tools/iperf/multi-stream-iperf3/ [2] https: //github.com/esnet/iperf/issues/289 Related-PROD: PROD-36943 Change-Id: I39d2c44723344c87836bf7b5fa02b546a08f2ca5
Requirements
At least Python 3.6 is required for the tests.
Installation
cd mos-spt/ virtualenv .venv . .venv/bin/activate pip install -r requirements.txt
Configuration
Open global_config.yaml file to override the settings, or export the environment variables.
Settings
The following options can be set in global_config.yaml file, or by exporting the environment variables.
Environment Variable | Default | Description |
---|---|---|
IMAGE_SIZE_MB | 9000 | Specific image size (in MB) to upload/download at Glance |
Environment Variable | Default | Description |
---|---|---|
flavor_name | spt-test | Flavor name |
flavor_ram | 1536 | To define RAM allocation for specific flavor, MB |
flavor_vcpus | 1 | To define a count of vCPU for flavor |
flavor_disk | 5 | To define a count of disks on flavor, GB |
image_name | cvp.ubuntu.2004 | Cloud Ubuntu image to create VMs. Use 20.04 image in case internet_at_vms=false since the offline packages are set for Ubuntu 20.04. You can use any other Ubuntu image in case internet_at_vms=true. |
CMP_HOSTS | "" | Pair of compute hosts to create VMs at different hosts. By default, some random pair from nova compute list will be selected. To set some pair, set CMP_HOSTS: ["cmp001", "cmp002"] in global_config.yaml file, or export CMP_HOSTS="cmp001,cmp002". |
skipped_nodes | "" | Skip some compute hosts, so they are not selected at CMP_HOSTS pair. To set some nodes to skip, set skipped_nodes: ["cmp003"] in global_config.yaml file, or export skipped_nodes="cmp003". |
nova_timeout | 300 | Timeout to VM to be ACTIVE, seconds. |
external_network | public | External network name to allocate the Floating IPs |
custom_mtu | default | The MTU to set at the VMs. If "default" is set, the MTU will be set automatically from the newly created SPT internal networks. The default value in the networks comes from the Neutron configuration. In case you want to test the bandwidth with some specific custom MTU, set the value like 8950. |
ssh_timeout | 500 | Timeout to VM to be reachable via SSH, seconds. |
iperf_prep_string | "sudo /bin/bash -c 'echo "91.189.88.161 archive.ubuntu.com" >> /etc/hosts'" | Preparation string to set ubuntu repository host in /etc/hosts of VMs |
internet_at_vms | 'true' | In case True, the Internet is present at VMs, and the tests are able to install iperf3 by apt update; apt install iperf3. In case VMs have no Internet, set 'false' and the iperf3 will be installed from offline *.deb packages. |
iperf_deb_package_dir_path | /opt/packages/ | Path to the local directory where the iperf3 *.deb packages are present. In the toolset offline images they are located at /opt/packages. Or you can download iperf3 deb package and its dependencies and put them at some custom folder. |
iperf_time | 60 | iperf3 -t option value: time in seconds to transmit for (iperf -t option). |
In case internet_at_vms=false, please make sure that iperf_deb_package_dir_path is set correctly and has iperf3 deb package and its dependencies.
Executing tests
Run tests:
pytest -sv --tb=short tests/
In case the test is skipped and you want to know the reason, use python -rs option:
pytest -rs --tb=short tests/
Enable logging
In case something went wrong, use -o log_cli=true option to see detailed logs:
pytest -sv --tb=short -o log_cli=true tests/
By default, the log level is INFO log_cli_level=info. In case you want to go deeper for the API requests (with URIs, payloads, etc), set cli_level=debug in pytest.ini file.