- If you don't already have one, create a GitHub account
- Enable two-factor authentication
- GitHub's appearance can easily be customized with Stylish. If you just want to change tab width from 8 to 4, you may find this extension convenient. With Stylish more customization is easy. You can create a new style and use the following to customize to your preference:
/* affects source code blocks */
.blob-code-inner,
.highlight {
font-size: 16px;
tab-size: 4;
}
/* affects all container blocks */
.container {
width: 1200px;
}
Using GitHub will be a daily process so it is very important that you understand it.
- Clone the main repository, e.g.
https://github.com/mkdecisiondev/project.git
- This step should create a remote named
origin
that points tohttps://github.com/mkdecisiondev/project.git
- This step should create a remote named
- Create a fork of the repository by clicking the "Fork" button at the top right of the page
- Add a remote for your fork:
git remote add <GitHub username> https://github.com/<GitHub username>/project.git
- Create a new branch based off master:
git checkout -b my-branch
- Do your work and make some commits in "my-branch"
- When your work is done and you are ready to submit a pull request, check if master has been updated
- If master has been updated you will need to rebase those changes into your branch:
git checkout master
git pull origin master
git checkout my-branch
git rebase master
git push -f
You will have to force push to send your updates to GitHub since rebasing rewrites history. If you are not the only person working on the branch, be sure to coordinate with others every time you rebase. They will have to force pull to receive your updates.- If there are conflicts during the rebase, you will have to resolve them - get help from a team member if you are not experienced with this process
- Once you have pushed your branch to your GitHub fork you can create a pull request
- Open your fork of the repository on GitHub
- Select your branch from the "Branches" dropdown on the left
- Click the "Pull request" link on the right
- PR title: should generally be the same as the issue title, e.g. "Create AmazingWidget component" or "Fix BuggyWidget issue"
- The PR should only address changes specified by its ticket - unrelated fixes/updates should not be squeezed in, they should go in separate PRs
- PR description: should describe what changes in the codebase are introduced by the PR. The last line of the PR should say "Closes/Resolves/Fixes #XX" where "XX" is the number of the related issue
- To the right of the PR title and description there is a "Reviewers" option - assign a reviewer and post a message in the project's chat letting them know you've submitted a PR for review
remote
: a URL from which a repository can be fetched (or pushed to).origin
: this is the default name for the primary remote for a repository. It should point to the repository under the "mkdecisiondev" organization.fork
: a copy of a repository on GitHub. A fork is a GitHub feature, not a Git concept. Typically you will only have read access to repositories on GitHub. By creating a fork, you have a copy of the repository on GitHub that you have write access to which enables you to create pull requests to the main repository. There is no automatic synchronization between the main repo and your fork. To update master, or any other branch on your fork you have to push from your local repo.rebase
: a Git procedure that inserts commits into history.
origin
: this should always be the primary team repository under the "mkdecisiondev" organizationupstream
: don't use this naming scheme<username>
: for remotes pointing to your fork, or other team member's forks, name the remote the same as their GitHub user name
A good GUI like TortoiseGit makes this easy. If you prefer the CLI then learn how to use git remote
. If you accidentally cloned from a fork, you will end up with origin
pointing to the fork. Rename that remote and create a new origin
that points to mkdecisiondev
.
At the time you create the branch new-feature
the history may look like this:
Branch: master
A -> B -> C
Branch: new-feature
A -> B -> C -> D
While work is being done in new-feature
, updates are also made to master
:
Branch: master
A -> B -> C -> E
Branch: new-feature
A -> B -> C -> D
To avoid creating merge commits, new-feature
can be rebased on master
:
Branch: new-feature
A -> B -> C -> E -> D
Branches should ideally be short-lived and introduce a compact set of changes. If you are working in a branch for days or weeks, you should regularly check if you need to rebase on master. Waiting to merge a large set of changes will be complicated.