2015-08-11 08:33:31 -04:00
# Merge Requests
Merge requests allow you to exchange changes you made to source code
2016-06-07 07:02:55 -04:00
## Only allow merge requests to be merged if the build succeeds
You can prevent merge requests from being merged if their build did not succeed
in the project settings page.
![only_allow_merge_if_build_succeeds ](merge_requests/only_allow_merge_if_build_succeeds.png )
Navigate to project settings page and select the `Only allow merge requests to be merged if the build succeeds` check box.
Please note that you need to have builds configured to enable this feature.
2015-08-11 08:33:31 -04:00
## Checkout merge requests locally
2016-08-22 15:57:43 -04:00
### By adding a git alias
Add the following alias to your `~/.gitconfig` :
2016-08-23 15:02:16 -04:00
2016-08-22 15:57:43 -04:00
```
[alias]
2016-08-23 15:05:34 -04:00
mr = !sh -c 'git fetch $1 merge-requests/$2/head:mr-$1-$2 & & git checkout mr-$1-$2' -
2016-08-22 15:57:43 -04:00
```
2016-08-23 15:02:16 -04:00
2016-08-23 15:05:34 -04:00
Now you can check out a particular merge request from any repository and any remote, e.g. to check out a merge request number 5 as shown in GitLab from the `upstream` remote, do:
2016-08-23 15:02:16 -04:00
2016-08-22 15:57:43 -04:00
```
2016-08-23 15:05:34 -04:00
$ git mr upstream 5
2016-08-22 15:57:43 -04:00
```
2016-08-23 15:02:16 -04:00
2016-08-23 15:05:34 -04:00
This will fetch the merge request into a local `mr-upstream-5` branch and check it out.
2016-08-22 15:57:43 -04:00
### By modifying `.git/config` for a given repository
2015-08-11 08:33:31 -04:00
Locate the section for your GitLab remote in the `.git/config` file. It looks like this:
```
[remote "origin"]
url = https://gitlab.com/gitlab-org/gitlab-ce.git
fetch = +refs/heads/*:refs/remotes/origin/*
```
2016-04-05 17:09:49 -04:00
Now add the line `fetch = +refs/merge-requests/*/head:refs/remotes/origin/merge-requests/*` to this section.
2015-08-11 08:33:31 -04:00
2016-04-05 17:09:49 -04:00
It should look like this:
2015-08-11 08:33:31 -04:00
```
[remote "origin"]
url = https://gitlab.com/gitlab-org/gitlab-ce.git
fetch = +refs/heads/*:refs/remotes/origin/*
fetch = +refs/merge-requests/*/head:refs/remotes/origin/merge-requests/*
```
2016-08-25 00:56:48 -04:00
Now you can fetch all the merge requests:
2015-08-11 08:33:31 -04:00
```
$ git fetch origin
From https://gitlab.com/gitlab-org/gitlab-ce.git
* [new ref] refs/merge-requests/1/head -> origin/merge-requests/1
* [new ref] refs/merge-requests/2/head -> origin/merge-requests/2
...
```
To check out a particular merge request:
```
$ git checkout origin/merge-requests/1
```
2015-10-21 20:55:35 -04:00
## Ignore whitespace changes in Merge Request diff view
![MR diff ](merge_requests/merge_request_diff.png )
2016-04-07 13:57:51 -04:00
If you click the "Hide whitespace changes" button, you can see the diff without whitespace changes.
2015-10-21 20:55:35 -04:00
![MR diff without whitespace ](merge_requests/merge_request_diff_without_whitespace.png )
It is also working on commits compare view.
![Commit Compare ](merge_requests/commit_compare.png )
2016-08-12 08:40:00 -04:00
## Merge Requests versions
Every time you push to merge request branch, a new version of merge request diff
is created. When you visit the merge request page you see latest version of changes.
However you can select an older one from version dropdown
![Merge Request Versions ](merge_requests/versions.png )