Skip to main content

Mock out responses from the requests package

Project description

https://badge.fury.io/py/requests-mock.png

Intro

requests-mock provides a building block to stub out the HTTP requests portions of your testing code. You should checkout the docs for more information.

The Basics

Everything in requests eventually goes through an adapter to do the transport work. requests-mock creates a custom adapter that allows you to predefine responses when certain URIs are called.

There are then a number of methods provided to get the adapter used.

A simple example:

>>> import requests
>>> import requests_mock

>>> session = requests.Session()
>>> adapter = requests_mock.Adapter()
>>> session.mount('mock://', adapter)

>>> adapter.register_uri('GET', 'mock://test.com', text='data')
>>> resp = session.get('mock://test.com')
>>> resp.status_code, resp.text
(200, 'data')

Obviously having all URLs be mock:// prefixed isn’t going to be useful, so you can use requests_mock.Mocker to get the adapter into place.

As a context manager:

>>> with requests_mock.Mocker() as m:
...     m.get('http://test.com', text='data')
...     requests.get('http://test.com').text
...
'data'

Or as a decorator:

>>> @requests_mock.Mocker()
... def test_func(m):
...     m.get('http://test.com', text='data')
...     return requests.get('http://test.com').text
...
>>> test_func()
'data'

Or as a pytest fixture:

>>> def test_simple(requests_mock):
...    requests_mock.get('http://test.com', text='data')
...    assert 'data' == requests.get('http://test.com').text

For more information checkout the docs.

Reporting Bugs

Development and bug tracking is performed on GitHub.

Questions

There is a tag dedicated to requests-mock on StackOverflow where you can ask usage questions.

License

Licensed under the Apache License, Version 2.0 (the “License”); you may not use this file except in compliance with the License. You may obtain a copy of the License at

https://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

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-mock-1.10.0.tar.gz (72.6 kB view details)

Uploaded Source

Built Distribution

requests_mock-1.10.0-py2.py3-none-any.whl (28.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file requests-mock-1.10.0.tar.gz.

File metadata

  • Download URL: requests-mock-1.10.0.tar.gz
  • Upload date:
  • Size: 72.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for requests-mock-1.10.0.tar.gz
Algorithm Hash digest
SHA256 59c9c32419a9fb1ae83ec242d98e889c45bd7d7a65d48375cc243ec08441658b
MD5 ce719611693cf91b6b8f961c1a96c10c
BLAKE2b-256 9eeac03f99a9df9086a686fd37072886563b5a9776d33b438147308fd95e4be7

See more details on using hashes here.

File details

Details for the file requests_mock-1.10.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for requests_mock-1.10.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 2fdbb637ad17ee15c06f33d31169e71bf9fe2bdb7bc9da26185be0dd8d842699
MD5 21da2332ab7e2bbe04c9d1d5473ddabb
BLAKE2b-256 b3f96de3ebddd002f92df8c3f3bcb75c59a4dcc3d3b70bd4fd74ad53b20ab78e

See more details on using hashes here.

Supported by

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