Commit 175d2048 authored by Mark Chao's avatar Mark Chao

Prevent query of calculating milestone dates when fixed dates are not used

parent 5bec56da
...@@ -123,12 +123,12 @@ module EE ...@@ -123,12 +123,12 @@ module EE
# Earliest start date from issues' milestones # Earliest start date from issues' milestones
def start_date_from_milestones def start_date_from_milestones
epic_issues.joins(issue: :milestone).minimum('milestones.start_date') start_date_is_fixed? ? epic_issues.joins(issue: :milestone).minimum('milestones.start_date') : start_date
end end
# Latest end date from issues' milestones # Latest end date from issues' milestones
def due_date_from_milestones def due_date_from_milestones
epic_issues.joins(issue: :milestone).maximum('milestones.due_date') due_date_is_fixed? ? epic_issues.joins(issue: :milestone).maximum('milestones.due_date') : due_date
end end
def to_reference(from = nil, full: false) def to_reference(from = nil, full: false)
......
...@@ -98,56 +98,78 @@ describe Epic do ...@@ -98,56 +98,78 @@ describe Epic do
end end
describe '#start_date_from_milestones' do describe '#start_date_from_milestones' do
subject { create(:epic) } context 'fixed date' do
let(:date) { Date.new(2017, 3, 4) } subject { create(:epic, :use_fixed_dates) }
let(:date) { Date.new(2017, 3, 4) }
before do before do
milestone1 = create( milestone1 = create(
:milestone, :milestone,
start_date: date, start_date: date,
due_date: date + 10.days due_date: date + 10.days
) )
epic_issue1 = create(:epic_issue, epic: subject) epic_issue1 = create(:epic_issue, epic: subject)
epic_issue1.issue.update(milestone: milestone1) epic_issue1.issue.update(milestone: milestone1)
milestone2 = create( milestone2 = create(
:milestone, :milestone,
start_date: date + 5.days, start_date: date + 5.days,
due_date: date + 15.days due_date: date + 15.days
) )
epic_issue2 = create(:epic_issue, epic: subject) epic_issue2 = create(:epic_issue, epic: subject)
epic_issue2.issue.update(milestone: milestone2) epic_issue2.issue.update(milestone: milestone2)
end
it 'returns earliest start date from issue milestones' do
expect(subject.start_date_from_milestones).to eq(date)
end
end end
it 'returns earliest start date from issue milestones' do context 'milestone date' do
expect(subject.start_date_from_milestones).to eq(date) subject { create(:epic, start_date: date) }
let(:date) { Date.new(2017, 3, 4) }
it 'returns start_date' do
expect(subject.start_date_from_milestones).to eq(date)
end
end end
end end
describe '#due_date_from_milestones' do describe '#due_date_from_milestones' do
subject { create(:epic) } context 'fixed date' do
let(:date) { Date.new(2017, 3, 4) } subject { create(:epic, :use_fixed_dates) }
let(:date) { Date.new(2017, 3, 4) }
before do before do
milestone1 = create( milestone1 = create(
:milestone, :milestone,
start_date: date - 30.days, start_date: date - 30.days,
due_date: date - 20.days due_date: date - 20.days
) )
epic_issue1 = create(:epic_issue, epic: subject) epic_issue1 = create(:epic_issue, epic: subject)
epic_issue1.issue.update(milestone: milestone1) epic_issue1.issue.update(milestone: milestone1)
milestone2 = create( milestone2 = create(
:milestone, :milestone,
start_date: date - 10.days, start_date: date - 10.days,
due_date: date due_date: date
) )
epic_issue2 = create(:epic_issue, epic: subject) epic_issue2 = create(:epic_issue, epic: subject)
epic_issue2.issue.update(milestone: milestone2) epic_issue2.issue.update(milestone: milestone2)
end
it 'returns latest due date from issue milestones' do
expect(subject.due_date_from_milestones).to eq(date)
end
end end
it 'returns latest due date from issue milestones' do context 'milestone date' do
expect(subject.due_date_from_milestones).to eq(date) subject { create(:epic, due_date: date) }
let(:date) { Date.new(2017, 3, 4) }
it 'returns due_date' do
expect(subject.due_date_from_milestones).to eq(date)
end
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