Commit 6c345997 authored by Dmitriy Zaporozhets's avatar Dmitriy Zaporozhets

Add new methods to MR to check if source or target branch exists

Signed-off-by: default avatarDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
parent 5a4386a4
...@@ -160,14 +160,17 @@ class Projects::MergeRequestsController < Projects::ApplicationController ...@@ -160,14 +160,17 @@ class Projects::MergeRequestsController < Projects::ApplicationController
end end
def validates_merge_request def validates_merge_request
# If source project was removed (Ex. mr from fork to origin)
return invalid_mr unless @merge_request.source_project
# Show git not found page # Show git not found page
# if there is no saved commits between source & target branch # if there is no saved commits between source & target branch
if @merge_request.commits.blank? if @merge_request.commits.blank?
# and if source target doesn't exist # and if target branch doesn't exist
return invalid_mr unless @merge_request.target_project.repository.branch_names.include?(@merge_request.target_branch) return invalid_mr unless @merge_request.target_branch_exists?
# or if source branch doesn't exist # or if source branch doesn't exist
return invalid_mr unless @merge_request.source_project.repository.branch_names.include?(@merge_request.source_branch) return invalid_mr unless @merge_request.source_branch_exists?
end end
end end
......
...@@ -262,7 +262,7 @@ class MergeRequest < ActiveRecord::Base ...@@ -262,7 +262,7 @@ class MergeRequest < ActiveRecord::Base
# Return the set of issues that will be closed if this merge request is accepted. # Return the set of issues that will be closed if this merge request is accepted.
def closes_issues def closes_issues
if target_branch == project.default_branch if target_branch == project.default_branch
unmerged_commits.map { |c| c.closes_issues(project) }.flatten.uniq.sort_by(&:id) commits.map { |c| c.closes_issues(project) }.flatten.uniq.sort_by(&:id)
else else
[] []
end end
...@@ -273,6 +273,34 @@ class MergeRequest < ActiveRecord::Base ...@@ -273,6 +273,34 @@ class MergeRequest < ActiveRecord::Base
"merge request !#{iid}" "merge request !#{iid}"
end end
def target_project_path
if target_project
target_project.path_with_namespace
else
"(removed)"
end
end
def source_project_path
if source_project
source_project.path_with_namespace
else
"(removed)"
end
end
def source_branch_exists?
return false unless self.source_project
self.source_project.repository.branch_names.include?(self.source_branch)
end
def target_branch_exists?
return false unless self.target_project
self.target_project.repository.branch_names.include?(self.target_branch)
end
private private
def dump_commits(commits) def dump_commits(commits)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment