To make the process of contributing as seamless as possible please read this contributing guide. Any one who follows this document can contribute to the repo.
- Fork this repo
- If an issue is not already filed for the change, define the intent of the work following the Issues guide below
- Start a Pull Request to bring in the work done.
This repo uses git-hooks to run some automated client-side actions (e.g. doc update) before you commit.
Install and configure git-hooks locally for this repository:
npm install git-hooks --global
git-hooks --install
Now this is getting the usage doc regenerated automatically with every commit.
If you find hooks are a problem, you can work around them with git commit --no-verify ...
Issues are use for any new work coming in. Issues can be for
Each issue should articulate for other contributors and maintainers.
- Why is it an issue?
- What is the planned change for it?
- What is the scope and definition of success?
- What is not part of the needed resolution of the issue?
The motivation here is to clearly articulate the need, the form and details of an issue before a Pull Request is posted that addresses the issue. This is to insure that the other reviewers can appreciate the need for the Pull Request and do justice to the code review.
Large feature requests issues can spawn other focused issues that complete one end to end functionality.
The master is always shippable with a clear set of functionality that works. Milestones are analogous to sprints and a release will be cut after every milestone. Milestones are planned on a 3 week cadence. Large releases that are a culmination of a few milestones are tracked as projects.
In the weeks leading up to a Milestone, the issues planned for it need to be reviewed to make sure that they comply with the requirements listed above. Only issues that meet the requirement will be worked on and reviewed to close a milestone.
Maintainers need to meet through the week to insure that the backlog of issues for upcoming sprints has been fleshed out to be actionable.
It is encouraged to use Pull Requests when incomplete work needs to be reviewed. Adding WIP to the title of a commit or to the title of the Pull Request, the Pull Request can be reviewed but will be blocked from being merged in.
This repo requires work to be signed off with a verifiable GPG signature that the work is compliant with Digital Certificate of Origin.
A valid and appropriate email address is needed.
git config --global user.useConfigOnly true
git config --global --unset-all user.email
This repo uses PGP keys. Please setup PGP before pushing changes. One option to simplify the PGP setup is to use a service such as KeyBase
This repo mandates DCO. Developers submitting the change have to comply with the DCO text and sign off commits.
Sufficient unit tests need to be written to cover edge conditions.
Every commit goes through the entire set of end to end tests before it makes it way to the target branch.