diff options
author | Robert Speicher <robert@gitlab.com> | 2016-06-12 19:26:29 +0000 |
---|---|---|
committer | Robert Speicher <robert@gitlab.com> | 2016-06-12 19:26:29 +0000 |
commit | 8d243f9bdacea1909bf503eb715bd437c3b48aa7 (patch) | |
tree | 122885cdf932838647df64a240185e1f1ff8b98c /spec | |
parent | 714a60b45c07fe1fd241863230422d2f76e4bcb6 (diff) | |
parent | a85dde9182f177cc2fdabd90ccdad870bf4d84c3 (diff) | |
download | gitlab-ce-8d243f9bdacea1909bf503eb715bd437c3b48aa7.tar.gz |
Merge branch 'fix-closes-issues-error-500' into 'master'
Fix Error 500 when using closes_issues API with an external issue tracker
Closes #18484
See merge request !4608
Diffstat (limited to 'spec')
-rw-r--r-- | spec/requests/api/merge_requests_spec.rb | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/spec/requests/api/merge_requests_spec.rb b/spec/requests/api/merge_requests_spec.rb index 1356f87b0e9..5896b93603f 100644 --- a/spec/requests/api/merge_requests_spec.rb +++ b/spec/requests/api/merge_requests_spec.rb @@ -563,6 +563,21 @@ describe API::API, api: true do expect(json_response).to be_an Array expect(json_response.length).to eq(0) end + + it 'handles external issues' do + jira_project = create(:jira_project, :public, name: 'JIR_EXT1') + issue = ExternalIssue.new("#{jira_project.name}-123", jira_project) + merge_request = create(:merge_request, :simple, author: user, assignee: user, source_project: jira_project) + merge_request.update_attribute(:description, "Closes #{issue.to_reference(jira_project)}") + + get api("/projects/#{jira_project.id}/merge_requests/#{merge_request.id}/closes_issues", user) + + expect(response.status).to eq(200) + expect(json_response).to be_an Array + expect(json_response.length).to eq(1) + expect(json_response.first['title']).to eq(issue.title) + expect(json_response.first['id']).to eq(issue.id) + end end describe 'POST :id/merge_requests/:merge_request_id/subscription' do |