2011-12-02 15:53:32 -05:00
|
|
|
Tempest - The OpenStack Integration Test Suite
|
|
|
|
==============================================
|
2011-08-11 12:57:44 -05:00
|
|
|
|
2013-05-21 17:57:41 -04:00
|
|
|
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.
|
|
|
|
|
2013-11-01 18:09:55 -04:00
|
|
|
Design Principles
|
2014-06-04 11:43:10 -04:00
|
|
|
-----------------
|
2013-11-01 18:09:55 -04:00
|
|
|
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 interfaces, API calls (native or 3rd party),
|
2015-04-29 12:23:01 -04:00
|
|
|
or libraries.
|
2013-11-01 18:09:55 -04:00
|
|
|
- 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 is some feature of
|
|
|
|
OpenStack that is 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.
|
2015-08-21 04:09:08 +00:00
|
|
|
- Tempest should be self-testing.
|
2011-08-11 12:57:44 -05:00
|
|
|
|
|
|
|
Quickstart
|
|
|
|
----------
|
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
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.
|
2011-08-11 12:57:44 -05:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
#. You first need to install Tempest this is done with pip, after you check out
|
|
|
|
the Tempest repo you simply run something like::
|
2011-08-11 12:57:44 -05:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
$ pip install tempest
|
2011-12-02 15:53:32 -05:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
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.
|
2015-03-11 15:39:24 -04:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
#. Installing Tempest will create a /etc/tempest dir which will contain the
|
|
|
|
sample config file packaged with Tempest. The contents of /etc/tempest will
|
|
|
|
be copied to all local working dirs, so if there is any common configuration
|
|
|
|
you'd like to be shared between anyone setting up local Tempest working dirs
|
|
|
|
it's recommended that you copy or rename tempest.conf.sample to tempest.conf
|
|
|
|
and make those changes to that file in /etc/tempest
|
2013-07-24 10:25:02 +02:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
#. Setup a local working Tempest dir. This is done using the tempest init
|
|
|
|
command::
|
2012-03-06 00:21:45 -06:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
tempest init cloud-01
|
2015-03-11 15:39:24 -04:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
works the same as::
|
2013-07-24 10:25:02 +02:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
mkdir cloud-01 && cd cloud-01 && tempest init
|
2013-09-17 17:04:03 +00:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
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.
|
2015-03-11 15:39:24 -04:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
#. 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.
|
2015-03-11 15:39:24 -04:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
#. Once the configuration is done you're now ready to run Tempest. This can
|
|
|
|
be done with testr directly or any `testr`_ based test runner, like
|
|
|
|
`ostestr`_. For example, from the working dir running::
|
2015-03-11 15:39:24 -04:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
$ ostestr --regex '(?!.*\[.*\bslow\b.*\])(^tempest\.(api|scenario|thirdparty))'
|
2015-03-11 15:39:24 -04:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
will run the same set of tests as the default gate jobs.
|
2015-03-11 15:39:24 -04:00
|
|
|
|
2015-07-06 15:43:46 -04:00
|
|
|
.. _testr: https://testrepository.readthedocs.org/en/latest/MANUAL.html
|
|
|
|
.. _ostestr: http://docs.openstack.org/developer/os-testr/
|
2012-11-13 22:06:45 +00:00
|
|
|
|
2012-03-06 00:21:45 -06:00
|
|
|
Configuration
|
|
|
|
-------------
|
|
|
|
|
2015-03-16 17:46:24 +01:00
|
|
|
Detailed configuration of Tempest is beyond the scope of this
|
2015-03-11 15:39:24 -04:00
|
|
|
document see :ref:`tempest-configuration` for more details on configuring
|
2015-08-21 04:09:08 +00:00
|
|
|
Tempest. The etc/tempest.conf.sample attempts to be a self-documenting version
|
2015-03-11 15:39:24 -04:00
|
|
|
of the configuration.
|
2013-05-21 17:57:41 -04:00
|
|
|
|
2015-03-11 15:39:24 -04:00
|
|
|
You can generate a new sample tempest.conf file, run the following
|
2015-03-16 17:46:24 +01:00
|
|
|
command from the top level of the Tempest directory:
|
2014-11-18 15:28:46 +09:00
|
|
|
|
|
|
|
tox -egenconfig
|
2013-11-26 15:28:12 +00:00
|
|
|
|
2013-05-21 17:57:41 -04:00
|
|
|
The most important pieces that are needed are the user ids, openstack
|
2015-03-11 15:39:24 -04:00
|
|
|
endpoint, and basic flavors and images needed to run tests.
|
2014-01-13 18:20:50 +00:00
|
|
|
|
|
|
|
Unit Tests
|
|
|
|
----------
|
|
|
|
|
2015-03-16 17:46:24 +01:00
|
|
|
Tempest also has a set of unit tests which test the Tempest code itself. These
|
2015-07-28 21:52:17 +09:00
|
|
|
tests can be run by specifying the test discovery path::
|
2014-01-13 18:20:50 +00:00
|
|
|
|
|
|
|
$> 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
|
2015-03-16 17:46:24 +01:00
|
|
|
Tempest suite.
|
2014-01-13 18:20:50 +00:00
|
|
|
|
|
|
|
Alternatively, you can use the run_tests.sh script which will create a venv and
|
2015-05-11 22:18:00 -04:00
|
|
|
run the unit tests. There are also the py27 and py34 tox jobs which will run
|
|
|
|
the unit tests with the corresponding version of python.
|
2014-02-13 14:35:38 -05:00
|
|
|
|
|
|
|
Python 2.6
|
|
|
|
----------
|
|
|
|
|
2015-02-23 11:52:33 -05:00
|
|
|
Starting in the kilo release the OpenStack services dropped all support for
|
2015-03-16 17:46:24 +01:00
|
|
|
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
|
2015-02-23 11:52:33 -05:00
|
|
|
python 2.6 compatibility will be rejected, and moving forward more features not
|
2015-03-16 17:46:24 +01:00
|
|
|
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
|
2015-02-23 11:52:33 -05:00
|
|
|
from a remote system running python 2.7. (or deploy a cloud guest in your cloud
|
|
|
|
that has python 2.7)
|
2015-05-11 22:18:00 -04:00
|
|
|
|
|
|
|
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
|
2015-08-21 04:09:08 +00:00
|
|
|
work on Python 3.4. However, because large parts of Tempest are self-verifying
|
2015-05-11 22:18:00 -04:00
|
|
|
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.
|
2015-07-06 15:43:46 -04:00
|
|
|
|
|
|
|
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 \
|
2015-04-13 21:55:58 -04:00
|
|
|
etc/config-generator.tempest.conf \
|
2015-07-06 15:43:46 -04:00
|
|
|
--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.
|