.. image:: https://travis-ci.org/Trax-air/swagger-stub.svg?branch=master :alt: Travis status :target: https://travis-ci.org/Trax-air/swagger-stub .. image:: https://badges.gitter.im/Trax-air/swagger-stub.svg :alt: Join the chat at https://gitter.im/Trax-air/swagger-stub :target: https://gitter.im/Trax-air/swagger-stub?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge .. image:: https://img.shields.io/pypi/v/swagger-stub.svg :target: https://pypi.python.org/pypi/swagger-stub/
Swagger-stub create automatically a stub of your swagger REST API. This stub can be used anywhere you want like in a pytest fixture for your unit test.
In addition of mocking your API, you can mock some call, and check every call that have been made to the API.
You may find related libraries to this one:
.. code:: python
import pytest import requests
from swagger_stub import swagger_stub
@pytest.fixture def test_stub(): return swagger_stub([('swagger.yaml', 'http://foo.com')]).next()
def test_swagger_stub(test_stub):
test_stub.definitions['Foo']
# Check a simple call
response = requests.get('http://foo.com/v1/bar/')
assert response.status_code == 200
assert response.json() == {
'foo': 'bar'
}
# Check that an invalid body cause an error
response = requests.post('http://foo.com/v1/bar/', data='invalid data')
assert response.status_code == 400
# Mock a call
test_stub.add_mock_call('get', '/test', {'mock': 'call'})
response = requests.get('http://foo.com/v1/test')
assert response.json() == {'mock': 'call'}
# Set some side_effect like in the mock library
test_stub.add_mock_side_effect('get', '/iter', [{'test': '1'}, {'test': '2'}, {'test': '3'}])
response = requests.get('http://foo.com/v1/iter')
assert response.json() == {'test': '1'}
response = requests.get('http://foo.com/v1/iter')
assert response.json() == {'test': '2'}
response = requests.get('http://foo.com/v1/iter')
assert response.json() == {'test': '3'}
# This side effect will raise a custom error
test_stub.add_mock_side_effect('get', '/error', Exception)
with pytest.raises(Exception):
response = requests.get('http://foo.com/v1/error')
More documentation is available at https://swagger-stub.readthedocs.org/en/latest/.
make install
or pip install swagger-stub
swagger-stub is licensed under http://opensource.org/licenses/MIT.