BigW Consortium Gitlab

issues_helper_spec.rb 4.24 KB
Newer Older
Andrew8xx8 committed
1 2 3
require "spec_helper"

describe IssuesHelper do
Andrew8xx8 committed
4 5 6
  let(:project) { create :project }
  let(:issue) { create :issue, project: project }
  let(:ext_project) { create :redmine_project }
Andrew8xx8 committed
7

8
  describe "url_for_issue" do
9
    let(:issues_url) { ext_project.external_issue_tracker.issues_url}
10
    let(:ext_expected) { issues_url.gsub(':id', issue.iid.to_s).gsub(':project_id', ext_project.id.to_s) }
Vinnie Okada committed
11
    let(:int_expected) { polymorphic_path([@project.namespace, project, issue]) }
Andrew8xx8 committed
12

13
    it "returns internal path if used internal tracker" do
Andrew8xx8 committed
14
      @project = project
15

16
      expect(url_for_issue(issue.iid)).to match(int_expected)
Andrew8xx8 committed
17 18
    end

19
    it "returns path to external tracker" do
Andrew8xx8 committed
20 21
      @project = ext_project

22
      expect(url_for_issue(issue.iid)).to match(ext_expected)
Andrew8xx8 committed
23 24
    end

25
    it "returns empty string if project nil" do
Andrew8xx8 committed
26 27
      @project = nil

28
      expect(url_for_issue(issue.iid)).to eq ""
Andrew8xx8 committed
29
    end
30

31 32 33 34 35 36 37 38 39 40 41 42
    it 'returns an empty string if issue_url is invalid' do
      expect(project).to receive_message_chain('issues_tracker.issue_url') { 'javascript:alert("foo");' }

      expect(url_for_issue(issue.iid, project)).to eq ''
    end

    it 'returns an empty string if issue_path is invalid' do
      expect(project).to receive_message_chain('issues_tracker.issue_path') { 'javascript:alert("foo");' }

      expect(url_for_issue(issue.iid, project, only_path: true)).to eq ''
    end

43 44 45
    describe "when external tracker was enabled and then config removed" do
      before do
        @project = ext_project
46
        allow(Gitlab.config).to receive(:issues_tracker).and_return(nil)
47 48
      end

49
      it "returns external path" do
50
        expect(url_for_issue(issue.iid)).to match(ext_expected)
51 52
      end
    end
Andrew8xx8 committed
53
  end
54

55
  describe "merge_requests_sentence" do
56 57 58 59 60 61 62 63 64
    subject { merge_requests_sentence(merge_requests)}
    let(:merge_requests) do
      [ build(:merge_request, iid: 1), build(:merge_request, iid: 2),
        build(:merge_request, iid: 3)]
    end

    it { is_expected.to eq("!1, !2, or !3") }
  end

65 66 67
  describe '#award_user_list' do
    let!(:awards) { build_list(:award_emoji, 15) }

68
    it "returns a comma seperated list of 1-9 users" do
69
      expect(award_user_list(awards.first(9), nil)).to eq(awards.first(9).map { |a| a.user.name }.to_sentence)
70 71
    end

72 73
    it "displays the current user's name as 'You'" do
      expect(award_user_list(awards.first(1), awards[0].user)).to eq('You')
74 75
    end

76 77 78 79 80 81
    it "truncates lists of larger than 9 users" do
      expect(award_user_list(awards, nil)).to eq(awards.first(9).map { |a| a.user.name }.join(', ') + ", and 6 more.")
    end

    it "displays the current user in front of 0-9 other users" do
      expect(award_user_list(awards, awards[0].user)).
82
        to eq("You, " + awards[1..9].map { |a| a.user.name }.join(', ') + ", and 5 more.")
83 84 85 86
    end

    it "displays the current user in front regardless of position in the list" do
      expect(award_user_list(awards, awards[12].user)).
87
        to eq("You, " + awards[0..8].map { |a| a.user.name }.join(', ') + ", and 5 more.")
88 89 90
    end
  end

91 92
  describe '#award_active_class' do
    let!(:upvote) { create(:award_emoji) }
Valery Sizov committed
93 94

    it "returns empty string for unauthenticated user" do
95
      expect(award_active_class(AwardEmoji.all, nil)).to eq("")
Valery Sizov committed
96 97 98
    end

    it "returns active string for author" do
99
      expect(award_active_class(AwardEmoji.all, upvote.user)).to eq("active")
Valery Sizov committed
100 101
    end
  end
Valery Sizov committed
102

103
  describe "awards_sort" do
Valery Sizov committed
104
    it "sorts a hash so thumbsup and thumbsdown are always on top" do
Valery Sizov committed
105
      data = { "thumbsdown" => "some value", "lifter" => "some value", "thumbsup" => "some value" }
Valery Sizov committed
106 107 108
      expect(awards_sort(data).keys).to eq(["thumbsup", "thumbsdown", "lifter"])
    end
  end
109

110
  describe "milestone_options" do
111
    it "gets closed milestone from current issue" do
112 113 114 115 116
      closed_milestone = create(:closed_milestone, project: project)
      milestone1       = create(:milestone, project: project)
      milestone2       = create(:milestone, project: project)
      issue.update_attributes(milestone_id: closed_milestone.id)

117
      options = milestone_options(issue)
118

119 120 121 122 123
      expect(options).to have_selector('option[selected]', text: closed_milestone.title)
      expect(options).to have_selector('option', text: milestone1.title)
      expect(options).to have_selector('option', text: milestone2.title)
    end
  end
Andrew8xx8 committed
124
end