🕸🤖👺 A Python tool to mock API easily and humanly without any coding.
Project description
PyMock-API
A Python tool to mock API easily and humanly without any coding.
Overview | Python versions support | Quickly Start | Documentation
Overview
Do you ever have experience about needing to set up a very simple application and write some APIs with hardcode response again and again for developing Font-End site? PyMock-API provides a command line tool to let developers could quickly and easily set up application to mock APIs with configuration only.
Python versions support
The code base of PyMock-API to set up an application still depends on third party Python package, i.e., Flask, FastAPI, etc. So the Python versions it supports also be affected by them, e.g., Flask only supports Python version 3.8 up currently. So PyMock-API also only supports version Python 3.8 up.
Quickly Start
Here section would lead you quickly start to set up your first one application by PyMock-API for mocking APIs easily.
In basically, it has 3 steps: install the package, configure settings about the APIs for mocking and run command.
Install command line tool
First of all, we need to install the command line tool and the way to install is same as installing Python package by pip
.
>>> pip install pymock-api
If the runtime environment has installed some Python web framework, e.g., Flask, you also could install Pymock-API with one specific option as following:
>>> pip install "pymock-api[flask]"
Then it would only install the lowest Python dependencies you need.
After you done above step, please make sure the command line tool feature should work finely by below command:
>>> mock-api --help
Note
Please take a look at option --app-type (this option is in subcommand mock-api run) of the command line tool. Its option value could be
auto
,flask
orfastapi
. It means that PyMock-API only supports 2 Python web frameworks: Flask and FastAPI.
Configure setting to mock target APIs
Now, we have the command line tool. Let's configure the settings it needs to set up application to mock API.
The configuration format of PyMock-API to use is YAML. So let's write below settings in YAML file:
mocked_apis:
google_home:
url: '/google'
http:
request:
method: 'GET'
response:
strategy: string
value: 'This is Google home API.'
Run command to set up application
Now, both of the command line tool and configuration have been already. So let's try to run the command to set up application!
>>> mock-api run -c <your configuration path>
You would see some log messages in terminal and that is the log of web server by one specific Python web framework.
And you could test the API by curl
:
>>> curl http://127.0.0.1:9672/google
"This is Google home API."%
Documentation
Currently, it won't have documentation. But it would have soon.
Coding style and following rules
PyMock-API follows coding styles black and PyLint to control code quality.
Downloading state
PyMock-API still a young open source which keep growing. Here's its download state:
License
Project details
Release history Release notifications | RSS feed
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 pymock_api-0.1.0.tar.gz
.
File metadata
- Download URL: pymock_api-0.1.0.tar.gz
- Upload date:
- Size: 54.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.2 CPython/3.10.13 Linux/6.5.0-1016-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 59832e5b38c7ccfbaddf98fcc45d87fff36f71215e1cc85e481d93e7c2cd1190 |
|
MD5 | aba4a09d7dfdb05f0afc86e5d78984ed |
|
BLAKE2b-256 | 631b73346e2e3649547e10c7ca55b9d04991ab81b01b430e9d6c0045c42bb3f6 |
File details
Details for the file pymock_api-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: pymock_api-0.1.0-py3-none-any.whl
- Upload date:
- Size: 75.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.2 CPython/3.10.13 Linux/6.5.0-1016-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b3acdba71c8a970f2a2d654bd80a2c5916b428bde8448cc663f3c7724afa8410 |
|
MD5 | 3e1a47c98cfe19d7b9aa84a7554b8bd9 |
|
BLAKE2b-256 | 4ee5cf5d287eed9303680d43052dca88636f5cbe97480c7864362e0ea223a418 |