GitXplorerGitXplorer
a

requests-mock-flask

public
9 stars
0 forks
1 issues

Commits

List of commits on branch main.
Verified
df628a478832665efa9d4c9b7ad3cb13fed79c0a

Merge pull request #1249 from adamtheturtle/per-file-ignores

aadamtheturtle committed 11 hours ago
Verified
5a296857eb536a1d42712cb995d26c9b1a4d9de6

Use new format for pylint-per-file-ignores

aadamtheturtle committed 11 hours ago
Verified
f829cacc76e2922d44c2902abcb43ef160afd50f

Merge pull request #1248 from adamtheturtle/dependabot/pip/ruff-0.9.2

ggithub-actions[bot] committed 2 days ago
Verified
fd643e01e3a4957bf3a6916f233995e951875af6

Bump ruff from 0.9.1 to 0.9.2

ddependabot[bot] committed 2 days ago
Verified
603841c3ddea682081a5bc14d244eb70136c9145

Merge pull request #1247 from adamtheturtle/bump-uv-precommit

aadamtheturtle committed 2 days ago
Verified
934b9eb26f2a03a946765583b08714d8cc842a1c

Bump uv in pre-commit hooks to 0.5.20

aadamtheturtle committed 2 days ago

README

The README file for this repository.

|Build Status| |codecov| |PyPI| |Documentation Status|

requests-mock-flask

requests-mock-flask helps with testing Flask_ applications with httpretty, responses or requests-mock_.

.. contents:: :local:

Installation

Requires Python |minimum-python-version|+.

.. code-block:: sh

pip install requests-mock-flask

Usage example

.. code-block:: python

""" Examples of using requests-mock-flask with responses, requests-mock and httpretty. """

from http import HTTPStatus

import flask import httpretty # pyright: ignore[reportMissingTypeStubs] import requests import requests_mock import responses

from requests_mock_flask import add_flask_app_to_mock

app = flask.Flask(import_name="test_app")

@app.route(rule="/") def _() -> str: """Return a simple message.""" return "Hello, World!"

@responses.activate def test_responses_decorator() -> None: """ It is possible to use the helper with a responses decorator. """ add_flask_app_to_mock( mock_obj=responses, flask_app=app, base_url="http://www.example.com", )

   response = requests.get(url="http://www.example.com", timeout=30)

   assert response.status_code == HTTPStatus.OK
   assert response.text == "Hello, World!"

def test_responses_context_manager() -> None: """ It is possible to use the helper with a responses context manager. """ with responses.RequestsMock( assert_all_requests_are_fired=False, ) as resp_m: add_flask_app_to_mock( mock_obj=resp_m, flask_app=app, base_url="http://www.example.com", )

       response = requests.get(url="http://www.example.com", timeout=30)

       assert response.status_code == HTTPStatus.OK
       assert response.text == "Hello, World!"

def test_requests_mock_context_manager() -> None: """ It is possible to use the helper with a requests_mock context manager. """ with requests_mock.Mocker() as resp_m: add_flask_app_to_mock( mock_obj=resp_m, flask_app=app, base_url="http://www.example.com", )

       response = requests.get(url="http://www.example.com", timeout=30)

   assert response.status_code == HTTPStatus.OK
   assert response.text == "Hello, World!"

def test_requests_mock_adapter() -> None: """ It is possible to use the helper with a requests_mock fixture. """ session = requests.Session() adapter = requests_mock.Adapter() session.mount(prefix="mock", adapter=adapter)

   add_flask_app_to_mock(
       mock_obj=adapter,
       flask_app=app,
       base_url="mock://www.example.com",
   )

   response = session.get(url="mock://www.example.com", timeout=30)

   assert response.status_code == HTTPStatus.OK
   assert response.text == "Hello, World!"

def test_httpretty_context_manager() -> None: """ It is possible to use the helper with a httpretty context manager. """ with httpretty.core.httprettized(): # type: ignore[no-untyped-call] add_flask_app_to_mock( mock_obj=httpretty, flask_app=app, base_url="http://www.example.com", )

       response = requests.get(url="http://www.example.com", timeout=30)

   assert response.status_code == HTTPStatus.OK
   assert response.text == "Hello, World!"

Use cases

  • Use requests or other Python APIs for testing Flask applications.
  • Create a test suite which can test a Flask application as well as a live web application, to make a verified fake.
  • Test a service which calls a Flask application that you have the source code for.

Full documentation

See the full documentation <https://requests-mock-flask.readthedocs.io/en/latest>__ for more information including how to contribute.

.. _Flask: https://flask.palletsprojects.com/ .. _requests-mock: https://requests-mock.readthedocs.io/en/latest/ .. _responses: https://github.com/getsentry/responses .. _httpretty: https://httpretty.readthedocs.io

.. |Build Status| image:: https://github.com/adamtheturtle/requests-mock-flask/actions/workflows/ci.yml/badge.svg?branch=main :target: https://github.com/adamtheturtle/requests-mock-flask/actions .. |codecov| image:: https://codecov.io/gh/adamtheturtle/requests-mock-flask/branch/main/graph/badge.svg :target: https://codecov.io/gh/adamtheturtle/requests-mock-flask .. |Documentation Status| image:: https://readthedocs.org/projects/requests-mock-flask/badge/?version=latest :target: https://requests-mock-flask.readthedocs.io/en/latest/?badge=latest :alt: Documentation Status .. |PyPI| image:: https://badge.fury.io/py/requests-mock-flask.svg :target: https://badge.fury.io/py/requests-mock-flask .. |minimum-python-version| replace:: 3.12