Skip to content
This repository has been archived by the owner on Oct 19, 2024. It is now read-only.

Latest commit

 

History

History
89 lines (65 loc) · 5.85 KB

CONTRIBUTING.md

File metadata and controls

89 lines (65 loc) · 5.85 KB

Contributing to aframe

Thanks for taking the time to contribute! While we appreciate all who wish to contribute, at the moment we're prioritizing contributions from IGWN scientists.

Here are some guidelines on how code in this repo should be structured, as well as best practices for making contributions to it.

Getting started

To start contributing, create a fork of this repository. You can then either clone your fork

git clone git@github.com:johnny-tsunami/aframe.git

(replacing your GitHub username for johnny-tsunami) or add your fork as a remote reference to an existing clone of the repo (in this case, a common practice is to rename this remote upstream)

git remote add upstream git@github.com:ML4GW/aframe.git
git remote set-url origin git@github.com:johnny-tsunami/aframe.git

Next, check out to a new branch for a specific issue you're trying to solve

git checkout -b new-unit-tests

Now you're ready to start adding in all your important fixes!

Contribution guidelines

Environment

The key environment management tool for this repo is Poetry. For installation instructions, see the README. Any libraries or projects you create should have a pyproject.toml with a [tool.poetry] table that describes the relevant dependencies. You should create and commit a lockfile via poetry lock and git add poetry.lock to ensure that the environment you've specified can be built.

Libraries vs. Projects

If the code you're writing is some general-purpose function that gets used in many places, consider implementing it as a library in libs that other code can import and call. To make clear what libraries come from this repository, we've adopted the practice that local library imports should start with aframe., e.g. from aframe.analysis import matched_filter.

In practice, this means structuring libraries like:

| libs/
|    | my-library/
|    |    | aframe/
|    |    |    | my-library/
|    |    |    |    | __init__.py
|    |    |    |    | ...
|    |    | pyproject.toml
|    |    | poetry.lock

Code that produces artifacts of some specific experiment (training data, optimized models, analysis plots, etc.) should be implemented as a project in the projects directory. Projects should be kept modular and specific to the artifact they are designed to generate, with light-weight environments.

If multiple projects are meant to be executed in serial with some shared configuration, consider organizing them as a pipeline like the sandbox experiment. See this experiment's pyproject.toml and README for more information on how to organize a pipeline.

Testing

For any code that you contribute, make sure to add unit tests which explicitly state and validate expectations about the behavior of your code. Tests should be placed in a tests subdirectory of each library and project, and should be structured similarly to the library code itself but with test_ prepended to all the names.

Pre-commit hooks

To keep the code style consistent and neat throughout the repo, we implement pre-commit hooks to statically lint and style-check any code that wants to get added to the upstream main branch. You can install these hooks to run locally by installing pre-commit either via Poetry from the root directory

poetry install
poetry run pre-commit install

or via pip in your local Python environment

pip install pre-commit
pre-commit install

Now any attempts to commit new code will require these tests to past first (and even do some reformatting for you if possible). To run the hooks on existing code, you can run (with an optional poetry run in front of this if you installed via Poetry)

pre-commit run --all

Non-automatable style guidelines

  • Annotate function arguments and returns as specifically as possible
  • Adopt Google docstring formatting (this will eventually be used by Sphinx autodoc, so consistency is important)

Adding your code

Once you've added all the code required to solve the issue you set out for, and have tested it and run it through the pre-commit hooks, you're ready to add it to the upstream repo! To do this, push the branch you've been working on back up to your fork

git push -u origin new-unit-tests

Now submit a new pull request from your branch to upstream main, describing what your new code does and potentially linking to any issues it addresses. This will kick off CI workflows for unit testing and style checks, as well as a review from your fellow aframe contributors.

If any of the CI tests fail or your reviewers request changes to the code, you can keep working on your same branch locally and push the relevant fixes and changes up once they're ready, which will kick this process off again. One common issue here is that changes have been made to the main branch by another contributor that you don't have in your repo. If this is the case, try pulling the changes into your local branch via git pull upstream/main.

Once all the checks pass and at least one reviewer approves your code, your changes will be merged into the main repository for all the world to use!

Occasionally, you may have a branch that is not ready to pass all the checks required for merging, but is still useful to make others aware of the work that is going on (for e.g. Project board planning). If this is the case, consider opening a draft pull request, then updating its status once the code is complete.