 e00144c3a0
			
		
	
	e00144c3a0
	
	
	
		
			
			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
		
			
				
	
	
	
		
			1.3 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			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:
- To validate or assist in the creation of new functionality or changes to existing code.
- To prevent regressions.
- To allow inspection and analysis of the system being tested.
API tests should strive to enable each of these without limiting the others.
Proposals
- 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.
- 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.
- your input here