Attila Fazekas | 58d2330 | 2013-07-24 10:25:02 +0200 | [diff] [blame] | 1 | ============================ |
Sean Dague | 7679b48 | 2013-05-24 08:49:44 -0400 | [diff] [blame] | 2 | Tempest Field Guide Overview |
Attila Fazekas | 58d2330 | 2013-07-24 10:25:02 +0200 | [diff] [blame] | 3 | ============================ |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 4 | |
| 5 | Tempest is designed to be useful for a large number of different |
| 6 | environments. This includes being useful for gating commits to |
| 7 | OpenStack core projects, being used to validate OpenStack cloud |
| 8 | implementations for both correctness, as well as a burn in tool for |
| 9 | OpenStack clouds. |
| 10 | |
| 11 | As such Tempest tests come in many flavors, each with their own rules |
Jordan Pittier | 74a56ab | 2017-04-26 16:46:20 +0200 | [diff] [blame] | 12 | and guidelines. Below is the overview of the Tempest respository structure |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 13 | to make this clear. |
| 14 | |
Xiao Hanyu | a4036d1 | 2013-06-19 14:12:23 +0800 | [diff] [blame] | 15 | | tempest/ |
| 16 | | api/ - API tests |
Xiao Hanyu | a4036d1 | 2013-06-19 14:12:23 +0800 | [diff] [blame] | 17 | | scenario/ - complex scenario tests |
Jordan Pittier | 74a56ab | 2017-04-26 16:46:20 +0200 | [diff] [blame] | 18 | | tests/ - unit tests for Tempest internals |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 19 | |
| 20 | Each of these directories contains different types of tests. What |
| 21 | belongs in each directory, the rules and examples for good tests, are |
| 22 | documented in a README.rst file in the directory. |
| 23 | |
Matthew Treinish | a9aef87 | 2014-07-25 16:03:08 -0400 | [diff] [blame] | 24 | :ref:`api_field_guide` |
| 25 | ---------------------- |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 26 | |
| 27 | API tests are validation tests for the OpenStack API. They should not |
Jordan Pittier | 74a56ab | 2017-04-26 16:46:20 +0200 | [diff] [blame] | 28 | use the existing Python clients for OpenStack, but should instead use |
| 29 | the Tempest implementations of clients. Having raw clients let us |
guo yunxian | a221647 | 2016-08-01 16:34:43 +0800 | [diff] [blame] | 30 | pass invalid JSON to the APIs and see the results, something we could |
| 31 | not get with the native clients. |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 32 | |
| 33 | When it makes sense, API testing should be moved closer to the |
| 34 | projects themselves, possibly as functional tests in their unit test |
| 35 | frameworks. |
| 36 | |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 37 | |
Matthew Treinish | a9aef87 | 2014-07-25 16:03:08 -0400 | [diff] [blame] | 38 | :ref:`scenario_field_guide` |
| 39 | --------------------------- |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 40 | |
| 41 | Scenario tests are complex "through path" tests for OpenStack |
| 42 | functionality. They are typically a series of steps where complicated |
| 43 | state requiring multiple services is set up exercised, and torn down. |
| 44 | |
Jordan Pittier | 74a56ab | 2017-04-26 16:46:20 +0200 | [diff] [blame] | 45 | Scenario tests should not use the existing Python clients for OpenStack, |
| 46 | but should instead use the Tempest implementations of clients. |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 47 | |
Sean Dague | 31a57ad | 2013-05-07 15:24:05 -0400 | [diff] [blame] | 48 | |
Matthew Treinish | 817a808 | 2014-07-25 16:07:20 -0400 | [diff] [blame] | 49 | :ref:`unit_tests_field_guide` |
| 50 | ----------------------------- |
| 51 | |
| 52 | Unit tests are the self checks for Tempest. They provide functional |
Jordan Pittier | 74a56ab | 2017-04-26 16:46:20 +0200 | [diff] [blame] | 53 | verification and regression checking for the internal components of Tempest. |
| 54 | They should be used to just verify that the individual pieces of Tempest are |
Matthew Treinish | 817a808 | 2014-07-25 16:07:20 -0400 | [diff] [blame] | 55 | working as expected. |