Jay Pipes | 7f75763 | 2011-12-02 15:53:32 -0500 | [diff] [blame] | 1 | Tempest - The OpenStack Integration Test Suite |
| 2 | ============================================== |
Justin Shepherd | 0d9bbd1 | 2011-08-11 12:57:44 -0500 | [diff] [blame] | 3 | |
Sean Dague | b56052b | 2013-05-21 17:57:41 -0400 | [diff] [blame] | 4 | This is a set of integration tests to be run against a live OpenStack |
| 5 | cluster. Tempest has batteries of tests for OpenStack API validation, |
| 6 | Scenarios, and other specific tests useful in validating an OpenStack |
| 7 | deployment. |
| 8 | |
Sean Dague | a26454d | 2013-11-01 18:09:55 -0400 | [diff] [blame] | 9 | Design Principles |
Matthew Treinish | 077a563 | 2014-06-04 11:43:10 -0400 | [diff] [blame] | 10 | ----------------- |
Sean Dague | a26454d | 2013-11-01 18:09:55 -0400 | [diff] [blame] | 11 | Tempest Design Principles that we strive to live by. |
| 12 | |
| 13 | - Tempest should be able to run against any OpenStack cloud, be it a |
| 14 | one node devstack install, a 20 node lxc cloud, or a 1000 node kvm |
| 15 | cloud. |
| 16 | - Tempest should be explicit in testing features. It is easy to auto |
| 17 | discover features of a cloud incorrectly, and give people an |
| 18 | incorrect assessment of their cloud. Explicit is always better. |
| 19 | - Tempest uses OpenStack public interfaces. Tests in Tempest should |
| 20 | only touch public interfaces, API calls (native or 3rd party), |
| 21 | public CLI or libraries. |
| 22 | - Tempest should not touch private or implementation specific |
| 23 | interfaces. This means not directly going to the database, not |
| 24 | directly hitting the hypervisors, not testing extensions not |
| 25 | included in the OpenStack base. If there is some feature of |
| 26 | OpenStack that is not verifiable through standard interfaces, this |
| 27 | should be considered a possible enhancement. |
| 28 | - Tempest strives for complete coverage of the OpenStack API and |
| 29 | common scenarios that demonstrate a working cloud. |
| 30 | - Tempest drives load in an OpenStack cloud. By including a broad |
| 31 | array of API and scenario tests Tempest can be reused in whole or in |
| 32 | parts as load generation for an OpenStack cloud. |
| 33 | - Tempest should attempt to clean up after itself, whenever possible |
| 34 | we should tear down resources when done. |
| 35 | - Tempest should be self testing. |
Justin Shepherd | 0d9bbd1 | 2011-08-11 12:57:44 -0500 | [diff] [blame] | 36 | |
| 37 | Quickstart |
| 38 | ---------- |
| 39 | |
Jay Pipes | 7f75763 | 2011-12-02 15:53:32 -0500 | [diff] [blame] | 40 | To run Tempest, you first need to create a configuration file that |
| 41 | will tell Tempest where to find the various OpenStack services and |
Daryl Walleck | e36f623 | 2012-03-06 00:21:45 -0600 | [diff] [blame] | 42 | other testing behavior switches. |
Justin Shepherd | 0d9bbd1 | 2011-08-11 12:57:44 -0500 | [diff] [blame] | 43 | |
Jay Pipes | 7f75763 | 2011-12-02 15:53:32 -0500 | [diff] [blame] | 44 | The easiest way to create a configuration file is to copy the sample |
| 45 | one in the ``etc/`` directory :: |
Justin Shepherd | 0d9bbd1 | 2011-08-11 12:57:44 -0500 | [diff] [blame] | 46 | |
Jay Pipes | 7f75763 | 2011-12-02 15:53:32 -0500 | [diff] [blame] | 47 | $> cd $TEMPEST_ROOT_DIR |
Brian Lamar | 930fc5b | 2011-12-08 11:51:26 -0500 | [diff] [blame] | 48 | $> cp etc/tempest.conf.sample etc/tempest.conf |
Justin Shepherd | 0d9bbd1 | 2011-08-11 12:57:44 -0500 | [diff] [blame] | 49 | |
Brian Lamar | 930fc5b | 2011-12-08 11:51:26 -0500 | [diff] [blame] | 50 | After that, open up the ``etc/tempest.conf`` file and edit the |
Daryl Walleck | e36f623 | 2012-03-06 00:21:45 -0600 | [diff] [blame] | 51 | configuration variables to match valid data in your environment. |
| 52 | This includes your Keystone endpoint, a valid user and credentials, |
| 53 | and reference data to be used in testing. |
Justin Shepherd | 0d9bbd1 | 2011-08-11 12:57:44 -0500 | [diff] [blame] | 54 | |
Jay Pipes | 7f75763 | 2011-12-02 15:53:32 -0500 | [diff] [blame] | 55 | .. note:: |
Justin Shepherd | 0d9bbd1 | 2011-08-11 12:57:44 -0500 | [diff] [blame] | 56 | |
Sean Dague | b56052b | 2013-05-21 17:57:41 -0400 | [diff] [blame] | 57 | If you have a running devstack environment, tempest will be |
| 58 | automatically configured and placed in ``/opt/stack/tempest``. It |
| 59 | will have a configuration file already set up to work with your |
| 60 | devstack installation. |
Jay Pipes | 7f75763 | 2011-12-02 15:53:32 -0500 | [diff] [blame] | 61 | |
Matthew Treinish | b17460e | 2013-09-17 17:04:03 +0000 | [diff] [blame] | 62 | Tempest is not tied to any single test runner, but testr is the most commonly |
Daryl Walleck | e36f623 | 2012-03-06 00:21:45 -0600 | [diff] [blame] | 63 | used tool. After setting up your configuration file, you can execute |
Matthew Treinish | b17460e | 2013-09-17 17:04:03 +0000 | [diff] [blame] | 64 | the set of Tempest tests by using ``testr`` :: |
Attila Fazekas | 58d2330 | 2013-07-24 10:25:02 +0200 | [diff] [blame] | 65 | |
Matthew Treinish | a7c7f9f | 2014-01-13 18:20:50 +0000 | [diff] [blame] | 66 | $> testr run --parallel |
Daryl Walleck | e36f623 | 2012-03-06 00:21:45 -0600 | [diff] [blame] | 67 | |
nayna-patel | ddb489c | 2012-11-13 22:06:45 +0000 | [diff] [blame] | 68 | To run one single test :: |
Attila Fazekas | 58d2330 | 2013-07-24 10:25:02 +0200 | [diff] [blame] | 69 | |
Masayuki Igawa | fd52ac2 | 2013-12-24 18:20:50 +0900 | [diff] [blame] | 70 | $> testr run --parallel tempest.api.compute.servers.test_servers_negative.ServersNegativeTestJSON.test_reboot_non_existent_server |
Matthew Treinish | b17460e | 2013-09-17 17:04:03 +0000 | [diff] [blame] | 71 | |
Matthew Treinish | a7c7f9f | 2014-01-13 18:20:50 +0000 | [diff] [blame] | 72 | Alternatively, you can use the run_tempest.sh script which will create a venv |
Matthew Treinish | b17460e | 2013-09-17 17:04:03 +0000 | [diff] [blame] | 73 | and run the tests or use tox to do the same. |
nayna-patel | ddb489c | 2012-11-13 22:06:45 +0000 | [diff] [blame] | 74 | |
Daryl Walleck | e36f623 | 2012-03-06 00:21:45 -0600 | [diff] [blame] | 75 | Configuration |
| 76 | ------------- |
| 77 | |
Sean Dague | b56052b | 2013-05-21 17:57:41 -0400 | [diff] [blame] | 78 | Detailed configuration of tempest is beyond the scope of this |
| 79 | document. The etc/tempest.conf.sample attempts to be a self |
| 80 | documenting version of the configuration. |
| 81 | |
Masayuki Igawa | ac401c7 | 2014-11-18 15:28:46 +0900 | [diff] [blame] | 82 | To generate the sample tempest.conf file, run the following |
| 83 | command from the top level of the tempest directory: |
| 84 | |
| 85 | tox -egenconfig |
Matthew Treinish | 6eb0585 | 2013-11-26 15:28:12 +0000 | [diff] [blame] | 86 | |
Sean Dague | b56052b | 2013-05-21 17:57:41 -0400 | [diff] [blame] | 87 | The most important pieces that are needed are the user ids, openstack |
| 88 | endpoints, and basic flavors and images needed to run tests. |
Daryl Walleck | e36f623 | 2012-03-06 00:21:45 -0600 | [diff] [blame] | 89 | |
| 90 | Common Issues |
| 91 | ------------- |
| 92 | |
| 93 | Tempest was originally designed to primarily run against a full OpenStack |
| 94 | deployment. Due to that focus, some issues may occur when running Tempest |
| 95 | against devstack. |
| 96 | |
| 97 | Running Tempest, especially in parallel, against a devstack instance may |
| 98 | cause requests to be rate limited, which will cause unexpected failures. |
| 99 | Given the number of requests Tempest can make against a cluster, rate limiting |
| 100 | should be disabled for all test accounts. |
| 101 | |
| 102 | Additionally, devstack only provides a single image which Nova can use. |
| 103 | For the moment, the best solution is to provide the same image uuid for |
| 104 | both image_ref and image_ref_alt. Tempest will skip tests as needed if it |
| 105 | detects that both images are the same. |
Matthew Treinish | a7c7f9f | 2014-01-13 18:20:50 +0000 | [diff] [blame] | 106 | |
| 107 | Unit Tests |
| 108 | ---------- |
| 109 | |
| 110 | Tempest also has a set of unit tests which test the tempest code itself. These |
| 111 | tests can be run by specifing the test discovery path:: |
| 112 | |
| 113 | $> OS_TEST_PATH=./tempest/tests testr run --parallel |
| 114 | |
| 115 | By setting OS_TEST_PATH to ./tempest/tests it specifies that test discover |
| 116 | should only be run on the unit test directory. The default value of OS_TEST_PATH |
| 117 | is OS_TEST_PATH=./tempest/test_discover which will only run test discover on the |
| 118 | tempest suite. |
| 119 | |
| 120 | Alternatively, you can use the run_tests.sh script which will create a venv and |
| 121 | run the unit tests. There are also the py26, py27, or py33 tox jobs which will |
| 122 | run the unit tests with the corresponding version of python. |
Matthew Treinish | af37dc9 | 2014-02-13 14:35:38 -0500 | [diff] [blame] | 123 | |
| 124 | Python 2.6 |
| 125 | ---------- |
| 126 | |
Matthew Treinish | d28dd7b | 2015-02-23 11:52:33 -0500 | [diff] [blame] | 127 | Starting in the kilo release the OpenStack services dropped all support for |
| 128 | python 2.6. This change has been mirrored in tempest, starting after the |
| 129 | tempest-2 tag. This means that proposed changes to tempest which only fix |
| 130 | python 2.6 compatibility will be rejected, and moving forward more features not |
| 131 | present in python 2.6 will be used. If you're running you're OpenStack services |
| 132 | on an earlier release with python 2.6 you can easily run tempest against it |
| 133 | from a remote system running python 2.7. (or deploy a cloud guest in your cloud |
| 134 | that has python 2.7) |
Matthew Treinish | cd7bf62 | 2014-06-04 11:32:07 -0400 | [diff] [blame] | 135 | |
| 136 | Branchless Tempest Considerations |
| 137 | --------------------------------- |
| 138 | |
| 139 | Starting with the OpenStack Icehouse release Tempest no longer has any stable |
| 140 | branches. This is to better ensure API consistency between releases because |
| 141 | the API behavior should not change between releases. This means that the stable |
| 142 | branches are also gated by the Tempest master branch, which also means that |
| 143 | proposed commits to Tempest must work against both the master and all the |
| 144 | currently supported stable branches of the projects. As such there are a few |
| 145 | special considerations that have to be accounted for when pushing new changes |
| 146 | to tempest. |
| 147 | |
| 148 | 1. New Tests for new features |
| 149 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 150 | |
| 151 | When adding tests for new features that were not in previous releases of the |
| 152 | projects the new test has to be properly skipped with a feature flag. Whether |
| 153 | this is just as simple as using the @test.requires_ext() decorator to check |
| 154 | if the required extension (or discoverable optional API) is enabled or adding |
| 155 | a new config option to the appropriate section. If there isn't a method of |
| 156 | selecting the new **feature** from the config file then there won't be a |
| 157 | mechanism to disable the test with older stable releases and the new test won't |
| 158 | be able to merge. |
| 159 | |
| 160 | 2. Bug fix on core project needing Tempest changes |
| 161 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 162 | |
| 163 | When trying to land a bug fix which changes a tested API you'll have to use the |
| 164 | following procedure:: |
| 165 | |
| 166 | - Propose change to the project, get a +2 on the change even with failing |
| 167 | - Propose skip on Tempest which will only be approved after the |
| 168 | corresponding change in the project has a +2 on change |
| 169 | - Land project change in master and all open stable branches (if required) |
| 170 | - Land changed test in Tempest |
| 171 | |
| 172 | Otherwise the bug fix won't be able to land in the project. |
| 173 | |
| 174 | 3. New Tests for existing features |
| 175 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 176 | |
| 177 | If a test is being added for a feature that exists in all the current releases |
| 178 | of the projects then the only concern is that the API behavior is the same |
| 179 | across all the versions of the project being tested. If the behavior is not |
| 180 | consistent the test will not be able to merge. |
Matthew Treinish | 3eb7a89 | 2014-06-05 15:40:33 -0400 | [diff] [blame] | 181 | |
| 182 | API Stability |
| 183 | ------------- |
| 184 | |
| 185 | For new tests being added to Tempest the assumption is that the API being |
| 186 | tested is considered stable and adheres to the OpenStack API stability |
| 187 | guidelines. If an API is still considered experimental or in development then |
| 188 | it should not be tested by Tempest until it is considered stable. |