summaryrefslogtreecommitdiff
path: root/app/services/merge_requests
diff options
context:
space:
mode:
author🙈 jacopo beschi 🙉 <intrip@gmail.com>2019-09-12 10:23:24 +0000
committerRémy Coutable <remy@rymai.me>2019-09-12 10:23:24 +0000
commit58de7d8f485d34861b077575da29a7cc1ba49bc1 (patch)
tree0364a41e6dfdc806265536bbac913f8053be199a /app/services/merge_requests
parent5abf3186d408752901621aa4fb7054396128c8ce (diff)
downloadgitlab-ce-58de7d8f485d34861b077575da29a7cc1ba49bc1.tar.gz
Fix create MR from issue using a tag as ref
Creating a MR from an issue using a tag as ref correctly creates the source branch starting from the tag.
Diffstat (limited to 'app/services/merge_requests')
-rw-r--r--app/services/merge_requests/create_from_issue_service.rb30
1 files changed, 28 insertions, 2 deletions
diff --git a/app/services/merge_requests/create_from_issue_service.rb b/app/services/merge_requests/create_from_issue_service.rb
index 2a217a6f689..200a34cae04 100644
--- a/app/services/merge_requests/create_from_issue_service.rb
+++ b/app/services/merge_requests/create_from_issue_service.rb
@@ -52,8 +52,26 @@ module MergeRequests
end
def ref
- return @ref if target_project.repository.branch_exists?(@ref)
+ if valid_ref?
+ @ref
+ else
+ default_branch
+ end
+ end
+
+ def valid_ref?
+ ref_is_branch? || ref_is_tag?
+ end
+
+ def ref_is_branch?
+ target_project.repository.branch_exists?(@ref)
+ end
+ def ref_is_tag?
+ target_project.repository.tag_exists?(@ref)
+ end
+
+ def default_branch
target_project.default_branch || 'master'
end
@@ -67,10 +85,18 @@ module MergeRequests
source_project_id: target_project.id,
source_branch: branch_name,
target_project_id: target_project.id,
- target_branch: ref
+ target_branch: target_branch
}
end
+ def target_branch
+ if ref_is_branch?
+ @ref
+ else
+ default_branch
+ end
+ end
+
def success(merge_request)
super().merge(merge_request: merge_request)
end