2016-02-23 15:55:53 +00:00
|
|
|
.. _library:
|
|
|
|
|
2016-03-07 15:17:08 +00:00
|
|
|
Tempest Library Documentation
|
2016-02-23 15:55:53 +00:00
|
|
|
=============================
|
|
|
|
|
|
|
|
Tempest provides a stable library interface that provides external tools or
|
|
|
|
test suites an interface for reusing pieces of tempest code. Any public
|
|
|
|
interface that lives in tempest/lib in the tempest repo is treated as a stable
|
|
|
|
public interface and it should be safe to external consume that. Every effort
|
2016-04-29 19:26:22 +00:00
|
|
|
goes into maintaining backwards compatibility with any change.
|
|
|
|
The library is self contained and doesn't have any dependency on
|
|
|
|
other tempest internals outside of lib (including no usage of tempest
|
|
|
|
configuration).
|
2016-02-23 15:55:53 +00:00
|
|
|
|
|
|
|
Stability
|
|
|
|
---------
|
2016-04-29 19:26:22 +00:00
|
|
|
Any code that lives in tempest/lib will be treated as a stable interface.
|
2016-02-23 15:55:53 +00:00
|
|
|
This means that any public interface under the tempest/lib directory is
|
|
|
|
expected to be a stable interface suitable for public consumption. However, for
|
|
|
|
any interfaces outside of tempest/lib in the tempest tree (unless otherwise
|
|
|
|
noted) or any private interfaces the same stability guarantees don't apply.
|
|
|
|
|
|
|
|
Adding Interfaces
|
|
|
|
'''''''''''''''''
|
|
|
|
When adding an interface to tempest/lib we have to make sure there are no
|
|
|
|
dependencies on any pieces of tempest outside of tempest/lib. This means if
|
|
|
|
for example there is a dependency on the configuration file we need remove that.
|
|
|
|
The other aspect when adding an interface is to make sure it's really an
|
|
|
|
interface ready for external consumption and something we want to commit to
|
|
|
|
supporting.
|
|
|
|
|
|
|
|
Making changes
|
|
|
|
''''''''''''''
|
|
|
|
When making changes to tempest/lib you have to be conscious of the effect of
|
|
|
|
any changes on external consumers. If your proposed changeset will change the
|
|
|
|
default behaviour of any interface, or make something which previously worked
|
|
|
|
not after your change, then it is not acceptable. Every effort needs to go into
|
|
|
|
preserving backwards compatibility in changes.
|
|
|
|
|
|
|
|
Reviewing
|
|
|
|
'''''''''
|
|
|
|
When reviewing a proposed change to tempest/lib code we need to be careful to
|
|
|
|
ensure that we don't break backwards compatibility. For patches that change
|
|
|
|
existing interfaces we have to be careful to make sure we don't break any
|
|
|
|
external consumers. Some common red flags are:
|
|
|
|
|
|
|
|
* a change to an existing API requires a change outside the library directory
|
|
|
|
where the interface is being consumed
|
|
|
|
* a unit test has to be significantly changed to make the proposed change pass
|
|
|
|
|
|
|
|
Testing
|
|
|
|
'''''''
|
|
|
|
When adding a new interface to the library we need to at a minimum have unit
|
|
|
|
test coverage. A proposed change to add an interface to tempest/lib that
|
|
|
|
doesn't have unit tests shouldn't be accepted. Ideally these unit tests will
|
|
|
|
provide sufficient coverage to ensure a stable interface moving forward.
|
|
|
|
|
|
|
|
Current Library APIs
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 2
|
|
|
|
|
|
|
|
library/cli
|
|
|
|
library/decorators
|
|
|
|
library/rest_client
|
|
|
|
library/utils
|
2016-02-24 19:57:18 +00:00
|
|
|
library/api_microversion_testing
|
2016-06-10 01:40:02 +00:00
|
|
|
library/auth
|