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`:
|
|
|
|
```
|
|
|
|
[alias]
|
|
|
|
mr = !sh -c 'git fetch origin merge-requests/$1/head:mr-$1 && git checkout mr-$1' -
|
|
|
|
```
|
|
|
|
Now you can check out a particular merge request from any repository (it will use the `origin` remote) by:
|
|
|
|
```
|
|
|
|
$ git mr 5
|
|
|
|
```
|
|
|
|
This will fetch the merge request into a local `mr-5` branch and check it out.
|
|
|
|
|
|
|
|
### 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/*
|
|
|
|
```
|
|
|
|
|
|
|
|
Now you can fetch all the merge requests requests:
|
|
|
|
|
|
|
|
```
|
|
|
|
$ 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)
|