Metadata-Version: 1.1
Name: swagger-stub
Version: 0.1
Summary: Generate a stub from a swagger file
Home-page: https://github.com/Trax-air/swagger-stub
Author: Cyprien Guillemot
Author-email: cyprien.guillemot@gmail.com
License: GPL
Description: .. image:: https://travis-ci.org/Trax-air/swagger-stub.svg?branch=master
           :alt: Travis status
           :target: https://travis-ci.org/Trax-air/swagger-stub
        
        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
        -------------
        
        .. code:: python
        
          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.
        
Keywords: swagger,stub,API,REST,swagger-stub
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: GNU General Public License v3 (GPLv3)
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
