Welcome to the Provena Python Client repository! This client library is a programmatic interface designed to interact seamlessly with your Provena instance. The client uses the same Pydantic models as the Provena API, ensuring a one-to-one typed interface with the API. This means that the models used in the client library directly correspond to those used by the API, providing consistency and ease of use. It allows you to replicate most functionalities of the Provena Web app through Python code, including fetching or minting datasets, creating items within the registry, and launching provenance workflows. With the Provena Python Client, you can achieve comprehensive interactions with only a few lines of code.
To install the Provena Python Client, simply use pip:
pip install provenaclient
Once you have successfully installed provenaclient, refer to the following notebook for examples on how to use the client. Example Notebook here at: Example Notebook.
To find more examples on how to use the client, refer to these collection of notebooks: Provena Notebook Repository
If you are interested in running any tests, please make sure to first clone this repository and then follow the below steps:
The Provena Python Client includes unit tests that check functionality using real server interactions and mocked components using httpx_mock
. Tests cover HTTP methods, error handling, and JSON parsing.
To run unit tests:
- Install dependencies from
pyproject.toml
. - Run
pytest test_unit.py
in the test directory.
The Provena Python Client includes integration tests that validate and assess the functioning of the client library and its interaction with Provena API's, focusing on dataset operations, entity searching, item fetching, and provenance lifecycle.
To run integration tests:
- Install dependencies from
pyproject.toml
. - Set up necessary credentials in
.env
(contact Provena Development Team for setup). - Run
pytest test_integration.py
in the test directory.
For detailed testing procedures, see the Testing Guide.
Find Provena Python Client documentation and API Reference at: (Provena Client Documentation)
Contact Provena Developers via https://www.csiro.au/en/contact
Refer to the following doc Contributing Guidelines
provenaclient
was created by Provena Development Team (CSIRO). Provena Development Team (CSIRO) retains all rights to the source and it may not be reproduced, distributed, or used to create derivative works.
The development of Provena Python Client was funded by Reef Restoration and Adaptation Program (RRAP), which is a partnership between the Australian Government’s Reef Trust and the Great Barrier Reef Foundation. Provena Python Client has been developed to support the Modelling and Decision Support (MDS) Subprogram (https://gbrrestoration.org/program/modelling-and-decision-support/).
People who contributed and developed Provena Python Client (ordered alphabetically):
- Jonathan Yu
- Parth Kulkarni
- Peter Baker
- Ross Petridis