This document outlines the processes and practices recommended for contributing enhancements to kubeflow-profiles
.
Before developing enhancements to this charm, you should open an issue explaining your use case. If you would like to chat with us about your use-cases or proposed implementation, you can reach us at MLOps Mattermost public channel or on Discourse.
Please help us out in ensuring easy to review branches by rebasing your pull request branch onto the main
branch. This also avoids merge commits and creates a linear Git commit history.
All pull requests require review before being merged. Code review typically examines:
- code quality
- test coverage
- user experience for Juju administrators of this charm.
Familiarising yourself with the Charmed Operator Framework library will help you a lot when working on new features or bug fixes.
To build kubeflow-profiles
run:
charmcraft pack
You can use the environments created by tox
for development. For example, to load the unit
environment into your shell, run:
tox --notest -e unit
source .tox/unit/bin/activate
Use tox for testing. For example to test the integration
environment, run:
tox -e integration
See tox.ini
for all available environments.
# Create a model
juju add-model dev
# Enable DEBUG logging
juju model-config logging-config="<root>=INFO;unit=DEBUG"
# Deploy the charm
juju deploy ./kubeflow-profiles_ubuntu-20.04-amd64.charm --trust \
--resource profile-image=$(yq '.resources."profile-image"."upstream-source"' metadata.yaml) \
--resource kfam-image=$(yq '.resources."kfam-image"."upstream-source"' metadata.yaml)
Canonical welcomes contributions to this charm. Please check out our contributor agreement if you're interested in contributing.