Initial high level documentation for Tempest

Change-Id: I8c84c56e9bf98c569966d5334a8c24bbfcf321d9
This commit is contained in:
Daryl Walleck 2011-11-30 02:13:30 -06:00
parent 39c0801b70
commit 73e440817c

View File

@ -13,12 +13,9 @@ White box testing refers to tests where the test runner can access
internal data structures (machine state) or algorithms in order to internal data structures (machine state) or algorithms in order to
verify a specification. verify a specification.
In black box testing, only the public API is ever called, since internal In black box testing, only the public API or other externally facing resources are ever called, since internal interfaces would give access to internal machine state, and the goal is typically to verify that a public API behaves according to its publically documented specification.
interfaces would give access to internal machine state, and the goal is
typically to verify that a public API behaves according to its publically
documented specification.
The ``openstack-integration-tests`` Project The ``Tempest`` Project
******************************************* *******************************************
There was a proliferation of integration test suites in 2011, and at the There was a proliferation of integration test suites in 2011, and at the
@ -26,24 +23,73 @@ Essex design summit, a number of interested parties, including authors of
the various existing integration test suites -- met to discuss a plan the various existing integration test suites -- met to discuss a plan
to consolidate similar test suites into a single project that everyone to consolidate similar test suites into a single project that everyone
could focus their efforts on. The resulting project is the could focus their efforts on. The resulting project is the
``openstack-integration-tests`` project. This project contains functional ``Tempest`` project. This project contains functional and integration tests that are meant to be executed against a fully-deployed OpenStack environment.
and integration tests that are meant to be executed against a fully-deployed
OpenStack environment.
.. note .. note
You should join the OpenStack QA team on Launchpad to contribute You should join the OpenStack QA team on Launchpad to contribute
to the ``openstack-integration-tests`` project. to the ``Tempest`` project.
Source Code Structure Source Code Structure
~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~
The project source code is divided into a number of directories, containing The project source code is divided up in such a way that additional or
various stand-alone test suites as well as a number of scripts for running alternate functionality can easily be added to the framework. The current
whole suites or sets of individual test cases. directory structure is shown below.
Architecture of Main Suite Runner * etc
* include
* kong
* tempest
- common
- services
- tests
* tools
Of these, the include, kong, and tools directories are deprecated and will
soon be removed. Of the remaining directories, their purposes are:
* etc - a directory for text configuration files
* common - a set of reusable classes that provide additional functionality for testing and verification purposes
* services - code abstractions of an API. These clients provide access to the application under test in a simple and straightforward manner using domain specific terminology
* tests - a directory for the tests themselves. While this is currently a flat directory, the expectation is that subdirectories will be created to logically divide tests by project and logical functionality
Project Goals and Architecture
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
When designing this framework, the primary focus were the following goals: ease of development, scalability, flexibility, and maintainability. This means that a test class can take action via the client without having to format and make a request. The client then becomes a middle man between the tests and a simple REST client. This separation of concerns has the benefit of not only x, but also reduces the refactoring impact when changes are made to the application under test.
Adding a New Integration Test To achieve the first goal, domain specific clients were developed. In doing so, several things were achieved. First, some of the complexity of testing APIs such as handling requests, authentication, and parsing of responses are already handled. An additional benefit is that in doing so, the structure and logic of the REST request itself is removed from the tests into a single location. This increases the maintainability of the code since when a change in logic or request structure occurs, only the client code needs to change.
Configuring Tempest
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
To make execution of Tempest flexible, values that will vary by environment are expected to be provided by an external data source, which is currently an external configuration file.
Additionally, Tempest takes into account that certain functionality may vary or not be usable based on the environment the tests are executed against. To avoid execution of tests that are not valid in a given environment, feature flags can also be set which will skip over executing tests that are not valid for the environment under test. For more detailed information, see the Temptest_README file and the example Tempest configuration file which are located in the /etc directory.
Running Tempest
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Tests can be run using the Nose test runner. To run a test or a group of tests, execute the nosetests command with a specific test file or directory as a parameter. For example, running "nosetests tempest/tests" will run all tests in the tempest/tests directory.
Adding a New Test
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* Create new files/subdirectories for the functionality to be tested
* Add attributes to the test to describe its purpose
* Create an instance of the OpenStack manager class
* Pull test data from external sources if necessary
* Execute the desired scenario using service methods exposed via the clients or capabilities provided by common libraries
* Make any necessary assertions to verify the goal of the test has been met
In the development of tests, some patterns and practices have come into being:
* Individual tests should make no assumptions on the current state of the application. tests should either create their own resources or rely on provided known good values from external sources
* Tests should have a very clear focus. Trying to test too much in a single test makes the purpose of a test unclear.
Future Development
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* Additional data sources for test data and configuration
* Parallel test execution
* Detailed logging
* Support for testing with XML requests/responses
* Improved reporting over the standard Nose xunit results