Generate a stub from a swagger file
Project description
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.
Example Usage
import pytest
import requests
from swagger_stub import swagger_stub
# This is the fixture of your stub
# You only need to specify the path of the swagger file and the address
# where you want to bind your stub.
@pytest.fixture
def test_stub():
return swagger_stub([('swagger.yaml', 'http://foo.com')]).next()
# Then you can use this fixture anywhere you want like your API is really running.
def test_swagger_stub(test_stub):
# 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')
Documentation
More documentation is available at https://swagger-stub.readthedocs.org/en/latest/.
Setup
make install or pip install swagger-stub
License
swagger-stub is licensed under http://opensource.org/licenses/GPL-3.0.
History
0.1 (2016-1-29)
First release on PyPI.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
swagger_stub-0.1.tar.gz
(29.1 kB
view hashes)
Built Distribution
Close
Hashes for swagger_stub-0.1-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c1fe67bbdeb06bcdd2a2621ec85cc3b058eba9118e3b0a0041c54c51a3c404b9 |
|
MD5 | 97fca24f7617893832bbf731dd3fd644 |
|
BLAKE2b-256 | 9229b6e18399e2fcae67faced13d3fe012a1997f20f9c6eeea1d53af7916010f |