Contributor’s Guide#
Aeolus takes contributions using pull requests on GitHub.
Setting up repositories#
Create an account on GitHub.
Fork aeolus on GitHub, so a copy of it appears in your GitHub profile and has a remote URL like your_user_name/aeolus.
Git-clone it to your computer using the new URL (or change the remote of your existing folder).
Developing the code#
It is often more convenient to install the library you are developing in the “developer” mode. To do this, navigate to the cloned copy of the repository and type
pip install -e .
(Make sure you are usingpip
in the correct python environment and note the dot at the end!) Alternatively, runpython setup.py develop
(no dot at the end).It is also better to create a new branch instead of working on the main branch (e.g.
git checkout -b new_branch_for_cool_addition
). If your contribution is relatively small, such as fixing one small bug or typo, you can skip this step.Make changes, commit them and push to your remote. (Which again, should have your URL. You can check it by typing
git remote -v
).Test the changes (see below)!
Go to your aeolus page on GitHub and create a pull request (a prompt for this should show up on top of the page).
Wait for the automatic tests to pass and for aeolus developers to review your pull request. If any further changes are needed, make the necessary changes and commit to your forked remote repository. The pull request will update automatically.
Checking the code formatting#
Install
pre-commit
in the current environment:pip install pre-commit
.Check the formatting style by running
pre-commit
on all files:pre-commit run --all-files
.The errors should be corrected automatically, otherwise fix them manually.
On your next commit, the
pre-commit
hook should work automatically.
Testing the code#
Run your own tests to make sure the code does what you expect (make sure you are importing the “right” version of aeolus).
Download the test data (from the top level of the aeolus directory)
git clone https://github.com/exoclim/aeolus_data.git tests/data
Run aeolus tests
pytest -c setup.cfg --cov=aeolus --cov-report term-missing -v
Fix all the errors, if there are any!.
Contributing to the documentation#
We welcome contributions to improve the documentation of aeolus.
Please make yourself familiar with the reST formatting guide.
Follow the steps above to create a fork on GitHub.
Make changes. Do not forget to add any relevant references to papers or textbooks.
- Build the documentation locally.
Create a separate conda environment
conda env create -f docs/environment.yml
cd
to the docs/ directory.Build the documentation
make html
cd
to the _build/html sub-directory.Start an HTTP server using a random port
python -m http.server 1234
Open the
http://localhost:1234
page in the browser. Use CTRL-F5 to refresh the page if needed.To close the session, use CTRL-C in the command line where the HTTP server was started.
Create a pull request and wait for the aeolus team to review it.