Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jakubtesarek/dbgr
Dbgr is a terminal tool to test and debug HTTP APIs.
https://github.com/jakubtesarek/dbgr
http http-client python python3 rest rest-api terminal testing testing-tools tool
Last synced: about 2 months ago
JSON representation
Dbgr is a terminal tool to test and debug HTTP APIs.
- Host: GitHub
- URL: https://github.com/jakubtesarek/dbgr
- Owner: JakubTesarek
- License: other
- Created: 2019-05-13T14:19:17.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2021-03-13T23:28:31.000Z (almost 4 years ago)
- Last Synced: 2024-10-01T09:02:57.234Z (3 months ago)
- Topics: http, http-client, python, python3, rest, rest-api, terminal, testing, testing-tools, tool
- Language: Python
- Homepage:
- Size: 170 KB
- Stars: 8
- Watchers: 1
- Forks: 0
- Open Issues: 25
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG.rst
Awesome Lists containing this project
README
DBGR: HTTP client that gives you full control
=============================================|PyPI version| |License| |Build Status| |Code Coverage| |Documentation Status|
.. |PyPI version| image:: https://badge.fury.io/py/dbgr.svg
:target: https://badge.fury.io/py/dbgr
.. |License| image:: https://img.shields.io/badge/License-Apache%202.0-blue.svg
:target: https://opensource.org/licenses/Apache-2.0
.. |Build Status| image:: https://travis-ci.org/JakubTesarek/dbgr.svg?branch=master
:target: https://travis-ci.org/JakubTesarek/dbgr
.. |Code Coverage| image:: https://codecov.io/gh/JakubTesarek/dbgr/branch/master/graph/badge.svg
:target: https://codecov.io/gh/JakubTesarek/dbgr
.. |Documentation Status| image:: https://readthedocs.org/projects/dbgr/badge/?version=latest
:target: https://dbgr.readthedocs.io/en/latest/?badge=latestDbgr [read 'ˌdiːˈbʌɡər'] is a interactive terminal tool to test and debug HTTP APIs.
It offers alternative to Postman_, Insomnia_ and other HTTP clients. It is designed
for programmers that prefer to use code instead of graphical tools and want full control
over their HTTP requests... _postman: https://www.getpostman.com/
.. _insomnia: https://insomnia.rest/`Full documentation can be found on Read the Docs`_
.. _`full documentation can be found on read the docs`: https://dbgr.readthedocs.io/en/latest/
Features
--------
- `Terminal interface with autocomplete and bash history`_
- `Full control over your requests with Python`_
- `Recursive calls`_
- `Local caching of responses`_
- `Customizable interface`_.. _`Terminal interface with autocomplete and bash history`: https://dbgr.readthedocs.io/en/latest/terminal-interface.html
.. _`Full control over your requests with Python`: https://dbgr.readthedocs.io/en/latest/requests.html#requests
.. _`Recursive calls`: https://dbgr.readthedocs.io/en/latest/recursive-calls.html#recursive-calls
.. _`Local caching of responses`: https://dbgr.readthedocs.io/en/latest/caching.html
.. _`Customizable interface`: https://dbgr.readthedocs.io/en/latest/types.html#types|screencast|
.. |screencast| image:: https://asciinema.org/a/uNs262JVwxY2d1BGZTdRvDsWH.svg
:alt: DBGR Basic Usage Example
:target: https://asciinema.org/a/uNs262JVwxY2d1BGZTdRvDsWHInstallation
------------
The easiest way to install DBGR is via PyPi_:.. _pypi: https://pypi.org/project/dbgr/
.. code-block:: bash
$ pip install dbgr
$ dbgr -v
1.1.0DBGR requires Python >=3.6.
Quick Start
-----------
First step when working with DBGR is to create a directory which will DBGR search
for requests and environment settings.You can also `download the quickstart from Github`_.
.. _download the quickstart from github: https://github.com/JakubTesarek/dbgr/tree/master/examples/quickstart
.. code-block:: bash
$ mkdir quickstart
$ cd quickstartInside create your default environment file ``default.ini``. For now just place
a section header inside:.. code-block:: ini
[default]
Now create another file, call it ``quickstart.py`` and place create your first request:
.. code-block:: python
from dbgr import request
@request
async def get_example(session):
await session.get('http://example.com')You can check that DBGR registered the request by running ``dbgr list``:
.. code-block:: bash
$ dbgr list
quickstart:
- get_exampleTo execute it, run ``dbgr request get_example``:
.. code-block:: bash
# Output in this example is shortened
> GET http://example.com
> 200 OK
>
> Request headers:
> Host: example.com
> Accept: */*
> Accept-Encoding: gzip, deflate
> User-Agent: Python/3.6 aiohttp/3.5.4
<
< Response headers:
< Content-Encoding: gzip
< Accept-Ranges: bytes
< Cache-Control: max-age=604800
< Content-Type: text/html; charset=UTF-8
< Date: Sun, 16 Jun 2019 15:29:41 GMT
< Last-Modified: Fri, 09 Aug 2013 23:54:35 GMT
< Content-Length: 606
<
< Response data (text/html):
Example Domain
Example Domain
This domain is established to be used for illustrative examples in documents. You may use this
domain in examples without prior coordination or asking for permission.
Result (NoneType)`Read the full documentation on Read the Docs`_
.. _`read the full documentation on read the docs`: https://dbgr.readthedocs.io/en/latest/