Testing OpenStack upgrades
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Nathan Weinberg 65c1d6ca39 [docs] Updated quickstart guide and example conf file 7 months ago
doc [docs] Updated quickstart guide and example conf file 7 months ago
etc/oslo-config-generator Autogenerate config options and sample config file 2 years ago
infrared_plugin Use tobiko 0.4.0 as default version for Downstream jobs 8 months ago
playbooks Remove DevStack support from tobiko repository 12 months ago
releasenotes Add check requirements job 9 months ago
roles Gate Tobiko projects running faults test cases 8 months ago
tobiko Merge "Remove duplicated get_osp_version method" 8 months ago
tools Update pytest reports generation 8 months ago
zuul.d Execute only one infrared job on check and gate pipelines, all of them on periodic 8 months ago
.ansible-lint Spliting infrared plugin into roles 2 years ago
.coveragerc Relax low coverage trealdshold 2 years ago
.dockerignore Update Dockerfile to use bindep and tox 1 year ago
.gitignore gitignore add .idea 10 months ago
.gitreview OpenDev Migration Patch 2 years ago
.pre-commit-config.yaml Remove -j0 option from pylint pre-commit hook 1 year ago
.stestr.conf Fix requirements and use ReadTheDocs HTML documentation theme 2 years ago
Dockerfile Update Dockerfile to use bindep and tox 1 year ago
LICENSE Introduce pre-commit hooks for linters verifications 1 year ago
Pipfile Add tobiko-fault command 3 years ago
README.rst Fixed typo in README 8 months ago
ansible.cfg Rewrite Vagrant file using ansible and Centos 8 1 year ago
bindep.txt Add centos-7 support 1 year ago
docker-compose.yml Update Dockerfile to use bindep and tox 1 year ago
extra-requirements.txt Use pytest-cov plugin for getting coverage 8 months ago
linters-requirements.txt Pass broken jobs with Python 3.8 (Ubuntu Focal and Fedora 32) 10 months ago
lower-constraints.txt Add check requirements job 9 months ago
pytest.ini Update pytest reports generation 8 months ago
requirements.txt Remove last dependency from stestr 8 months ago
setup.cfg Switch to pytest test runner 9 months ago
setup.py Add initial structure 3 years ago
test-requirements.txt Use pytest-cov plugin for getting coverage 8 months ago
tobiko.conf.example [docs] Updated quickstart guide and example conf file 7 months ago
tox.ini Fix reboot when target host si not reachable 8 months ago

README.rst

Tobiko 0.3

Test Big Cloud Operations

Tobiko is an OpenStack testing framework focusing on areas mostly complementary to Tempest. While tempest main focus has been testing OpenStack rest APIs, the main Tobiko focus is to test OpenStack system operations while "simulating" the use of the cloud as the final user would.

Tobiko's test cases populate the cloud with workloads such as Nova instances; they execute disruption operations such as services/nodes restart; finally they run test cases to validate that the cloud workloads are still functional.

Tobiko's test cases can also be used, for example, for testing that previously created workloads are working right after OpenStack services update/upgrade operation.

Project Requirements

Tobiko Python framework is being automatically tested with below Python versions:

  • Python 3.6
  • Python 3.8
  • Python 3.9 (new)

and below Linux distributions:

  • CentOS 7 / RHEL 7 (with Python 3.6)
  • CentOS 8 / RHEL 8 (with Python 3.6)
  • Ubuntu Focal (with Python 3.8)

Tobiko has also been tested for development purposes with below OSes:

  • Fedora 31 (with Python 3.7)
  • Fedora 32 (with Python 3.8)
  • Fedora 33 (with Python 3.9)
  • OSX (with Python 3.6 and Python 3.8)
  • Ubuntu Bionic (with Python 3.6)
  • Ubuntu Focal (with Python 3.9)

The Tobiko Python framework is being used to implement test cases. As Tobiko can be executed on nodes that are not part of the cloud to test against, this doesn't mean Tobiko requires cloud nodes have to run with one of above Python versions or Linux distributions.

Main Project Goals

  • To test OpenStack and Red Hat OpenStack Platform projects before they are released.
  • To provide a Python framework to write system scenario test cases (create and test workloads), to write white boxing test cases (to log to cloud nodes for internal inspection purpose), to write disruptive test cases (to simulate service disruptions like for example rebooting/interrupting a service to verify cloud reliability).
  • To provide Ansible roles to implement a work-flow designed to run an ordered sequence of test cases groups (like for example tests that creates resources and verify they are working, tests that execute cloud disruptions, and finally tests that verify if resources initially created are still working). The main use of these roles is writing continuous integration jobs for Zuul (via bare Ansible roles) or other services like Jenkins (via the InfraRed plug-in).
  • To verify previously created workloads are working fine after executing OpenStack nodes update/upgrade.
  • To provide tools to monitor and recollect the healthy status of the cloud as seen from user perspective (black-box testing) or from inside (white-box testing).

References