summaryrefslogtreecommitdiff
path: root/app/services
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2015-07-15 15:27:14 +0200
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2015-07-15 15:27:14 +0200
commit277f311f20739bd97f4059b51dfa1dbc38aa38e1 (patch)
treeeeaacaf966b4fc5c27b2887bb0bbc0c76cd94e6b /app/services
parent997a3b1d872f6b6b198582677acd67595bb15029 (diff)
downloadgitlab-ce-277f311f20739bd97f4059b51dfa1dbc38aa38e1.tar.gz
Fetch reference from fork repo when create merge request
Diffstat (limited to 'app/services')
-rw-r--r--app/services/merge_requests/create_service.rb9
1 files changed, 9 insertions, 0 deletions
diff --git a/app/services/merge_requests/create_service.rb b/app/services/merge_requests/create_service.rb
index f431c5d5534..8389f29a53a 100644
--- a/app/services/merge_requests/create_service.rb
+++ b/app/services/merge_requests/create_service.rb
@@ -9,6 +9,15 @@ module MergeRequests
merge_request.author = current_user
if merge_request.save
+ # Fetch fork branch into hidden ref of target repository
+ if merge_request.for_fork?
+ merge_request.target_project.repository.fetch_ref(
+ merge_request.source_project.repository.path_to_repo,
+ "refs/heads/#{merge_request.source_branch}",
+ "refs/merge-requests/#{merge_request.id}/head"
+ )
+ end
+
merge_request.update_attributes(label_ids: label_params)
event_service.open_mr(merge_request, current_user)
notification_service.new_merge_request(merge_request, current_user)