2017-01-16 13:43:03 -05:00
|
|
|
shared_examples 'update invalid issuable' do |klass|
|
|
|
|
let(:params) do
|
|
|
|
{
|
|
|
|
namespace_id: project.namespace.path,
|
|
|
|
project_id: project.path,
|
|
|
|
id: issuable.iid
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:issuable) do
|
|
|
|
klass == Issue ? issue : merge_request
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
if klass == Issue
|
|
|
|
params.merge!(issue: { title: "any" })
|
|
|
|
else
|
|
|
|
params.merge!(merge_request: { title: "any" })
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when updating causes conflicts' do
|
|
|
|
before do
|
2017-06-21 09:48:12 -04:00
|
|
|
allow_any_instance_of(issuable.class).to receive(:save)
|
|
|
|
.and_raise(ActiveRecord::StaleObjectError.new(issuable, :save))
|
2017-01-16 13:43:03 -05:00
|
|
|
end
|
|
|
|
|
2017-09-19 04:30:18 -04:00
|
|
|
if klass == MergeRequest
|
|
|
|
it 'renders edit when format is html' do
|
|
|
|
put :update, params
|
2017-01-16 13:43:03 -05:00
|
|
|
|
2017-09-19 04:30:18 -04:00
|
|
|
expect(response).to render_template(:edit)
|
|
|
|
expect(assigns[:conflict]).to be_truthy
|
|
|
|
end
|
2017-01-16 13:43:03 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders json error message when format is json' do
|
2017-02-27 10:57:04 -05:00
|
|
|
params[:format] = "json"
|
2017-01-16 13:43:03 -05:00
|
|
|
|
|
|
|
put :update, params
|
|
|
|
|
|
|
|
expect(response.status).to eq(409)
|
|
|
|
expect(JSON.parse(response.body)).to have_key('errors')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-09-19 04:30:18 -04:00
|
|
|
if klass == MergeRequest
|
|
|
|
context 'when updating an invalid issuable' do
|
|
|
|
before do
|
|
|
|
params[:merge_request][:title] = ""
|
|
|
|
end
|
2017-01-16 13:43:03 -05:00
|
|
|
|
2017-09-19 04:30:18 -04:00
|
|
|
it 'renders edit when merge request is invalid' do
|
|
|
|
put :update, params
|
2017-01-16 13:43:03 -05:00
|
|
|
|
2017-09-19 04:30:18 -04:00
|
|
|
expect(response).to render_template(:edit)
|
|
|
|
end
|
2017-01-16 13:43:03 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|