This document describes how the 18F eRegs team has agreed to work together with regard to Git, GitHub and facilitating changes to the repositories they administer.
The most common workflow is:
- A change is initiated and discussed via a GitHub issue or Trello card.
- Team members discuss prioritization in daily standup and claim tasks.
- A Pull Request (PR) is created on Github. The related GitHub issue or Trello card is referenced in the PR description.
- The PR is reviewed by someone other than the committer.
- Once PR feedback has been addressed and/or incorporated, the reviewer merges the pull request.
- When the Travis CI build passes on
master
, updates are automatically deployed to the staging environment.
- Use PEP8 as the coding standard for Python.
- Use Sphinx-style docstrings for function and method documentation, including signatures, unless they're very short. See http://www.sphinx-doc.org/en/stable/domains.html#signatures for details.
- Add inline comments for things that aren't intuitive.
- If you can re-write something to be more intuitive, that is preferable to adding comments.
- Follow the boy scout rule: "Always leave the code cleaner than you found it."
- The author and reviewer have equal responsibility for code.
- Don't merge things until you are confident you could maintain it as-written.
- Reviewers expect code to be submitted with test coverage.
- Travis CI runs the test suite and a PEP8 linter on GitHub PRs. PRs should only be merged when Travis is green.
Individual contributors may choose to rebase and squash commits to clean up git history on a fork that is being PR'd. It is not expected or required for contributors to change their git history.
This team opens PRs for all commits, even typos.
Exceptions may be granted in the case of an imminent deploy. The team should be consulting before pushing code directly to master.
When pairing, a pair may self-merge work but should open a pull request before merging to create a record of the work being merged.
This team does not have a standard QA process.
- Don't merge your own pull request. Find a friend to review your code and merge your pull request.
- Pull requests should contain some tests. Ideally they would contain decent test coverage.
- If you make changes to the API, please help update the API documentation.
When creating a new pull request:
- If the pull request is still a work-in-progress and should not be merged, say so in the description.
- Anyone is welcome to informally review a PR and comment on it at any time, no matter who is assigned.
This project is in the public domain within the United States, and copyright and related rights in the work worldwide are waived through the CC0 1.0 Universal public domain dedication.
All contributions to this project will be released under the CC0 dedication. By submitting a pull request, you are agreeing to comply with this waiver of copyright interest.