Skip to main content

An opinionated way to translate server side HTTP errors to the client side.

Project description

tests PyPI version shields.io PyPI pyversions Coverage Status

httpyexpect

An opinionated way to translate server side HTTP errors to the client side.

Installation

This package is available at PyPI: https://pypi.org/project/httpyexpect

You can install it from there using:

pip install httpyexpect

If you want to use the server-oriented utilities of the package, please install the following extra: server.

Client-Server Contract

Httpyexcept proposes a client-server contract on how to communicate exceptions. All error responses coming from the server (i.e. all responses with a 4xx or a 5xx status code) should have a body that complies with the following schema:

Usage

A detailed documentation is coming soon, until then please have a look at the integration tests as a usage example.

test_fastapi.py demonstrates the server side usage with FastAPI.

test_client.py demonstrates how to translate an HTTP error into a Python exception on the client side.

Development

For setting up the development environment, we rely on the devcontainer feature of vscode.

To use it, you have to have Docker as well as vscode with its "Remote - Containers" extension (ms-vscode-remote.remote-containers) extension installed. Then, you just have to open this repo in vscode and run the command Remote-Containers: Reopen in Container from the vscode "Command Palette".

This will give you a full-fledged, pre-configured development environment including:

  • infrastructural dependencies of the service (databases, etc.)
  • all relevant vscode extensions pre-installed
  • pre-configured linting and auto-formating
  • a pre-configured debugger
  • automatic license-header insertion

Moreover, inside the devcontainer, there is follwing convenience command available (please type it in the integrated terminal of vscode):

  • dev_install - install the lib with all development dependencies and pre-commit hooks (please run that if you are starting the devcontainer for the first time or if added any python dependencies to the ./setup.cfg)

If you prefer not to use vscode, you could get a similar setup (without the editor specific features) by running the following commands:

# Execute in the repo's root dir:
cd ./.devcontainer

# build and run the environment with docker-compose
docker build -t httpyexpect .
docker run -it httpyexpect /bin/bash

License

This repository is free to use and modify according to the Apache 2.0 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

httpyexpect-0.2.7.tar.gz (29.2 kB view details)

Uploaded Source

Built Distribution

httpyexpect-0.2.7-py3-none-any.whl (52.3 kB view details)

Uploaded Python 3

File details

Details for the file httpyexpect-0.2.7.tar.gz.

File metadata

  • Download URL: httpyexpect-0.2.7.tar.gz
  • Upload date:
  • Size: 29.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for httpyexpect-0.2.7.tar.gz
Algorithm Hash digest
SHA256 2c82240790989fbd9a8ed29f4503310e0da796311a504fefe6d38d0e8fa2bc55
MD5 5f41deec2146f77fcb989c1472fed1d6
BLAKE2b-256 1226aabe6d49282be0584638a7e88785f80c22b636b311103f8b7f47bdef6444

See more details on using hashes here.

File details

Details for the file httpyexpect-0.2.7-py3-none-any.whl.

File metadata

  • Download URL: httpyexpect-0.2.7-py3-none-any.whl
  • Upload date:
  • Size: 52.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for httpyexpect-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 28193a5f36a37ab69d4a4cfbd5a8c7d327cd0978ef461069519936e2873913aa
MD5 9cbd6ec4cc3db163e9daef30c921f29a
BLAKE2b-256 3d778bce7891ea696641d256e7f55f34b0a6891218e8eeb7e28781f9f311054e

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