apps/opik-documentation/documentation/fern/docs/contributing/python-sdk.mdx
The Opik Python SDK is a key component of our platform, allowing developers to integrate Opik into their Python applications seamlessly. The SDK source code is located in the sdks/python directory of the main comet-ml/opik repository.
# Configure the Python SDK to point to the local Opik deployment
opik configure --use_local
```
</Tab>
<Tab title="Windows">
```powershell
# From the root of the repository
.\opik.ps1 --port-mapping
# Configure the Python SDK to point to the local Opik deployment
opik configure --use_local
```
</Tab>
Note: The --port-mapping flag exposes all service ports (including MySQL on 3306, ClickHouse on 8123, Redis on 6379) which is useful for debugging. The Python SDK routes traffic through the API gateway (nginx) in the frontend service.
Your local Opik server will be accessible at http://localhost:5173.
# Activate it (example path)
cd my-opik-env\Scripts && .\activate.bat
# Install the SDK in editable mode (adjust path to sdks/python from your current location)
pip install -e ../../sdks/python
# Configure the SDK to use your local Opik instance
opik configure --use_local
```
Navigate to the sdks/python directory (or use the path from your virtual environment setup) and install the SDK in editable mode:
pip install -e .
Familiarize yourself with the coding guidelines for our Python SDK. This will cover style, conventions, and other important aspects.
Make your desired code changes, additions, or bug fixes within the sdks/python directory.
Testing is crucial. For most SDK contributions, you should run the unit and the end-to-end (e2e) tests:
cd sdks/python # Ensure you are in this directory
# Install test-specific requirements
pip install -r tests/test_requirements.txt
# Install unit test requirements
pip install -r tests/unit/test_requirements.txt
# Install pre-commit for linting checks (optional but good practice)
pip install pre-commit
# Run unit tests
python3 -m pytest -vv tests/unit/
# Run e2e tests
python3 -m pytest -vv tests/e2e/
If you're making changes to specific integrations (e.g., OpenAI, Anthropic):
pip install -r tests/integrations/openai/requirements.txt (example for OpenAI).python3 -m pytest tests/integrations/openai/ (example for OpenAI).Ensure your code adheres to our linting standards:
cd "$(git rev-parse --show-toplevel)"
make precommit-sdks
If your changes impact public-facing methods, parameters, or docstrings, please also update the documentation. Refer to the Documentation Contribution Guide for how to update the Python SDK Reference Documentation (Sphinx).
Once all tests and checks pass, and any relevant documentation is updated, commit your changes and open a Pull Request against the main branch of the comet-ml/opik repository. Clearly describe your changes and link to any relevant issues.