Skip to main content

A static HTTP mock interface for requests

Project description

requests-staticmock

https://img.shields.io/pypi/v/requests-staticmock.svg https://img.shields.io/travis/tonybaloney/requests-staticmock.svg Documentation Status https://coveralls.io/repos/github/tonybaloney/requests-staticmock/badge.svg?branch=master

A static HTTP mock interface for testing classes that leverage Python requests with no monkey patching!

Usage

As a context manager for requests Session instances

The requests_staticmock

import requests
import requests_staticmock

session = requests.Session()
with requests_staticmock.mock_session_with_fixtures(session, 'tests/fixtures', 'http://test_context.com'):
    # will return a response object with the contents of tests/fixtures/test.json
    response = new_session.request('get', 'http://test_context.com/test.json')

As an adapter

You can inject the requests_staticmock adapter into an existing (or new) requests session to mock out a particular URL or domain, e.g.

import requests
from requests_staticmock import Adapter

session = requests.Session()
special_adapter = Adapter('fixtures')
session.mount('http://specialwebsite.com', special_adapter)
session.request('http://normal.com/api/example') # works as normal
session.request('http://specialwebsite.com') # returns static mocks

Class adapter

Instead of using a static asset adapter, you can use an adapter that expects an internal method to respond with a string, e.g.

GET /test/example.xml will call method _test_example_xml(self, request)

GET /test/example.xml?query=param will call method _test_example_xml(self, request)

This can be used via requests_staticmock.ClassAdapter or the context manager

import requests
import requests_staticmock


class MyTestClass(requests_staticmock.BaseMockClass):
    def _api_v1_idea(self, request):
        return "woop woop"

session = requests.Session()
with requests_staticmock.mock_session_with_class(session, MyTestClass, 'http://test_context.com'):
    # will return a response object with the contents 'woop woop'
    response = new_session.request('get', 'http://test_context.com/api/v1/idea')

Class adapter with unpacked requests

The class adapter supports unpacking of the following components, just add these keyword arguments to your callback methods and the class adapter will match them to the arguments.

  • method - The HTTP verb, e.g. GET

  • url - The full URL

  • params - The dict with the request parameters

  • headers - The request headers

  • body - The request body text

import requests
import requests_staticmock

class_session = Session()
class TestMockClass(BaseMockClass):
    def _api_v1_idea(self, method, params, headers):
        if params['special'] == 'value':
            return 'yes'
    def _api_v1_brillo(self, url, body):
        if json.loads(body)['special'] == 'value':
            return 'yes'

a = ClassAdapter(TestMockClass)

session = requests.Session()
with requests_staticmock.mock_session_with_class(session, MyTestClass, 'http://test_context.com'):
    response = new_session.request('get', 'http://test_context.com/api/v1/idea')

Features

  • Allow mocking of HTTP responses via a directory of static fixtures

  • Support for sub-directories matching URL paths

Credits

This project takes inspiration and ideas from the requests_mock package, maintained by the OpenStack foundation.

This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.

History

1.4.0 (2017-09-01)

  • Class adapter correctly maps - character to _ as - is invalid method name in Python

1.3.0 (2017-09-01)

  • Add a property in MockClass for the adapter instance, helps when you want to respond with static fixture data

1.2.0 (2017-05-10)

  • Add support for case-insensitive file matching

1.1.0 (2017-05-10)

  • Add support for query params being part of the file path

0.8.0 (2017-02-02)

  • Add support for streaming requests and iter_content/iter_lines

0.7.0 (2017-01-29)

  • Add support version unpacking, class adapters now support a range of keyword arguments, provided in no particular order.

0.6.0 (2017-01-29)

  • Add support for the class adapter methods to return either a string or a response object

  • Moved to Py.Test

0.3.0 (2017-01-29)

  • Added a class adapter

0.2.0 (2017-01-28)

  • Added a context manager for the static mocks

0.1.0 (2017-01-01)

  • 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

requests-staticmock-1.4.0.tar.gz (20.9 kB view details)

Uploaded Source

Built Distribution

requests_staticmock-1.4.0-py2.py3-none-any.whl (12.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file requests-staticmock-1.4.0.tar.gz.

File metadata

File hashes

Hashes for requests-staticmock-1.4.0.tar.gz
Algorithm Hash digest
SHA256 19b31043c4457a39c2baf617f9d0db72d52989164400130633cd8ffa3cdbf16f
MD5 3cc1a05c9f826551d1684e41aa824695
BLAKE2b-256 18e093e746fb933ea2978ed665ad18309b4fd02cb5371c9d67e6fccde4156572

See more details on using hashes here.

File details

Details for the file requests_staticmock-1.4.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for requests_staticmock-1.4.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 11814ebf2d3a6bda1412946f7c7b707a6ffaa62802d1c22aca31453238eba5e0
MD5 7f4dfbe37846eca5989e09a3b7bf5b55
BLAKE2b-256 3e585ee6f087ad2783773087f4263a82d3b17e1653ed0a8dd675fcf2d9091d6d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page