Commit 72a3058f1aa9b4193b3ac3697a7fb100cc19e0f9
Exists in
master
and in
1 other branch
Merge pull request #655 from brandedcrate/features/extract_issue_tracker-one_issue_button
have only one 'create issue' button
Showing
2 changed files
with
36 additions
and
12 deletions
Show diff stats
app/views/problems/_issue_tracker_links.html.haml
... | ... | @@ -6,10 +6,10 @@ |
6 | 6 | %span.disabled= link_to 'creating...', '#', :class => "#{problem.issue_type}_inactive create-issue" |
7 | 7 | = link_to 'retry', create_issue_app_problem_path(app, problem), :method => :post |
8 | 8 | - else |
9 | - - if app.github_repo? | |
9 | + - if app.issue_tracker_configured? && !app.issue_tracker.label.eql?('github') | |
10 | + %span= link_to 'create issue', create_issue_app_problem_path(app, problem), :method => :post, :class => "#{app.issue_tracker.label}_create create-issue" | |
11 | + - elsif app.github_repo? | |
10 | 12 | - if current_user.can_create_github_issues? |
11 | 13 | %span= link_to 'create issue', create_issue_app_problem_path(app, problem, :tracker => 'user_github'), :method => :post, :class => "github_create create-issue" |
12 | 14 | - elsif app.issue_tracker_configured? && app.issue_tracker.label.eql?('github') |
13 | 15 | %span= link_to 'create issue', create_issue_app_problem_path(app, problem), :method => :post, :class => "github_create create-issue" |
14 | - - if app.issue_tracker_configured? && !app.issue_tracker.label.eql?('github') | |
15 | - %span= link_to 'create issue', create_issue_app_problem_path(app, problem), :method => :post, :class => "#{app.issue_tracker.label}_create create-issue" | ... | ... |
spec/views/problems/show.html.haml_spec.rb
... | ... | @@ -115,25 +115,49 @@ describe "problems/show.html.haml" do |
115 | 115 | before do |
116 | 116 | with_issue_tracker("PivotalLabsTracker", problem) |
117 | 117 | end |
118 | - context "with problem without issue link" do | |
118 | + | |
119 | + context "with app having github_repo" do | |
120 | + let(:app) { App.new(:new_record => false, :github_repo => 'foo/bar') } | |
121 | + let(:problem){ Problem.new(:new_record => false, :app => app) } | |
122 | + | |
119 | 123 | before do |
120 | 124 | problem.issue_link = nil |
125 | + user = Fabricate(:user, :github_login => 'test_user', :github_oauth_token => 'abcdef') | |
126 | + controller.stub(:current_user) { user } | |
121 | 127 | end |
122 | - it 'not see link if no issue tracker' do | |
128 | + | |
129 | + it 'links to the associated tracker' do | |
123 | 130 | render |
124 | - expect(view.content_for(:action_bar)).to match(/create issue/) | |
131 | + expect(view.content_for(:action_bar)).to match(".pivotal_create.create-issue") | |
125 | 132 | end |
126 | 133 | |
134 | + it 'does not link to github' do | |
135 | + render | |
136 | + expect(view.content_for(:action_bar)).to_not match(".github_create.create-issue") | |
137 | + end | |
127 | 138 | end |
128 | 139 | |
129 | - context "with problem with issue link" do | |
130 | - before do | |
131 | - problem.issue_link = 'http://foo' | |
140 | + context "without app having github_repo" do | |
141 | + context "with problem without issue link" do | |
142 | + before do | |
143 | + problem.issue_link = nil | |
144 | + end | |
145 | + it 'not see link if no issue tracker' do | |
146 | + render | |
147 | + expect(view.content_for(:action_bar)).to match(/create issue/) | |
148 | + end | |
149 | + | |
132 | 150 | end |
133 | 151 | |
134 | - it 'not see link if no issue tracker' do | |
135 | - render | |
136 | - expect(view.content_for(:action_bar)).to_not match(/create issue/) | |
152 | + context "with problem with issue link" do | |
153 | + before do | |
154 | + problem.issue_link = 'http://foo' | |
155 | + end | |
156 | + | |
157 | + it 'not see link if no issue tracker' do | |
158 | + render | |
159 | + expect(view.content_for(:action_bar)).to_not match(/create issue/) | |
160 | + end | |
137 | 161 | end |
138 | 162 | end |
139 | 163 | ... | ... |