76aad9b76e
Make the following changes to deal with new behavior in Rails 4.1.2: * Use nested resources to avoid slashes in arguments to path helpers.
138 lines
4 KiB
Ruby
138 lines
4 KiB
Ruby
require "spec_helper"
|
|
|
|
describe IssuesHelper do
|
|
let(:project) { create :project }
|
|
let(:issue) { create :issue, project: project }
|
|
let(:ext_project) { create :redmine_project }
|
|
|
|
describe "title_for_issue" do
|
|
it "should return issue title if used internal tracker" do
|
|
@project = project
|
|
expect(title_for_issue(issue.iid)).to eq issue.title
|
|
end
|
|
|
|
it "should always return empty string if used external tracker" do
|
|
@project = ext_project
|
|
expect(title_for_issue(rand(100))).to eq ""
|
|
end
|
|
|
|
it "should always return empty string if project nil" do
|
|
@project = nil
|
|
|
|
expect(title_for_issue(rand(100))).to eq ""
|
|
end
|
|
end
|
|
|
|
describe "url_for_project_issues" do
|
|
let(:project_url) { ext_project.external_issue_tracker.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.namespace, project]) }
|
|
|
|
it "should return internal path if used internal tracker" do
|
|
@project = project
|
|
expect(url_for_project_issues).to match(int_expected)
|
|
end
|
|
|
|
it "should return path to external tracker" do
|
|
@project = ext_project
|
|
|
|
expect(url_for_project_issues).to match(ext_expected)
|
|
end
|
|
|
|
it "should return empty string if project nil" do
|
|
@project = nil
|
|
|
|
expect(url_for_project_issues).to eq ""
|
|
end
|
|
|
|
describe "when external tracker was enabled and then config removed" do
|
|
before do
|
|
@project = ext_project
|
|
allow(Gitlab.config).to receive(:issues_tracker).and_return(nil)
|
|
end
|
|
|
|
it "should return path to external tracker" do
|
|
expect(url_for_project_issues).to match(ext_expected)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "url_for_issue" do
|
|
let(:issues_url) { ext_project.external_issue_tracker.issues_url}
|
|
let(:ext_expected) do
|
|
issues_url.gsub(':id', issue.iid.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.namespace, project, issue]) }
|
|
|
|
it "should return internal path if used internal tracker" do
|
|
@project = project
|
|
expect(url_for_issue(issue.iid)).to match(int_expected)
|
|
end
|
|
|
|
it "should return path to external tracker" do
|
|
@project = ext_project
|
|
|
|
expect(url_for_issue(issue.iid)).to match(ext_expected)
|
|
end
|
|
|
|
it "should return empty string if project nil" do
|
|
@project = nil
|
|
|
|
expect(url_for_issue(issue.iid)).to eq ""
|
|
end
|
|
|
|
describe "when external tracker was enabled and then config removed" do
|
|
before do
|
|
@project = ext_project
|
|
allow(Gitlab.config).to receive(:issues_tracker).and_return(nil)
|
|
end
|
|
|
|
it "should return external path" do
|
|
expect(url_for_issue(issue.iid)).to match(ext_expected)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#url_for_new_issue' do
|
|
let(:issues_url) { ext_project.external_issue_tracker.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_namespace_project_issue_path(project.namespace, project) }
|
|
|
|
it "should return internal path if used internal tracker" do
|
|
@project = project
|
|
expect(url_for_new_issue).to match(int_expected)
|
|
end
|
|
|
|
it "should return path to external tracker" do
|
|
@project = ext_project
|
|
|
|
expect(url_for_new_issue).to match(ext_expected)
|
|
end
|
|
|
|
it "should return empty string if project nil" do
|
|
@project = nil
|
|
|
|
expect(url_for_new_issue).to eq ""
|
|
end
|
|
|
|
describe "when external tracker was enabled and then config removed" do
|
|
before do
|
|
@project = ext_project
|
|
allow(Gitlab.config).to receive(:issues_tracker).and_return(nil)
|
|
end
|
|
|
|
it "should return internal path" do
|
|
expect(url_for_new_issue).to match(ext_expected)
|
|
end
|
|
end
|
|
end
|
|
|
|
end
|