Skip to content

Latest commit

 

History

History
175 lines (116 loc) · 4.94 KB

CONTRIBUTING.md

File metadata and controls

175 lines (116 loc) · 4.94 KB

Contributing

Setup Development Environment

Git User

1. Tell Git who you are

git config --global user.name "Your Name"
git config --global user.email "[email protected]"

GPG Keys

1. Install GPG Tools -- do a customized install and deselect GPGMail.

2. Tell Git to use the gpg2 that comes with GPG Tools

git config --global gpg.program /usr/local/MacGPG2/bin/gpg2

3. Generate a GPG key using Applications/GPG Keychain

alt text

4. Tell Git to use your new GPG Key and auto-sign all commits

git config --global user.signingkey KEY_ID_FROM_STEP_3
git config --global commit.gpgsign true

5. Add Keys to Github

https://help.github.com/articles/adding-a-new-gpg-key-to-your-github-account/

https://help.github.com/articles/generating-a-new-gpg-key/

Version Control

Master

The master branch should be considered the most up-to-date stable version of the software. No active development should take place on directly master and the latest commit should always be tagged to a release.

  • Hotfix should be branched off of master

Next

The next branch should be considered the most up-to-date development version of the software. No active development should take place on directly on next.

  • All development should be branched off of next

  • next should be rebased with master after a hotfix

Branches

All development should happen on a branch off of next. Branch names should include a ticket number if possible: TICKET-##-couple-words or my-update.

git checkout -b TICKET-11-my-feature
  • Branches should be rebased with next if they get out of date.

  • Branches should be merged into next when they are completed.

Hotfix

A hotfix is a branch that uses master as a base instead of next.

Commits

  • Commit messages should make it easy for some one to scan through a commit log and understand the current state of the code.

  • When only changing documentation, include [ci skip] in the commit description

  • Consider starting the commit message with an applicable emoji:

    • 🎉 :tada: for the initial commit
    • 💚 :green_heart: when fixing the CI build
    • :white_check_mark: when adding tests
    • ⬆️ :arrow_up: when upgrading dependencies
    • ⬇️ :arrow_down: when downgrading dependencies
    • 👕 :shirt: when removing linter warnings
    • ♻️ :wrench: when refactoring
    • 🔧 :wrench: when updating tooling

    start with one of the following emojis to add your commit to the change log:

    • 🐎 :racehorse: when improving performance
    • :sparkles: when adding a new feature
    • 🐛 :bug: when fixing a bug
    • 📚 :books: when adding documentation
    • 🌐 :globe_with_meridians: when adding internationalization
  • you can use multiple emojis but only with first will be considered when generating the change log

Examples

Commits have the following structure:

:icon: [TICKET-1,TICKET-2] one line description

Longer description
- list of changes
- one more thing

Examples of valid commits:

:sparkles: [TICKET-1,TICKET-2] adds new page to that page

Adds new feature to do that thing that we wanted to do:
- That one thing it does
- that other thing it does
:bug: [TICKET-1] fixes bug with thing
:racehorse::wrench: better production mode
:shirt: fixes eslint in tests

Code Review

  • All branches should be pushed to Github for code review.

  • All branches need to be reviewed and signed-off before they can be considered complete.

  • Any branches containing significant changes will also need to be QA'ed.

Merge Branch

After a branch has been reviewed it can be merged.

When merging use the Squash and Merge option:

alt text

Before merging you are free to squash commits locally if you want more control over the commit message.

https://git-scm.com/book/en/v2/Git-Tools-Rewriting-History#Squashing-Commits

https://github.com/blog/2141-squash-your-commits

Your First Pull Request

  1. clone the repo
  2. create a new branch
  3. do some work
  4. commit your changes
  5. push changes to Github for review
  6. repeat as necessary
  7. rebase next into your branch and deal with any conflicts.
  8. get someone to review and sign-off on your branch
  9. wait for the CI system to test your branch
  10. merge into next