An opinionated way to translate server side HTTP errors to the client side.
Project description
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
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2c82240790989fbd9a8ed29f4503310e0da796311a504fefe6d38d0e8fa2bc55 |
|
MD5 | 5f41deec2146f77fcb989c1472fed1d6 |
|
BLAKE2b-256 | 1226aabe6d49282be0584638a7e88785f80c22b636b311103f8b7f47bdef6444 |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 28193a5f36a37ab69d4a4cfbd5a8c7d327cd0978ef461069519936e2873913aa |
|
MD5 | 9cbd6ec4cc3db163e9daef30c921f29a |
|
BLAKE2b-256 | 3d778bce7891ea696641d256e7f55f34b0a6891218e8eeb7e28781f9f311054e |