describe "problems/show.html.haml", type: 'view' do
let(:problem) { Fabricate(:problem) }
let(:comment) { Fabricate(:comment) }
let(:pivotal_tracker) {
Class.new(ErrbitPlugin::MockIssueTracker) do
def self.label; 'pivotal'; end
def self.icons; {}; end
def configured?; true; end
end
}
let(:github_tracker) {
Class.new(ErrbitPlugin::MockIssueTracker) do
def self.label; 'github'; end
def self.icons; {}; end
def configured?; true; end
end
}
let(:trackers) {
{
'github' => github_tracker,
'pivotal' => pivotal_tracker
}
}
let(:app) { AppDecorator.new(problem.app) }
before do
allow(view).to receive(:app).and_return(app)
allow(view).to receive(:problem).and_return(problem)
assign :comment, comment
assign :notices, problem.notices.page(1).per(1)
assign :notice, problem.notices.first
allow(controller).to receive(:current_user).and_return(Fabricate(:user))
end
def with_issue_tracker(tracker, problem)
allow(ErrbitPlugin::Registry).to receive(:issue_trackers).and_return(trackers)
app.issue_tracker = IssueTrackerDecorator.new(
IssueTracker.new :type_tracker => tracker, :options => {
:api_token => "token token token",
:project_id => "1234"
})
end
describe "content_for :action_bar" do
def action_bar
view.content_for(:action_bar)
end
it "should confirm the 'resolve' link by default" do
render
expect(action_bar).to have_selector('a.resolve[data-confirm="%s"]' % I18n.t('problems.confirm.resolve_one'))
end
it "should confirm the 'resolve' link if configuration is unset" do
allow(Errbit::Config).to receive(:confirm_err_actions).and_return(nil)
render
expect(action_bar).to have_selector('a.resolve[data-confirm="%s"]' % I18n.t('problems.confirm.resolve_one'))
end
it "should not confirm the 'resolve' link if configured not to" do
allow(Errbit::Config).to receive(:confirm_err_actions).and_return(false)
render
expect(action_bar).to have_selector('a.resolve[data-confirm="null"]')
end
it "should link 'up' to HTTP_REFERER if is set" do
url = 'http://localhost:3000/problems'
controller.request.env['HTTP_REFERER'] = url
render
expect(action_bar).to have_selector("span a.up[href='#{url}']", :text => 'up')
end
it "should link 'up' to app_problems_path if HTTP_REFERER isn't set'" do
controller.request.env['HTTP_REFERER'] = nil
problem = Fabricate(:problem_with_comments)
allow(view).to receive(:problem).and_return(problem)
allow(view).to receive(:app).and_return(problem.app)
render
expect(action_bar).to have_selector("span a.up[href='#{app_problems_path(problem.app)}']", :text => 'up')
end
context 'create issue links' do
let(:app) { Fabricate(:app, :github_repo => "test_user/test_repo") }
it 'should allow creating issue for github if application has a github tracker' do
problem = Fabricate(:problem_with_comments, app: app)
with_issue_tracker("github", problem)
allow(view).to receive(:problem).and_return(problem)
allow(view).to receive(:app).and_return(problem.app)
render
expect(action_bar).to have_selector("span a.create-issue", text: 'create issue')
end
context "without issue tracker associate on app" do
let(:problem){ Problem.new(:new_record => false, :app => app) }
let(:app) { App.new(:new_record => false) }
it 'not see link to create issue' do
render
expect(view.content_for(:action_bar)).to_not match(/create issue/)
end
end
context "with tracker associate on app" do
before do
with_issue_tracker("pivotal", problem)
end
context "with app having github_repo" do
let(:app) { App.new(:new_record => false, :github_repo => 'foo/bar') }
let(:problem){ Problem.new(:new_record => false, :app => app) }
before do
problem.issue_link = nil
user = Fabricate(:user, :github_login => 'test_user', :github_oauth_token => 'abcdef')
allow(controller).to receive(:current_user).and_return(user)
end
it 'links to the associated tracker' do
render
expect(view.content_for(:action_bar)).to match(".create-issue")
end
end
context "without app having github_repo" do
context "with problem without issue link" do
before do
problem.issue_link = nil
end
it 'not see link if no issue tracker' do
render
expect(view.content_for(:action_bar)).to match(/create issue/)
end
end
context "with problem with issue link" do
before do
problem.issue_link = 'http://foo'
end
it 'not see link if no issue tracker' do
render
expect(view.content_for(:action_bar)).to_not match(/create issue/)
end
end
end
end
end
end
describe "content_for :comments" do
before do
problem = Fabricate(:problem_with_comments)
allow(view).to receive(:problem).and_return(problem)
allow(view).to receive(:app).and_return(problem.app)
allow(Errbit::Config).to receive(:use_gravatar).and_return(true)
end
it 'should display comments and new comment form' do
render
expect(view.content_for(:comments)).to include('Test comment')
expect(view.content_for(:comments)).to have_selector('img[src^="http://www.gravatar.com/avatar"]')
expect(view.content_for(:comments)).to include('Add a comment')
end
it 'should display existing comments with configured tracker' do
with_issue_tracker("pivotal", problem)
render
expect(view.content_for(:comments)).to include('Test comment')
expect(view.content_for(:comments)).to have_selector('img[src^="http://www.gravatar.com/avatar"]')
end
end
end