Andy projects accept contributions via GitHub pull requests. This document outlines the process to help get your contribution accepted.
python
3.00 or greaterpip
Before any development is undertaken, there should be a GitHub Issue created to properly track and isolate the changes. A branch is then created from the issue and it is to that branch that work will be submitted.
-
Consult the Andy Project Backlog to see any tickets that are Unassigned. If a task is available for this repository, assign it to yourself to reserve it. The backlog contains pending GitHub Issues that have yet to be scheduled for development within an iteration.
-
Once you have assigned yourself an issue, schedule the issue within an Iteration so it is visible on the Kanban Board. Once the issue is visible on the Kanban Board, drag the issue from Backlog to In Progress.
-
After the issue has been transitioned to In Progress, a Branch within the issue should be created to properly isolate changes. This branch will been the one to conduct development within, or open external Pull Requests against.
An API Key is required to be able to publish releases to testpypi. Upon the assignment of an issue, the repository owner will be in touch.
First, a local project environment needs to be created, then the project's modules will be installed into locally into a virtual environment.
-
Clone the repository.
git clone https://github.com/bellanov/serenade-flow.git cd serenade-flow
-
Create a virtual environment.
# Create Virtual Environment python3 -m venv .venv # Activate Virtual Environment source .venv/bin/activate # Install Dependencies pip install -r requirements.txt # Deactivate Virtual Environment deactivate
-
Make your changes, increment the version in
pyproject.toml
, and build the application.# Build a Python package distribution scripts/build.sh # Publish a distribution to PyPi (testpypi) scripts/release.sh # Install the Python package locally, from testpypi. scripts/install.sh "<VERSION>" # Execute Unit Tests scripts/test.sh # Execute Code Samples scripts/examples.sh # Lint Code Base scripts/lint.sh
-
Tag and version code changes.
git tag -a "1.2.3" -m "Version 1.2.3" git push --follow-tags