Files
api-sig/guidelines/testing.rst
Chris Yeoh e00144c3a0 Moves from markdown to rst
Changes format of files from markdown to reStructuredText
and adds the tox targets to verify the format and build
the html. Also adds bits and pieces needed to finish
bootstrapping the repository.

Change-Id: If559c21f19d7044a0d89b29e5743bf09c9da2ac1
2014-10-22 16:24:41 +10:30

1.3 KiB

Testing

This topic document serves to provide guidance on how to consistently and effectively test a project's public HTTP API.

Current State of Testing

TODO Enumerate the variety of HTTP API testing styles and systems used throughout OpenStack APIs.

Goals

There are many aspects to testing and at least as many stakeholders in their creation and use. Tests can operate at at least three levels:

  1. To validate or assist in the creation of new functionality or changes to existing code.
  2. To prevent regressions.
  3. To allow inspection and analysis of the system being tested.

API tests should strive to enable each of these without limiting the others.

Proposals

  1. Each project should have a suite of declarative tests which exercise the full breadth of the API, closely mirroring the HTTP requests and responses. Being declarative allows easy inspection for those who wish to create or understand clients of the service. It is also instructive in revealing a certain lack of grace in API construction which can be obscured by code-based tests.
  2. Black-box testing of APIs is desirable. They do not strictly require a web service to be run. WSGI applications can be called directly with constructed environments, or using intercepts.
  3. your input here