Install Git and follow the First-Time Git Setup
Use a shell/terminal to work with Git commands and not just to rely on GUI clients. If you're working on Windows, posh-git is a great PowerShell environment for Git. Another option is to use Git bash for Windows. On Linux/Mac, install git and simply use your favorite shell/terminal.
When working on an existing project, git clone
the repository and ensure you understand the team's branch, merge and release strategy (e.g. through the projects CONTRIBUTING.md file).
If you create a new repository, agree on your branch, merge and release strategies upfront and document them in your CONTRIBUTING.md. Also lock the default branches and define who can approve and merge Pull Requests into your default branches.
A public repository needs to have the following files in the root directory of the default branch:
- a LICENSE file
- a README.md file
- a CONTRIBUTING.md file
- reference the Microsoft Open Source Code of Conduct
To start to contribute by creating your own branch (e.g. your_alias/feature_name
) and commit early and often - make your commit comments useful to others by including the WHAT and WHY (instead of the HOW).
Agree if you want a linear or non-linear commit history. There are pros and cons to both approaches:
- Pro linear: A tidy, linear Git history
- Con linear: Why you should stop using Git rebase
Merging topic
into master
A---B---C topic
/ \
D---E---F---G---H master
git fetch origin
git checkout master
git merge topic
Before merging topic
into master
, we rebase topic
with the :
A---B---C topic
/ \
D---E---F-----------G---H master
git fetch origin
git rebase master topic
git checkout master
git merge topic
Squash merging is a merge option that allows you to condense the Git history of topic branches when you complete a pull request. Instead of each commit on topic
being added to the history of master
, a squash merge takes all the file changes and adds them to a single new commit on master
.
A---B---C topic
/
D---E---F-----------G---H master
Create a PR topic --> master in Azure DevOps and approve using the squash merge option
In a nutshell, if you use git commit -m
then you're most likely not write the best commit messages ;-)
See How to Write a Git Commit Message for the reasoning and A Note About Git Commit Messages for more context. This section is merely a tl;dr summary.
- Separate subject from body with a blank line
- Limit the subject line to 50 characters
- Capitalize the subject line
- Do not end the subject line with a period
- Use the imperative mood in the subject line
- Wrap the body at 72 characters
- Use the body to explain what and why vs. how
Here an example:
Summarize changes in around 50 characters or less
More detailed explanatory text, if necessary. Wrap it to about 72
characters or so. In some contexts, the first line is treated as the
subject of the commit and the rest of the text as the body. The
blank line separating the summary from the body is critical (unless
you omit the body entirely); various tools like `log`, `shortlog`
and `rebase` can get confused if you run the two together.
Explain the problem that this commit is solving. Focus on why you
are making this change as opposed to how (the code explains that).
Are there side effects or other unintuitive consequences of this
change? Here's the place to explain them.
Azure DevOps understands Markdown, so you can use that sparingly throughout.
Further paragraphs come after blank lines.
- Bullet points are okay, too
- Typically a hyphen or asterisk is used for the bullet, preceded
by a single space (no blank lines between them on Azure DevOps)
Put issue references to them at the bottom,
like this:
Resolves: #123
See also: #456, #789
You can specify the default git editor, which allows you to write your commit messages using your favorite editor. The following command makes vscode your default git editor:
git config --global core.editor "code --wait"
Let's use the following naming conventions for branches:
- personal branches:
user/your_alias/feature_name
- feature branches for staging (testing, integration,...):
staging/feature_name
- release branches:
release/release_name
Please see versioning.
The best way to avoid leaking secrets is to store them in local/private files which will be excluded from being tracked in git. This is done by configuring the .gitignore file.
E.g. the following pattern will exclude all files with the extension .private.config
:
# remove private configuration
*.private.config
For more details on proper management of credentials and secrets in source control, and handling an accidental commit of secrets to source control, please refer to the the Secrets Management document which has further information, split by language as well.
There are two options to "undo" a commit: git revert
and git reset
. git revert
creates a new commit that undoes commits while git reset
allows to delete commits entirely from the commit history.
If you accidentally committed secrets/keys only
git reset
will remove them from the commit history!
To delete the latest commit use HEAD~
:
git reset --hard HEAD~1
To delete commits back to a specific commit, use the respective commit id:
git reset --hard <sha1-commit-id>
after you deleted the unwanted commits, just push using force
:
git push origin HEAD --force
Submodules can be very useful in more complex deployment and/or development scenarios
Adding a submodule to your repo
git submodule add -b master <your_submodule>
Initialize and pull a repo with submodules:
git submodule init
git submodule update --init --remote
git submodule foreach git checkout master
git submodule foreach git pull origin
git stash
is super handy if you have un-committed changes in your working directory but you want to work on a different branch. You can simply run git stash
and save the un-committed work and reverts back to the HEAD commit. You can retrieve the saved changes by running git stash pop
:
git stash
...
git stash pop
Or you can simply move the current state into a new branch:
git stash branch <new_branch_to_save_changes>