debian-mirror-gitlab/app/services/merge_requests/build_service.rb

142 lines
4.1 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
module MergeRequests
class BuildService < MergeRequests::BaseService
def execute
2017-08-17 22:00:37 +05:30
self.merge_request = MergeRequest.new(params)
2014-09-02 18:07:02 +05:30
merge_request.compare_commits = []
2017-08-17 22:00:37 +05:30
merge_request.source_project = find_source_project
merge_request.target_project = find_target_project
merge_request.target_branch = find_target_branch
merge_request.can_be_created = branches_valid?
2016-06-02 11:05:42 +05:30
2017-08-17 22:00:37 +05:30
compare_branches if branches_present?
assign_title_and_description if merge_request.can_be_created
2016-06-02 11:05:42 +05:30
2017-08-17 22:00:37 +05:30
merge_request
end
2014-09-02 18:07:02 +05:30
2017-08-17 22:00:37 +05:30
private
2015-09-25 12:07:36 +05:30
2017-08-17 22:00:37 +05:30
attr_accessor :merge_request
2014-09-02 18:07:02 +05:30
2017-08-17 22:00:37 +05:30
delegate :target_branch, :source_branch, :source_project, :target_project, :compare_commits, :wip_title, :description, :errors, to: :merge_request
2016-11-03 12:29:30 +05:30
2017-08-17 22:00:37 +05:30
def find_source_project
return source_project if source_project.present? && can?(current_user, :read_project, source_project)
project
end
def find_target_project
return target_project if target_project.present? && can?(current_user, :read_project, target_project)
project.default_merge_request_target
end
def find_target_branch
target_branch || target_project.default_branch
end
def source_branch_specified?
params[:source_branch].present?
end
def target_branch_specified?
params[:target_branch].present?
end
def branches_valid?
return false unless source_branch_specified? || target_branch_specified?
validate_branches
errors.blank?
end
2016-11-03 12:29:30 +05:30
2017-08-17 22:00:37 +05:30
def compare_branches
compare = CompareService.new(
source_project,
source_branch
).execute(
target_project,
target_branch
2014-09-02 18:07:02 +05:30
)
2017-08-17 22:00:37 +05:30
if compare
merge_request.compare_commits = compare.commits
merge_request.compare = compare
end
end
2014-09-02 18:07:02 +05:30
2017-08-17 22:00:37 +05:30
def validate_branches
add_error('You must select source and target branch') unless branches_present?
add_error('You must select different branches') if same_source_and_target?
add_error("Source branch \"#{source_branch}\" does not exist") unless source_branch_exists?
add_error("Target branch \"#{target_branch}\" does not exist") unless target_branch_exists?
2016-06-02 11:05:42 +05:30
end
2014-09-02 18:07:02 +05:30
2017-08-17 22:00:37 +05:30
def add_error(message)
errors.add(:base, message)
end
def branches_present?
target_branch.present? && source_branch.present?
end
def same_source_and_target?
source_project == target_project && target_branch == source_branch
end
def source_branch_exists?
source_branch.blank? || source_project.commit(source_branch)
end
def target_branch_exists?
target_branch.blank? || target_project.commit(target_branch)
end
2014-09-02 18:07:02 +05:30
2016-06-02 11:05:42 +05:30
# When your branch name starts with an iid followed by a dash this pattern will be
# interpreted as the user wants to close that issue on this project.
#
# For example:
# - Issue 112 exists, title: Emoji don't show up in commit title
# - Source branch is: 112-fix-mep-mep
#
# Will lead to:
# - Appending `Closes #112` to the description
# - Setting the title as 'Resolves "Emoji don't show up in commit title"' if there is
# more than one commit in the MR
#
2017-08-17 22:00:37 +05:30
def assign_title_and_description
if match = source_branch.match(/\A(\d+)-/)
2016-06-02 11:05:42 +05:30
iid = match[1]
2014-09-02 18:07:02 +05:30
end
2017-08-17 22:00:37 +05:30
commits = compare_commits
2015-04-26 12:48:37 +05:30
if commits && commits.count == 1
commit = commits.first
2016-06-02 11:05:42 +05:30
merge_request.title = commit.title
2016-04-02 18:10:28 +05:30
merge_request.description ||= commit.description.try(:strip)
2017-08-17 22:00:37 +05:30
elsif iid && issue = target_project.get_issue(iid, current_user)
2016-06-02 11:05:42 +05:30
case issue
when Issue
merge_request.title = "Resolve \"#{issue.title}\""
when ExternalIssue
merge_request.title = "Resolve #{issue.title}"
end
2015-04-26 12:48:37 +05:30
else
2017-08-17 22:00:37 +05:30
merge_request.title = source_branch.titleize.humanize
2015-04-26 12:48:37 +05:30
end
2016-06-02 11:05:42 +05:30
if iid
closes_issue = "Closes ##{iid}"
2017-08-17 22:00:37 +05:30
if description.present?
2016-09-29 09:46:39 +05:30
merge_request.description += closes_issue.prepend("\n\n")
2016-06-02 11:05:42 +05:30
else
merge_request.description = closes_issue
end
end
2017-08-17 22:00:37 +05:30
merge_request.title = wip_title if commits.empty?
2014-09-02 18:07:02 +05:30
end
end
end