2019-09-04 21:01:54 +05:30
|
|
|
---
|
|
|
|
type: reference, concepts
|
|
|
|
---
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
# Squash and merge
|
|
|
|
|
2019-12-04 20:38:33 +05:30
|
|
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/merge_requests/1024) in [GitLab Starter](https://about.gitlab.com/pricing/) 8.17.
|
|
|
|
> - [Ported](https://gitlab.com/gitlab-org/gitlab-foss/merge_requests/18956) to GitLab Core 11.0.
|
2018-11-08 19:23:39 +05:30
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
With squash and merge you can combine all your merge request's commits into one
|
|
|
|
and retain a clean history.
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
|
|
|
Squashing lets you tidy up the commit history of a branch when accepting a merge
|
|
|
|
request. It applies all of the changes in the merge request as a single commit,
|
|
|
|
and then merges that commit using the merge method set for the project.
|
|
|
|
|
|
|
|
In other words, squashing a merge request turns a long list of commits:
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
data:image/s3,"s3://crabby-images/ec45a/ec45aacc14d75258540c3009ccbc887845decc37" alt="List of commits from a merge request"
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
Into a single commit on merge:
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
data:image/s3,"s3://crabby-images/d2f72/d2f7223b2720ae9192f01dd4e4863e931aeb878f" alt="A squashed commit followed by a merge commit"
|
2018-11-08 19:23:39 +05:30
|
|
|
|
2019-03-02 22:35:43 +05:30
|
|
|
The squashed commit's commit message will be either:
|
|
|
|
|
|
|
|
- Taken from the first multi-line commit message in the merge.
|
|
|
|
- The merge request's title if no multi-line commit message is found.
|
|
|
|
|
|
|
|
It can be customized before merging a merge request.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6bf98/6bf983684b4d2c9097709fb319f0d2c2fb45078c" alt="A squash commit message editor"
|
|
|
|
|
|
|
|
NOTE: **Note:**
|
|
|
|
The squashed commit in this example is followed by a merge commit, as the merge method for this example repository uses a merge commit.
|
|
|
|
|
|
|
|
Squashing also works with the fast-forward merge strategy, see [squashing and fast-forward merge](#squash-and-fast-forward-merge) for more details.
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
## Use cases
|
|
|
|
|
|
|
|
When working on a feature branch, you sometimes want to commit your current
|
|
|
|
progress, but don't really care about the commit messages. Those 'work in
|
|
|
|
progress commits' don't necessarily contain important information and as such
|
2019-03-02 22:35:43 +05:30
|
|
|
you'd rather not include them in your target branch.
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
With squash and merge, when the merge request is ready to be merged,
|
|
|
|
all you have to do is enable squashing before you press merge to join
|
2019-03-02 22:35:43 +05:30
|
|
|
the commits in the merge request into a single commit.
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
This way, the history of your base branch remains clean with
|
2019-09-30 21:07:59 +05:30
|
|
|
meaningful commit messages and:
|
|
|
|
|
|
|
|
- It's simpler to [revert](revert_changes.md) if necessary.
|
|
|
|
- The merged branch will retain the full commit history.
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
## Enabling squash for a merge request
|
|
|
|
|
|
|
|
Anyone who can create or edit a merge request can choose for it to be squashed
|
|
|
|
on the merge request form:
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
data:image/s3,"s3://crabby-images/f1d25/f1d252a3e52e55b631e1a910e519b930694e99c3" alt="Squash commits checkbox on edit form"
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
This can then be overridden at the time of accepting the merge request:
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
data:image/s3,"s3://crabby-images/73f8d/73f8d658b02b45275c9791f936156ff20d43755e" alt="Squash commits checkbox on accept merge request form"
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
## Commit metadata for squashed commits
|
|
|
|
|
|
|
|
The squashed commit has the following metadata:
|
|
|
|
|
2019-03-02 22:35:43 +05:30
|
|
|
- Message: the message of the squash commit, or a customized message.
|
|
|
|
- Author: the author of the merge request.
|
|
|
|
- Committer: the user who initiated the squash.
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
## Squash and fast-forward merge
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
When a project has the [fast-forward merge setting enabled](fast_forward_merge.md#enabling-fast-forward-merges), the merge
|
2018-11-08 19:23:39 +05:30
|
|
|
request must be able to be fast-forwarded without squashing in order to squash
|
|
|
|
it. This is because squashing is only available when accepting a merge request,
|
|
|
|
so a merge request may need to be rebased before squashing, even though
|
|
|
|
squashing can itself be considered equivalent to rebasing.
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
<!-- ## Troubleshooting
|
|
|
|
|
|
|
|
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
|
|
|
|
one might have when setting this up, or when something is changed, or on upgrading, it's
|
|
|
|
important to describe those, too. Think of things that may go wrong and include them here.
|
|
|
|
This is important to minimize requests for support, and to avoid doc comments with
|
|
|
|
questions that you know someone might ask.
|
|
|
|
|
|
|
|
Each scenario can be a third-level heading, e.g. `### Getting error message X`.
|
|
|
|
If you have none to add when creating a doc, leave this section in place
|
|
|
|
but commented out to help encourage others to add to it in the future. -->
|