Commit 942a6152 authored by Jarka Košanová's avatar Jarka Košanová

Improve readability of the epic parent validation

parent 529909e8
...@@ -326,29 +326,27 @@ module EE ...@@ -326,29 +326,27 @@ module EE
end end
def valid_parent?(parent_epic: nil, parent_group_descendants: nil) def valid_parent?(parent_epic: nil, parent_group_descendants: nil)
parent_epic ||= parent self.parent = parent_epic if parent_epic
return true unless parent_epic validate_parent(parent_group_descendants)
validate_parent(parent_epic, parent_group_descendants)
errors.empty? errors.empty?
end end
def validate_parent(parent_epic = parent, parent_group_descendents = nil) def validate_parent(preloaded_parent_group_and_descendants = nil)
return unless parent_epic return unless parent
parent_group_descendants ||= parent_epic.group.self_and_descendants preloaded_parent_group_and_descendants ||= parent.group.self_and_descendants
if self == parent_epic if self == parent
errors.add :parent, 'Cannot add an epic as a child of itself' errors.add :parent, 'Cannot add an epic as a child of itself'
elsif parent_epic.children.to_a.include?(self) elsif parent.children.to_a.include?(self)
errors.add :parent, "This epic can't be added as it is already assigned to the parent" errors.add :parent, "This epic can't be added as it is already assigned to the parent"
elsif parent_epic.has_ancestor?(self) elsif parent.has_ancestor?(self)
errors.add :parent, "This epic can't be added as it is already assigned to this epic's ancestor" errors.add :parent, "This epic can't be added as it is already assigned to this epic's ancestor"
elsif !parent_group_descendants.include?(group) elsif !preloaded_parent_group_and_descendants.include?(group)
errors.add :parent, "This epic can't be added because parent and child epics must belong to the same group" errors.add :parent, "This epic can't be added because parent and child epics must belong to the same group"
elsif level_depth_exceeded?(parent_epic) elsif level_depth_exceeded?(parent)
errors.add :parent, "This epic can't be added as the maximum depth of nested epics would be exceeded" errors.add :parent, "This epic can't be added as the maximum depth of nested epics would be exceeded"
end end
end end
......
...@@ -199,7 +199,7 @@ describe 'Epic Issues', :js do ...@@ -199,7 +199,7 @@ describe 'Epic Issues', :js do
add_epics(references) add_epics(references)
expect(page).to have_selector('.gl-field-error') expect(page).to have_selector('.gl-field-error')
expect(find('.gl-field-error')).to have_text("This epic can't be added because the parent is already at the maximum depth from its most distance ancestor") expect(find('.gl-field-error')).to have_text("This epic can't be added because the parent is already at the maximum depth from its most distant ancestor")
end end
end end
......
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