Skip to main content

The feldera python client

Project description

Feldera Python SDK

Feldera Python is the Feldera SDK for Python developers.

Installation

pip install feldera

Installing from Github

pip install git+https://github.com/feldera/feldera#subdirectory=python

Similarly, to install from a specific branch:

$ pip install git+https://github.com/feldera/feldera@{BRANCH_NAME}#subdirectory=python

Replace {BRANCH_NAME} with the name of the branch you want to install from.

Installing from Local Directory

If you have cloned the Feldera repo, you can install the python SDK as follows:

# the Feldera Python SDK is present inside the python/ directory
pip install python/

Checkout the docs here for an example on how to use the SDK.

Documentation

To build the html documentation run:

Ensure that you have sphinx installed. If not, install it using pip install sphinx.

Then run the following commands:

cd docs
sphinx-apidoc -o . ../feldera
make html

To clean the build, run make clean.

Testing

To run unit tests:

(cd python && python3 -m unittest)

⚠️ Running the unit tests will delete all existing pipelines.

The following command runs end-to-end tests. You'll need a pipeline manager running at http://localhost:8080. For the pipeline builder tests, you'll also need a broker available at localhost:9092 and (from the pipelines) redpanda:19092. (To change those locations, set the environment variables listed in python/tests/__init__.py.)

(cd python && python3 -m pytest tests)

To run tests from a specific file:

(cd python && python3 -m unittest ./tests/path-to-file.py)

To run the aggregate tests use:

cd python
PYTHONPATH=`pwd` python3 ./tests/aggregate_tests/main.py

Linting and formatting

Use Ruff to run the lint checks that will be executed by the precommit hook when a PR is submitted:

ruff check python/

To reformat the code in the same way as the precommit hook:

ruff format

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

feldera-0.98.0.tar.gz (34.8 kB view details)

Uploaded Source

Built Distribution

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

feldera-0.98.0-py3-none-any.whl (30.4 kB view details)

Uploaded Python 3

File details

Details for the file feldera-0.98.0.tar.gz.

File metadata

  • Download URL: feldera-0.98.0.tar.gz
  • Upload date:
  • Size: 34.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for feldera-0.98.0.tar.gz
Algorithm Hash digest
SHA256 b2e1f9007b0ad598723b49ad1d5bdfe9ba1a0f47ba71530ca0cbfec735d1c9b5
MD5 b85d05ea5b04425cdef680c1c2b0045f
BLAKE2b-256 56c96460dd7c4aa578854c1c395778e27509933e60be643e40c718e261dca2e2

See more details on using hashes here.

File details

Details for the file feldera-0.98.0-py3-none-any.whl.

File metadata

  • Download URL: feldera-0.98.0-py3-none-any.whl
  • Upload date:
  • Size: 30.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for feldera-0.98.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fb5596d9a8a08065609946e5a65966f75c4b586faeb323cc148ad3e650b3cac1
MD5 588be0bd4a0e5de9480bd69c2be04033
BLAKE2b-256 1afbbb6144dae471a5cf742105788968ebf9e0bb56b69fd4114eb4f55dfb567c

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