| .. _api_field_guide: |
| |
| Tempest Field Guide to API tests |
| ================================ |
| |
| |
| What are these tests? |
| --------------------- |
| |
| One of Tempest's prime function is to ensure that your OpenStack cloud |
| works with the OpenStack API as documented. The current largest |
| portion of Tempest code is devoted to test cases that do exactly this. |
| |
| It's also important to test not only the expected positive path on |
| APIs, but also to provide them with invalid data to ensure they fail |
| in expected and documented ways. The latter type of tests is called |
| ``negative tests`` in Tempest source code. Over the course of the OpenStack |
| project Tempest has discovered many fundamental bugs by doing just |
| this. |
| |
| In order for some APIs to return meaningful results, there must be |
| enough data in the system. This means these tests might start by |
| spinning up a server, image, etc, then operating on it. |
| |
| |
| Why are these tests in Tempest? |
| ------------------------------- |
| |
| This is one of the core missions for the Tempest project, and where it |
| started. Many people use this bit of function in Tempest to ensure |
| their clouds haven't broken the OpenStack API. |
| |
| It could be argued that some of the negative testing could be done |
| back in the projects themselves, and we might evolve there over time, |
| but currently in the OpenStack gate this is a fundamentally important |
| place to keep things. |
| |
| |
| Scope of these tests |
| -------------------- |
| |
| API tests should always use the Tempest implementation of the |
| OpenStack API, as we want to ensure that bugs aren't hidden by the |
| official clients. |
| |
| They should test specific API calls, and can build up complex state if |
| it's needed for the API call to be meaningful. |
| |
| They should send not only good data, but bad data at the API and look |
| for error codes. |
| |
| They should all be able to be run on their own, not depending on the |
| state created by a previous test. |