Contributing to madonna¶
I've tried to structure madonna to make it nice and easy for people to contribute. Here's how to go about doing it!
Note
All contributors must follow the Code of Conduct
Developing¶
If you want to fix a bug, improve the docs, add tests, add a feature or any other type of direct contribution to madonna: here's how you do it!
To work on madonna you'll need python >=3.8
Step 1: Fork madonna¶
The first thing to do is 'fork' madonna. This will put a version of it on your GitHub page. This means you can change that fork all you want and the actual version of madonna still works!
To create a fork, go to the madonna repo and click on the fork button!
Step 2: Clone your fork¶
Navigate to where you do your development work on your machine and open a terminal
If you use HTTPS:
git clone https://github.com/<your_github_username>/madonna.git
If you use SSH:
git clone git@github.com:<your_github_username>/madonna.git
Or you can be really fancy and use the GH CLI
gh repo clone <your_github_username>/madonna
HTTPS is probably the one most people use!
Once you've cloned the project, cd into it...
cd madonna
This will take you into the root directory of the project.
Now add the original madonna repo as an upstream in your forked project:
git remote add upstream https://github.com/FollowTheProcess/madonna.git
This makes the original version of madonna upstream
but not origin
. Basically, this means that if your working on it for a while and the original project has changed in the meantime, you can do:
git checkout main
git fetch upstream
git merge upstream/main
git push origin main
This will (in order):
- Checkout the main branch of your locally cloned fork
- Fetch any changes from the original project that have happened since you forked it
- Merge those changes in with what you have
- Push those changes up to your fork so your fork stays up to date with the original.
Note
Good practice is to do this before you start doing anything every time you start work, then the chances of you getting conflicting commits later on is much lower!
Step 3: Create the Environment¶
Before you do anything, you'll want to set up your development environment...
madonna uses poetry to manage development and nox for automation superpowers. So to work on it you'll need to get both of those tools too!
I recommend using pipx for python command line tools like these, it installs each tool in it's own isolated environment but exposes the command to your terminal as if you installed it globally.
We've automated the crap out of the development process for madonna, to get started all you need to do is run:
nox
Note
If you've never used nox before, go check it out. It's great!
It's an amazing project automation toolkit, you can do just about anything with it but it's especially good at things like this!
When you run this, nox will:
- Create a fresh python virtual environment in the project for you (.venv)
- Install madonna for you along with all of it's development dependencies
- Make sure VSCode is set up to use this environment (if you use it)
Not bad for a single command! Doing it this way means that before you start working on madonna you know its all been installed and works correctly.
Wait for it to do it's thing and then you can get started.
Note
The next time you run nox
, it won't do this step again. It will run all the project tests, lint and format the source code, analyse test coverage and build the docs
Step 4: Do your thing¶
Always checkout a new branch before changing anything
git checkout -b <name-of-your-bugfix-or-feature>
Now you're ready to start working!
Remember! madonna aims for high test coverage. If you implement a new feature, make sure to write tests for it! Similarly, if you fix a bug, it's good practice to write a test that would have caught that bug so we can be sure it doesn't reappear in the future!
madonna uses nox for automated testing, building the docs, formatting and linting etc. So when you've made your changes, just run:
nox
And it will tell you if something's wrong!
Step 5: Commit your changes¶
Once you're happy with what you've done, add the files you've changed:
git add <changed-file(s)>
# Might be easier to do
git add -A
# But be wary of this and check what it's added is what you wanted..
git status
Commit your changes:
git commit
# Now write a good commit message explaining what you've done and why.
While you were working on your changes, the original project might have changed (due to other people working on it). So first, you should rebase your current branch from the upstream destination. Doing this means that when you do your PR, it's all compatible:
git pull --rebase upstream main
Now push your changes to your fork:
git push origin <your-branch-name>
Step 6: Create a Pull Request¶
Now go to the original madonna repo and create a Pull Request. Make sure to choose upstream repo "main" as the destination branch and your forked repo "your-branch-name" as the source.
That's it! Your code will be tested automatically by madonna's CI suite and if everything passes and your PR is approved and merged then it will become part of madonna!
Note: There is a good guide to open source contribution workflow here and also here too
Contributing to Docs¶
Any improvements to the documentation are always appreciated! madonna uses mkdocs with the mkdocs-material theme so the documentation is all written in markdown and can be found in the docs
folder in the project root.
Because madonna uses nox, things like building and serving the documentation is super easy. All you have to do is:
# Builds the docs
nox -s docs
# Builds and serves to localhost
nox -s docs -- serve
If you use the serve
option, you can navigate to the localhost IP address it gives you and as you make changes to the source files, it will automatically reload your browser! Automation is power!
If you add pages to the docs, make sure they are placed in the nav tree in the mkdocs.yml
file and you're good to go!