|  | Tempest - The OpenStack Integration Test Suite | 
|  | ============================================== | 
|  |  | 
|  | The documentation for Tempest is officially hosted at: | 
|  | http://docs.openstack.org/developer/tempest/ | 
|  |  | 
|  | This is a set of integration tests to be run against a live OpenStack | 
|  | cluster. Tempest has batteries of tests for OpenStack API validation, | 
|  | Scenarios, and other specific tests useful in validating an OpenStack | 
|  | deployment. | 
|  |  | 
|  | Design Principles | 
|  | ----------------- | 
|  | Tempest Design Principles that we strive to live by. | 
|  |  | 
|  | - Tempest should be able to run against any OpenStack cloud, be it a | 
|  | one node devstack install, a 20 node lxc cloud, or a 1000 node kvm | 
|  | cloud. | 
|  | - Tempest should be explicit in testing features. It is easy to auto | 
|  | discover features of a cloud incorrectly, and give people an | 
|  | incorrect assessment of their cloud. Explicit is always better. | 
|  | - Tempest uses OpenStack public interfaces. Tests in Tempest should | 
|  | only touch public OpenStack APIs. | 
|  | - Tempest should not touch private or implementation specific | 
|  | interfaces. This means not directly going to the database, not | 
|  | directly hitting the hypervisors, not testing extensions not | 
|  | included in the OpenStack base. If there are some features of | 
|  | OpenStack that are not verifiable through standard interfaces, this | 
|  | should be considered a possible enhancement. | 
|  | - Tempest strives for complete coverage of the OpenStack API and | 
|  | common scenarios that demonstrate a working cloud. | 
|  | - Tempest drives load in an OpenStack cloud. By including a broad | 
|  | array of API and scenario tests Tempest can be reused in whole or in | 
|  | parts as load generation for an OpenStack cloud. | 
|  | - Tempest should attempt to clean up after itself, whenever possible | 
|  | we should tear down resources when done. | 
|  | - Tempest should be self-testing. | 
|  |  | 
|  | Quickstart | 
|  | ---------- | 
|  |  | 
|  | To run Tempest, you first need to create a configuration file that will tell | 
|  | Tempest where to find the various OpenStack services and other testing behavior | 
|  | switches. Where the configuration file lives and how you interact with it | 
|  | depends on how you'll be running Tempest. There are 2 methods of using Tempest. | 
|  | The first, which is a newer and recommended workflow treats Tempest as a system | 
|  | installed program. The second older method is to run Tempest assuming your | 
|  | working dir is the actually Tempest source repo, and there are a number of | 
|  | assumptions related to that. For this section we'll only cover the newer method | 
|  | as it is simpler, and quicker to work with. | 
|  |  | 
|  | #. You first need to install Tempest. This is done with pip after you check out | 
|  | the Tempest repo:: | 
|  |  | 
|  | $ git clone http://git.openstack.org/openstack/tempest | 
|  | $ pip install tempest/ | 
|  |  | 
|  | This can be done within a venv, but the assumption for this guide is that | 
|  | the Tempest cli entry point will be in your shell's PATH. | 
|  |  | 
|  | #. Installing Tempest may create a /etc/tempest dir, however if one isn't | 
|  | created you can create one or use ~/.tempest/etc or ~/.config/tempest in | 
|  | place of /etc/tempest. If none of these dirs are created tempest will create | 
|  | ~/.tempest/etc when it's needed. The contents of this dir will always | 
|  | automatically be copied to all etc/ dirs in local workspaces as an initial | 
|  | setup step. So if there is any common configuration you'd like to be shared | 
|  | between local Tempest workspaces it's recommended that you pre-populate it | 
|  | before running ``tempest init``. | 
|  |  | 
|  | #. Setup a local Tempest workspace. This is done by using the tempest init | 
|  | command:: | 
|  |  | 
|  | $ tempest init cloud-01 | 
|  |  | 
|  | which also works the same as:: | 
|  |  | 
|  | $ mkdir cloud-01 && cd cloud-01 && tempest init | 
|  |  | 
|  | This will create a new directory for running a single Tempest configuration. | 
|  | If you'd like to run Tempest against multiple OpenStack deployments the idea | 
|  | is that you'll create a new working directory for each to maintain separate | 
|  | configuration files and local artifact storage for each. | 
|  |  | 
|  | #. Then cd into the newly created working dir and also modify the local | 
|  | config files located in the etc/ subdir created by the ``tempest init`` | 
|  | command. Tempest is expecting a tempest.conf file in etc/ so if only a | 
|  | sample exists you must rename or copy it to tempest.conf before making | 
|  | any changes to it otherwise Tempest will not know how to load it. For | 
|  | details on configuring tempest refer to the :ref:`tempest-configuration`. | 
|  |  | 
|  | #. Once the configuration is done you're now ready to run Tempest. This can | 
|  | be done using the :ref:`tempest_run` command. This can be done by either | 
|  | running:: | 
|  |  | 
|  | $ tempest run | 
|  |  | 
|  | from the Tempest workspace directory. Or you can use the ``--workspace`` | 
|  | argument to run in the workspace you created regarless of your current | 
|  | working directory. For example:: | 
|  |  | 
|  | $ tempest run --workspace cloud-01 | 
|  |  | 
|  | There is also the option to use testr directly, or any `testr`_ based test | 
|  | runner, like `ostestr`_. For example, from the workspace dir run:: | 
|  |  | 
|  | $ ostestr --regex '(?!.*\[.*\bslow\b.*\])(^tempest\.(api|scenario))' | 
|  |  | 
|  | will run the same set of tests as the default gate jobs. | 
|  |  | 
|  | .. _testr: https://testrepository.readthedocs.org/en/latest/MANUAL.html | 
|  | .. _ostestr: http://docs.openstack.org/developer/os-testr/ | 
|  |  | 
|  | Library | 
|  | ------- | 
|  | Tempest exposes a library interface. This interface is a stable interface and | 
|  | should be backwards compatible (including backwards compatibility with the | 
|  | old tempest-lib package, with the exception of the import). If you plan to | 
|  | directly consume tempest in your project you should only import code from the | 
|  | tempest library interface, other pieces of tempest do not have the same | 
|  | stable interface and there are no guarantees on the Python API unless otherwise | 
|  | stated. | 
|  |  | 
|  | For more details refer to the library documentation here: :ref:`library` | 
|  |  | 
|  | Release Versioning | 
|  | ------------------ | 
|  | Tempest's released versions are broken into 2 sets of information. Depending on | 
|  | how you intend to consume tempest you might need | 
|  |  | 
|  | The version is a set of 3 numbers: | 
|  |  | 
|  | X.Y.Z | 
|  |  | 
|  | While this is almost `semver`_ like, the way versioning is handled is slightly | 
|  | different: | 
|  |  | 
|  | X is used to represent the supported OpenStack releases for tempest tests | 
|  | in-tree, and to signify major feature changes to tempest. It's a monotonically | 
|  | increasing integer where each version either indicates a new supported OpenStack | 
|  | release, the drop of support for an OpenStack release (which will coincide with | 
|  | the upstream stable branch going EOL), or a major feature lands (or is removed) | 
|  | from tempest. | 
|  |  | 
|  | Y.Z is used to represent library interface changes. This is treated the same | 
|  | way as minor and patch versions from `semver`_ but only for the library | 
|  | interface. When Y is incremented we've added functionality to the library | 
|  | interface and when Z is incremented it's a bug fix release for the library. | 
|  | Also note that both Y and Z are reset to 0 at each increment of X. | 
|  |  | 
|  | .. _semver: http://semver.org/ | 
|  |  | 
|  | Configuration | 
|  | ------------- | 
|  |  | 
|  | Detailed configuration of Tempest is beyond the scope of this | 
|  | document see :ref:`tempest-configuration` for more details on configuring | 
|  | Tempest. The etc/tempest.conf.sample attempts to be a self-documenting version | 
|  | of the configuration. | 
|  |  | 
|  | You can generate a new sample tempest.conf file, run the following | 
|  | command from the top level of the Tempest directory: | 
|  |  | 
|  | tox -egenconfig | 
|  |  | 
|  | The most important pieces that are needed are the user ids, openstack | 
|  | endpoint, and basic flavors and images needed to run tests. | 
|  |  | 
|  | Unit Tests | 
|  | ---------- | 
|  |  | 
|  | Tempest also has a set of unit tests which test the Tempest code itself. These | 
|  | tests can be run by specifying the test discovery path:: | 
|  |  | 
|  | $ OS_TEST_PATH=./tempest/tests testr run --parallel | 
|  |  | 
|  | By setting OS_TEST_PATH to ./tempest/tests it specifies that test discover | 
|  | should only be run on the unit test directory. The default value of OS_TEST_PATH | 
|  | is OS_TEST_PATH=./tempest/test_discover which will only run test discover on the | 
|  | Tempest suite. | 
|  |  | 
|  | Alternatively, there are the py27 and py34 tox jobs which will run the unit | 
|  | tests with the corresponding version of python. | 
|  |  | 
|  | Python 2.6 | 
|  | ---------- | 
|  |  | 
|  | Starting in the kilo release the OpenStack services dropped all support for | 
|  | python 2.6. This change has been mirrored in Tempest, starting after the | 
|  | tempest-2 tag. This means that proposed changes to Tempest which only fix | 
|  | python 2.6 compatibility will be rejected, and moving forward more features not | 
|  | present in python 2.6 will be used. If you're running your OpenStack services | 
|  | on an earlier release with python 2.6 you can easily run Tempest against it | 
|  | from a remote system running python 2.7. (or deploy a cloud guest in your cloud | 
|  | that has python 2.7) | 
|  |  | 
|  | Python 3.4 | 
|  | ---------- | 
|  |  | 
|  | Starting during the Liberty release development cycle work began on enabling | 
|  | Tempest to run under both Python 2.7 and Python 3.4. Tempest strives to fully | 
|  | support running with Python 3.4. A gating unit test job was added to also run | 
|  | Tempest's unit tests under Python 3.4. This means that the Tempest code at | 
|  | least imports under Python 3.4 and things that have unit test coverage will | 
|  | work on Python 3.4. However, because large parts of Tempest are self-verifying | 
|  | there might be uncaught issues running on Python 3.4. So until there is a gating | 
|  | job which does a full Tempest run using Python 3.4 there isn't any guarantee | 
|  | that running Tempest under Python 3.4 is bug free. | 
|  |  | 
|  | Legacy run method | 
|  | ----------------- | 
|  |  | 
|  | The legacy method of running Tempest is to just treat the Tempest source code | 
|  | as a python unittest repository and run directly from the source repo. When | 
|  | running in this way you still start with a Tempest config file and the steps | 
|  | are basically the same except that it expects you know where the Tempest code | 
|  | lives on your system and requires a bit more manual interaction to get Tempest | 
|  | running. For example, when running Tempest this way things like a lock file | 
|  | directory do not get generated automatically and the burden is on the user to | 
|  | create and configure that. | 
|  |  | 
|  | To start you need to create a configuration file. The easiest way to create a | 
|  | configuration file is to generate a sample in the ``etc/`` directory :: | 
|  |  | 
|  | $ cd $TEMPEST_ROOT_DIR | 
|  | $ oslo-config-generator --config-file \ | 
|  | tempest/cmd/config-generator.tempest.conf \ | 
|  | --output-file etc/tempest.conf | 
|  |  | 
|  | After that, open up the ``etc/tempest.conf`` file and edit the | 
|  | configuration variables to match valid data in your environment. | 
|  | This includes your Keystone endpoint, a valid user and credentials, | 
|  | and reference data to be used in testing. | 
|  |  | 
|  | .. note:: | 
|  |  | 
|  | If you have a running devstack environment, Tempest will be | 
|  | automatically configured and placed in ``/opt/stack/tempest``. It | 
|  | will have a configuration file already set up to work with your | 
|  | devstack installation. | 
|  |  | 
|  | Tempest is not tied to any single test runner, but `testr`_ is the most commonly | 
|  | used tool. Also, the nosetests test runner is **not** recommended to run Tempest. | 
|  |  | 
|  | After setting up your configuration file, you can execute the set of Tempest | 
|  | tests by using ``testr`` :: | 
|  |  | 
|  | $ testr run --parallel | 
|  |  | 
|  | To run one single test serially :: | 
|  |  | 
|  | $ testr run tempest.api.compute.servers.test_servers_negative.ServersNegativeTestJSON.test_reboot_non_existent_server | 
|  |  | 
|  | Alternatively, you can use the run_tempest.sh script which will create a venv | 
|  | and run the tests or use tox to do the same. Tox also contains several existing | 
|  | job configurations. For example:: | 
|  |  | 
|  | $ tox -efull | 
|  |  | 
|  | which will run the same set of tests as the OpenStack gate. (it's exactly how | 
|  | the gate invokes Tempest) Or:: | 
|  |  | 
|  | $ tox -esmoke | 
|  |  | 
|  | to run the tests tagged as smoke. |