BigW Consortium Gitlab

milestoneish_spec.rb 5.27 KB
Newer Older
1 2 3 4 5 6 7
require 'spec_helper'

describe Milestone, 'Milestoneish' do
  let(:author) { create(:user) }
  let(:assignee) { create(:user) }
  let(:non_member) { create(:user) }
  let(:member) { create(:user) }
8
  let(:guest) { create(:user) }
9
  let(:admin) { create(:admin) }
10
  let(:project) { create(:empty_project, :public) }
11 12 13
  let(:milestone) { create(:milestone, project: project) }
  let!(:issue) { create(:issue, project: project, milestone: milestone) }
  let!(:security_issue_1) { create(:issue, :confidential, project: project, author: author, milestone: milestone) }
14
  let!(:security_issue_2) { create(:issue, :confidential, project: project, assignees: [assignee], milestone: milestone) }
15 16 17
  let!(:closed_issue_1) { create(:issue, :closed, project: project, milestone: milestone) }
  let!(:closed_issue_2) { create(:issue, :closed, project: project, milestone: milestone) }
  let!(:closed_security_issue_1) { create(:issue, :confidential, :closed, project: project, author: author, milestone: milestone) }
18
  let!(:closed_security_issue_2) { create(:issue, :confidential, :closed, project: project, assignees: [assignee], milestone: milestone) }
19
  let!(:closed_security_issue_3) { create(:issue, :confidential, :closed, project: project, author: author, milestone: milestone) }
20
  let!(:closed_security_issue_4) { create(:issue, :confidential, :closed, project: project, assignees: [assignee], milestone: milestone) }
21 22 23 24
  let!(:merge_request) { create(:merge_request, source_project: project, target_project: project, milestone: milestone) }

  before do
    project.team << [member, :developer]
25
    project.team << [guest, :guest]
26 27 28
  end

  describe '#closed_items_count' do
29
    it 'does not count confidential issues for non project members' do
30 31 32
      expect(milestone.closed_items_count(non_member)).to eq 2
    end

33
    it 'does not count confidential issues for project members with guest role' do
34 35 36
      expect(milestone.closed_items_count(guest)).to eq 2
    end

37
    it 'counts confidential issues for author' do
38 39 40
      expect(milestone.closed_items_count(author)).to eq 4
    end

41
    it 'counts confidential issues for assignee' do
42 43 44
      expect(milestone.closed_items_count(assignee)).to eq 4
    end

45
    it 'counts confidential issues for project members' do
46 47 48
      expect(milestone.closed_items_count(member)).to eq 6
    end

49
    it 'counts all issues for admin' do
50 51 52 53 54
      expect(milestone.closed_items_count(admin)).to eq 6
    end
  end

  describe '#total_items_count' do
55
    it 'does not count confidential issues for non project members' do
56 57 58
      expect(milestone.total_items_count(non_member)).to eq 4
    end

59
    it 'does not count confidential issues for project members with guest role' do
60 61 62
      expect(milestone.total_items_count(guest)).to eq 4
    end

63
    it 'counts confidential issues for author' do
64 65 66
      expect(milestone.total_items_count(author)).to eq 7
    end

67
    it 'counts confidential issues for assignee' do
68 69 70
      expect(milestone.total_items_count(assignee)).to eq 7
    end

71
    it 'counts confidential issues for project members' do
72 73 74
      expect(milestone.total_items_count(member)).to eq 10
    end

75
    it 'counts all issues for admin' do
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
      expect(milestone.total_items_count(admin)).to eq 10
    end
  end

  describe '#complete?' do
    it 'returns false when has items opened' do
      expect(milestone.complete?(non_member)).to eq false
    end

    it 'returns true when all items are closed' do
      issue.close
      merge_request.close

      expect(milestone.complete?(non_member)).to eq true
    end
  end

  describe '#percent_complete' do
94
    it 'does not count confidential issues for non project members' do
95 96 97
      expect(milestone.percent_complete(non_member)).to eq 50
    end

98
    it 'does not count confidential issues for project members with guest role' do
99 100 101
      expect(milestone.percent_complete(guest)).to eq 50
    end

102
    it 'counts confidential issues for author' do
103 104 105
      expect(milestone.percent_complete(author)).to eq 57
    end

106
    it 'counts confidential issues for assignee' do
107 108 109
      expect(milestone.percent_complete(assignee)).to eq 57
    end

110
    it 'counts confidential issues for project members' do
111 112 113
      expect(milestone.percent_complete(member)).to eq 60
    end

114
    it 'counts confidential issues for admin' do
115 116 117
      expect(milestone.percent_complete(admin)).to eq 60
    end
  end
118

119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138
  describe '#remaining_days' do
    it 'shows 0 if no due date' do
      milestone = build_stubbed(:milestone)

      expect(milestone.remaining_days).to eq(0)
    end

    it 'shows 0 if expired' do
      milestone = build_stubbed(:milestone, due_date: 2.days.ago)

      expect(milestone.remaining_days).to eq(0)
    end

    it 'shows correct remaining days' do
      milestone = build_stubbed(:milestone, due_date: 2.days.from_now)

      expect(milestone.remaining_days).to eq(2)
    end
  end

139 140
  describe '#elapsed_days' do
    it 'shows 0 if no start_date set' do
141
      milestone = build_stubbed(:milestone)
142 143 144 145 146

      expect(milestone.elapsed_days).to eq(0)
    end

    it 'shows 0 if start_date is a future' do
147
      milestone = build_stubbed(:milestone, start_date: Time.now + 2.days)
148 149 150 151 152

      expect(milestone.elapsed_days).to eq(0)
    end

    it 'shows correct amount of days' do
153
      milestone = build_stubbed(:milestone, start_date: Time.now - 2.days)
154 155 156 157

      expect(milestone.elapsed_days).to eq(2)
    end
  end
158
end