Commit db99dc75 authored by Nick Thomas's avatar Nick Thomas

Merge branch...

Merge branch '9726-usage-ping-for-epics_deepest_relationship_level-should-not-be-1-for-most-non-eeu-cases' into 'master'

Return nil for epics_deepest_relationship_level when there are no Epics

Closes #9726

See merge request gitlab-org/gitlab-ee!10756
parents 95bf13b1 a06c7a6a
...@@ -159,12 +159,7 @@ module EE ...@@ -159,12 +159,7 @@ module EE
def deepest_relationship_level def deepest_relationship_level
return unless supports_nested_objects? return unless supports_nested_objects?
hierarchy = ::Gitlab::ObjectHierarchy.new(self.where.not(parent_id: nil)) ::Gitlab::ObjectHierarchy.new(self.where(parent_id: nil)).max_descendants_depth
deepest_level = hierarchy.max_descendants_depth || 0
# For performance reasons, epics without a parent_id are being ignored in the query.
# So we add 1 to the result to take into account the first parent.
deepest_level + 1
end end
def update_start_and_due_dates(epics) def update_start_and_due_dates(epics)
......
require 'spec_helper' require 'spec_helper'
describe Epic do describe Epic do
let(:group) { create(:group) } set(:group) { create(:group) }
let(:project) { create(:project, group: group) } let(:project) { create(:project, group: group) }
describe 'associations' do describe 'associations' do
...@@ -16,7 +16,7 @@ describe Epic do ...@@ -16,7 +16,7 @@ describe Epic do
end end
describe 'validations' do describe 'validations' do
subject { create(:epic) } subject { build(:epic) }
it { is_expected.to validate_presence_of(:group) } it { is_expected.to validate_presence_of(:group) }
it { is_expected.to validate_presence_of(:author) } it { is_expected.to validate_presence_of(:author) }
...@@ -86,33 +86,29 @@ describe Epic do ...@@ -86,33 +86,29 @@ describe Epic do
end end
end end
describe '#ancestors', :nested_groups do context 'hierarchy' do
set(:group) { create(:group) }
set(:epic1) { create(:epic, group: group) }
set(:epic2) { create(:epic, group: group, parent: epic1) }
set(:epic3) { create(:epic, group: group, parent: epic2) }
it 'returns all ancestors for an epic' do
expect(epic3.ancestors).to eq [epic2, epic1]
end
it 'returns an empty array if an epic does not have any parent' do
expect(epic1.ancestors).to be_empty
end
end
describe '#descendants', :nested_groups do
let(:group) { create(:group) }
let(:epic1) { create(:epic, group: group) } let(:epic1) { create(:epic, group: group) }
let(:epic2) { create(:epic, group: group, parent: epic1) } let(:epic2) { create(:epic, group: group, parent: epic1) }
let(:epic3) { create(:epic, group: group, parent: epic2) } let(:epic3) { create(:epic, group: group, parent: epic2) }
it 'returns all ancestors for an epic' do describe '#ancestors', :nested_groups do
expect(epic1.descendants).to match_array([epic2, epic3]) it 'returns all ancestors for an epic' do
expect(epic3.ancestors).to eq [epic2, epic1]
end
it 'returns an empty array if an epic does not have any parent' do
expect(epic1.ancestors).to be_empty
end
end end
it 'returns an empty array if an epic does not have any descendants' do describe '#descendants', :nested_groups do
expect(epic3.descendants).to be_empty it 'returns all ancestors for an epic' do
expect(epic1.descendants).to match_array([epic2, epic3])
end
it 'returns an empty array if an epic does not have any descendants' do
expect(epic3.descendants).to be_empty
end
end end
end end
...@@ -465,6 +461,12 @@ describe Epic do ...@@ -465,6 +461,12 @@ describe Epic do
end end
describe '.deepest_relationship_level', :postgresql do describe '.deepest_relationship_level', :postgresql do
context 'when there are no epics' do
it 'returns nil' do
expect(described_class.deepest_relationship_level).to be_nil
end
end
it 'returns the deepest relationship level between epics' do it 'returns the deepest relationship level between epics' do
group_1 = create(:group) group_1 = create(:group)
group_2 = create(:group) group_2 = create(:group)
...@@ -605,7 +607,6 @@ describe Epic do ...@@ -605,7 +607,6 @@ describe Epic do
end end
context 'mentioning other objects' do context 'mentioning other objects' do
let(:group) { create(:group) }
let(:epic) { create(:epic, group: group) } let(:epic) { create(:epic, group: group) }
let(:project) { create(:project, :repository, :public) } let(:project) { create(:project, :repository, :public) }
......
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