debian-mirror-gitlab/spec/models/milestone_spec.rb

172 lines
4.4 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
# == Schema Information
#
# Table name: milestones
#
# id :integer not null, primary key
# title :string(255) not null
# project_id :integer not null
# description :text
# due_date :date
# created_at :datetime
# updated_at :datetime
# state :string(255)
# iid :integer
#
require 'spec_helper'
describe Milestone do
describe "Associations" do
2015-04-26 12:48:37 +05:30
it { is_expected.to belong_to(:project) }
it { is_expected.to have_many(:issues) }
2014-09-02 18:07:02 +05:30
end
describe "Validation" do
2015-09-11 14:41:01 +05:30
before do
allow(subject).to receive(:set_iid).and_return(false)
end
2015-04-26 12:48:37 +05:30
it { is_expected.to validate_presence_of(:title) }
it { is_expected.to validate_presence_of(:project) }
2014-09-02 18:07:02 +05:30
end
let(:milestone) { create(:milestone) }
let(:issue) { create(:issue) }
describe "#percent_complete" do
it "should not count open issues" do
milestone.issues << issue
2015-04-26 12:48:37 +05:30
expect(milestone.percent_complete).to eq(0)
2014-09-02 18:07:02 +05:30
end
it "should count closed issues" do
issue.close
milestone.issues << issue
2015-04-26 12:48:37 +05:30
expect(milestone.percent_complete).to eq(100)
2014-09-02 18:07:02 +05:30
end
it "should recover from dividing by zero" do
2015-04-26 12:48:37 +05:30
expect(milestone.issues).to receive(:count).and_return(0)
2015-09-11 14:41:01 +05:30
expect(milestone.percent_complete).to eq(0)
2014-09-02 18:07:02 +05:30
end
end
describe "#expires_at" do
it "should be nil when due_date is unset" do
milestone.update_attributes(due_date: nil)
2015-04-26 12:48:37 +05:30
expect(milestone.expires_at).to be_nil
2014-09-02 18:07:02 +05:30
end
it "should not be nil when due_date is set" do
milestone.update_attributes(due_date: Date.tomorrow)
2015-04-26 12:48:37 +05:30
expect(milestone.expires_at).to be_present
2014-09-02 18:07:02 +05:30
end
end
describe :expired? do
context "expired" do
before do
2015-09-11 14:41:01 +05:30
allow(milestone).to receive(:due_date).and_return(Date.today.prev_year)
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
it { expect(milestone.expired?).to be_truthy }
2014-09-02 18:07:02 +05:30
end
context "not expired" do
before do
2015-09-11 14:41:01 +05:30
allow(milestone).to receive(:due_date).and_return(Date.today.next_year)
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
it { expect(milestone.expired?).to be_falsey }
2014-09-02 18:07:02 +05:30
end
end
describe :percent_complete do
before do
2015-09-11 14:41:01 +05:30
allow(milestone).to receive_messages(
2014-09-02 18:07:02 +05:30
closed_items_count: 3,
total_items_count: 4
)
end
2015-04-26 12:48:37 +05:30
it { expect(milestone.percent_complete).to eq(75) }
2014-09-02 18:07:02 +05:30
end
describe :items_count do
before do
milestone.issues << create(:issue)
milestone.issues << create(:closed_issue)
milestone.merge_requests << create(:merge_request)
end
2015-04-26 12:48:37 +05:30
it { expect(milestone.closed_items_count).to eq(1) }
it { expect(milestone.open_items_count).to eq(2) }
it { expect(milestone.total_items_count).to eq(3) }
it { expect(milestone.is_empty?).to be_falsey }
2014-09-02 18:07:02 +05:30
end
describe :can_be_closed? do
2015-04-26 12:48:37 +05:30
it { expect(milestone.can_be_closed?).to be_truthy }
2014-09-02 18:07:02 +05:30
end
describe :is_empty? do
before do
2015-10-24 18:46:33 +05:30
create :closed_issue, milestone: milestone
create :merge_request, milestone: milestone
2014-09-02 18:07:02 +05:30
end
it 'Should return total count of issues and merge requests assigned to milestone' do
2015-04-26 12:48:37 +05:30
expect(milestone.total_items_count).to eq 2
2014-09-02 18:07:02 +05:30
end
end
describe :can_be_closed? do
before do
milestone = create :milestone
create :closed_issue, milestone: milestone
2015-10-24 18:46:33 +05:30
create :issue
2014-09-02 18:07:02 +05:30
end
it 'should be true if milestone active and all nested issues closed' do
2015-04-26 12:48:37 +05:30
expect(milestone.can_be_closed?).to be_truthy
2014-09-02 18:07:02 +05:30
end
it 'should be false if milestone active and not all nested issues closed' do
issue.milestone = milestone
issue.save
2015-04-26 12:48:37 +05:30
expect(milestone.can_be_closed?).to be_falsey
2014-09-02 18:07:02 +05:30
end
end
2015-11-26 14:37:03 +05:30
describe '#sort_issues' do
let(:milestone) { create(:milestone) }
let(:issue1) { create(:issue, milestone: milestone, position: 1) }
let(:issue2) { create(:issue, milestone: milestone, position: 2) }
let(:issue3) { create(:issue, milestone: milestone, position: 3) }
let(:issue4) { create(:issue, position: 42) }
it 'sorts the given issues' do
milestone.sort_issues([issue3.id, issue2.id, issue1.id])
issue1.reload
issue2.reload
issue3.reload
expect(issue1.position).to eq(3)
expect(issue2.position).to eq(2)
expect(issue3.position).to eq(1)
end
it 'ignores issues not part of the milestone' do
milestone.sort_issues([issue3.id, issue2.id, issue1.id, issue4.id])
issue4.reload
expect(issue4.position).to eq(42)
end
end
2014-09-02 18:07:02 +05:30
end