BigW Consortium Gitlab

issues_helper_spec.rb 3.94 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 9 10

  describe :title_for_issue do
    it "should return issue title if used internal tracker" do
      @project = project
11
      title_for_issue(issue.iid).should eq issue.title
Andrew8xx8 committed
12 13 14 15 16 17 18 19 20 21 22 23 24 25
    end

    it "should always return empty string if used external tracker" do
      @project = ext_project
      title_for_issue(rand(100)).should eq ""
    end

    it "should always return empty string if project nil" do
      @project = nil

      title_for_issue(rand(100)).should eq ""
    end
  end

Andrew8xx8 committed
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
  describe :url_for_project_issues do
    let(:project_url) { Gitlab.config.issues_tracker.redmine.project_url}
    let(:ext_expected) do
      project_url.gsub(':project_id', ext_project.id.to_s)
                 .gsub(':issues_tracker_id', ext_project.issues_tracker_id.to_s)
    end
    let(:int_expected) { polymorphic_path([project]) }

    it "should return internal path if used internal tracker" do
      @project = project
      url_for_project_issues.should match(int_expected)
    end

    it "should return path to external tracker" do
      @project = ext_project

      url_for_project_issues.should match(ext_expected)
    end

    it "should return empty string if project nil" do
      @project = nil

      url_for_project_issues.should eq ""
    end
50 51 52 53 54 55 56 57 58 59 60

    describe "when external tracker was enabled and then config removed" do
      before do
        @project = ext_project
        Gitlab.config.stub(:issues_tracker).and_return(nil)
      end

      it "should return path to internal tracker" do
        url_for_project_issues.should match(polymorphic_path([@project]))
      end
    end
Andrew8xx8 committed
61 62
  end

Andrew8xx8 committed
63 64
  describe :url_for_issue do
    let(:issue_id) { 3 }
65
    let(:issues_url) { Gitlab.config.issues_tracker.redmine.issues_url}
Andrew8xx8 committed
66 67 68 69 70 71 72 73 74
    let(:ext_expected) do
      issues_url.gsub(':id', issue_id.to_s)
        .gsub(':project_id', ext_project.id.to_s)
        .gsub(':issues_tracker_id', ext_project.issues_tracker_id.to_s)
    end
    let(:int_expected) { polymorphic_path([project, issue]) }

    it "should return internal path if used internal tracker" do
      @project = project
75
      url_for_issue(issue.iid).should match(int_expected)
Andrew8xx8 committed
76 77 78 79 80 81 82 83 84 85 86
    end

    it "should return path to external tracker" do
      @project = ext_project

      url_for_issue(issue_id).should match(ext_expected)
    end

    it "should return empty string if project nil" do
      @project = nil

87
      url_for_issue(issue.iid).should eq ""
Andrew8xx8 committed
88
    end
89 90 91 92 93 94 95 96 97 98 99

    describe "when external tracker was enabled and then config removed" do
      before do
        @project = ext_project
        Gitlab.config.stub(:issues_tracker).and_return(nil)
      end

      it "should return internal path" do
        url_for_issue(issue.iid).should match(polymorphic_path([@project, issue]))
      end
    end
Andrew8xx8 committed
100
  end
101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125

  describe :url_for_new_issue do
    let(:issues_url) { Gitlab.config.issues_tracker.redmine.new_issue_url}
    let(:ext_expected) do
      issues_url.gsub(':project_id', ext_project.id.to_s)
        .gsub(':issues_tracker_id', ext_project.issues_tracker_id.to_s)
    end
    let(:int_expected) { new_project_issue_path(project) }

    it "should return internal path if used internal tracker" do
      @project = project
      url_for_new_issue.should match(int_expected)
    end

    it "should return path to external tracker" do
      @project = ext_project

      url_for_new_issue.should match(ext_expected)
    end

    it "should return empty string if project nil" do
      @project = nil

      url_for_new_issue.should eq ""
    end
126 127 128 129 130 131 132 133 134 135 136

    describe "when external tracker was enabled and then config removed" do
      before do
        @project = ext_project
        Gitlab.config.stub(:issues_tracker).and_return(nil)
      end

      it "should return internal path" do
        url_for_new_issue.should match(new_project_issue_path(@project))
      end
    end
137 138
  end

Andrew8xx8 committed
139
end