diff options
author | 🙈 jacopo beschi 🙉 <intrip@gmail.com> | 2019-09-12 10:23:24 +0000 |
---|---|---|
committer | Rémy Coutable <remy@rymai.me> | 2019-09-12 10:23:24 +0000 |
commit | 58de7d8f485d34861b077575da29a7cc1ba49bc1 (patch) | |
tree | 0364a41e6dfdc806265536bbac913f8053be199a /app/services/merge_requests | |
parent | 5abf3186d408752901621aa4fb7054396128c8ce (diff) | |
download | gitlab-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.rb | 30 |
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 |