Skip to main content

No project description provided

Project description

https://img.shields.io/pypi/v/i8t.svg https://img.shields.io/pypi/pyversions/i8t.svg tests Code style: Black

i8t instruments Python code to send checkpoints to i8t server.

Installation

pip install i8t

Usage

i8t can be used in a few ways:

  1. Instrument all inbound web requests (currently only Flask is supported):

    import flask
    import requests
    from i8t.instrument.flask_introspect import FlaskIntrospect
    
    app = flask.Flask(__name__)
    
    app.route("/test", methods=["POST"])
    def test_route():
        return "Test Response", 200
    
    introspect_client = IntrospectClient(
        session=requests.Session(),
        api_url="https://api.demin.dev/i8t/checkpoints/unique-tenant-id",
        name="app",
    )
    flask_introspect = FlaskIntrospect(introspect_client)
    flask_introspect.register(app)
  2. Instrument all outbound HTTP requests (currently only requests is supported):

    import requests
    from i8t.instrument.requests_introspect import RequestsIntrospect
    
    introspect_client = IntrospectClient(
        session=requests.Session(),
        api_url="https://api.demin.dev/i8t/checkpoints/unique-tenant-id",
        name="app",
    )
    requests_introspect = RequestsIntrospect(introspect_client)
    requests_introspect.register()
  3. Decorate any function to send its inputs and outputs:

    from i8t.client import IntrospectClient, IntrospectDecorator, introspect
    
    @introspect
    def test_func(first, second):
        return first + second
    
    introspect_client = IntrospectClient(
        session=requests.Session(),
        api_url="https://api.demin.dev/i8t/checkpoints/unique-tenant-id",
        name="app",
    )
    decorator = IntrospectDecorator(introspect_client)
    decorator.register()

Once initialized, the inputs and outputs of the instrumented calls are sent to the i8t server, where they can be later fetched at the same URL.

The fetched call checkpoints can be used to set up canned tests.

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

i8t-0.0.7.tar.gz (19.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

i8t-0.0.7-py2.py3-none-any.whl (18.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file i8t-0.0.7.tar.gz.

File metadata

  • Download URL: i8t-0.0.7.tar.gz
  • Upload date:
  • Size: 19.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for i8t-0.0.7.tar.gz
Algorithm Hash digest
SHA256 37fe7607f5cd868c53cbce9fd47c74fcbf82199be460a31056571f7c9c68e3c4
MD5 a5a8dcaeffde1f926f93cf1996b64356
BLAKE2b-256 9c51345a18deb8f8a30547056ad688786a9572b6ea9ad4a53131f51ba3d44044

See more details on using hashes here.

File details

Details for the file i8t-0.0.7-py2.py3-none-any.whl.

File metadata

  • Download URL: i8t-0.0.7-py2.py3-none-any.whl
  • Upload date:
  • Size: 18.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for i8t-0.0.7-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 75f338edc93844d2a80e2ff10e496cf84a490c2e85ce6268b1be3ae9c8a1bed3
MD5 763790128ca55850dfbb6685274d15b5
BLAKE2b-256 4189b587407e78093e56c140f89359ff20ef57fedac263f4b6601a9600d81e10

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page