Use github’s interface to make a fork of the master repo (github.com/ORG_NAME/REPO_NAME.git).
Navigate to your forked repo (github.com/<your_name>/<repo_name>.git). Clone this repo locally using git clone
. Then add the MASTER REPO (which belongs to the org, not you) as an upstream remote:
git remote add upstream https://github.com/<org_name>/<NAME_OF_REPO>.git
On your local machine, create a branch and give it a name indicating what your feature is.
These commands will help you do this:
# Creates your branch and brings you there
git checkout -b `your-branch-name`
As you write code for your feature, commit often. Make sure you are committing to your FEATURE BRANCH not master!
If you find yourself making changes unrelated to the current feature, make a new branch for those changes.
- The first line of your commit message should be a brief summary of what the commit changes. Aim for about 70 characters max. Remember: This is a summary, not a detailed description of everything that changed.
- If you want to explain the commit in more depth, following the first line should be a blank line and then a more detailed description of the commit. This can be as detailed as you want, so dig into details here and keep the first line short.
Once you are done making changes, run this command:
git pull --rebase upstream master
This will start the rebase process. You must commit all of your changes before doing this. If there are no conflicts, this should just roll all of your changes back and the apply them one by one on top of the current upstream, leading to a nice, clean, linear commit history.
If there are conflicting changes, git will start yelling at you part way through the rebasing process. Git will pause rebasing to allow you to sort out the conflicts. Look for the word "CONFLICT" in the command line output.
To resolve conflicts, go to the file(s) that appear after "CONFLICT". You will see your version and HEAD's version on top of each other. Simply resolve the conflict as you see fit by picking the version you want to keep and deleting the other (and also deleting the lines that Git inserted).
Once you've resolved the conflicts in one file, you must then git add
it to continue. NOTE: you do NOT commit while in the middle of a rebase process, only add.
git add FILE_NAME
Once you have added all the files that you have fixed conflicts for, run:
git rebase --continue
This will continue the rebasing process. Once you are done fixing all conflicts you should run the existing tests to make sure you didn’t break anything, then run your new tests (there are new tests, right?) and make sure they work also.
If rebasing broke anything, fix it, then repeat the above process until you get here again and nothing is broken and all the tests pass.
Push your local changes to your fork on GitHub:
git push origin BRANCH_NAME
This ensures that your fork of the repo on GitHub gets the feature branch with all your changes.
Go to GitHub and find YOUR FORK of the master repo. Initiate a pull request from your fork to the MASTER REPO.
In the title of your pull request, include one of these keywords: CLOSES, FIXES or RESOLVES, followed by "#", followed by the issue number you are resolving with this pull request. For ex. "Fixes #19". Please always include one of these keywords plus the issue number, so that the issue is closed automatically for us.
At least one other person MUST give your changes a code review, and once they are satisfied they will merge your changes into upstream. Alternatively, they may have some requested changes. You should make more commits to your branch to fix these, then follow this process again from rebasing onwards.
Once you get back here, make a comment requesting further review and someone will look at your code again. If they like it, it will get merged, else, just repeat again.
After your pull request has been accepted, the master branches on your GitHub fork and your local machine will be out of sync with the master repo (upstream).
Run the following commands on your computer:
git checkout master
git pull --rebase upstream master
git push origin master
You're now ready to start a new feature! Go back to Step 3 and follow the workflow again!
After your pull request has been accepted and closed, and after you've synced your master branches with upstream, you probably won't need your feature branch anymore. It gets confusing to have too many branches you might want to delete the branches on GitHub and locally.
git checkout master
git branch -d BRANCH_NAME
Then go to your fork on GitHub and click the "X branches" link. You will be able to delete the corresponding branch on GitHub from here.
- Uphold the current code standard:
- Keep your code [DRY][].
- Apply the [boy scout rule][].
- Follow STYLE-GUIDE.md
- Run the [tests][] before submitting a pull request.
- Tests are very, very important. Submit tests if your pull request contains new, testable behavior.
This is just to help you organize your process
- Did I cut my work branch off of master (don't cut new branches from existing feature brances)?
- Is my branch focused on a single main change?
- Do all of my changes directly relate to this change?
- Did I rebase the upstream master branch after I finished all my work?
- Did I write a clear pull request message detailing what changes I made?
- Did I include the keywords FIXES, RESOLVES or CLOSES plus the issue number in my pull request?
- Did I get a code review?
- Did I make any requested changes from that code review?
If you follow all of these guidelines and make good changes, you should have no problem getting your changes merged in.
Edited by: Andy Sponring