Expose update project service JSON endpoint

Utilize `json_fields` to expose fields via
`Service#as_json(only: json_fields)`.
This commit is contained in:
Peter Leitzen 2019-09-09 20:22:00 +00:00 committed by Douglas Barbosa Alexandre
parent a502a9d2a8
commit afe5f171db
4 changed files with 124 additions and 47 deletions

View file

@ -18,13 +18,26 @@ class Projects::ServicesController < Projects::ApplicationController
def update
@service.attributes = service_params[:service]
if @service.save(context: :manual_change)
redirect_to(project_settings_integrations_path(@project), notice: success_message)
saved = @service.save(context: :manual_change)
respond_to do |format|
format.html do
if saved
redirect_to project_settings_integrations_path(@project),
notice: success_message
else
render 'edit'
end
end
format.json do
status = saved ? :ok : :unprocessable_entity
render json: serialize_as_json, status: status
end
end
end
def test
if @service.can_test?
render json: service_test_response, status: :ok
@ -67,4 +80,10 @@ class Projects::ServicesController < Projects::ApplicationController
def ensure_service_enabled
render_404 unless service
end
def serialize_as_json
@service
.as_json(only: @service.json_fields)
.merge(errors: @service.errors.as_json)
end
end

View file

@ -107,6 +107,13 @@ class Service < ApplicationRecord
[]
end
# Expose a list of fields in the JSON endpoint.
#
# This list is used in `Service#as_json(only: json_fields)`.
def json_fields
%w(active)
end
def test_data(project, user)
Gitlab::DataBuilder::Push.build_sample(project, user)
end

View file

@ -0,0 +1,5 @@
---
title: Expose update project service endpoint JSON
merge_request: 32759
author:
type: added

View file

@ -19,9 +19,9 @@ describe Projects::ServicesController do
it 'renders 404' do
allow_any_instance_of(Service).to receive(:can_test?).and_return(false)
put :test, params: { namespace_id: project.namespace, project_id: project, id: service.to_param }
put :test, params: project_params
expect(response).to have_gitlab_http_status(404)
expect(response).to have_gitlab_http_status(:not_found)
end
end
@ -29,11 +29,11 @@ describe Projects::ServicesController do
let(:service_params) { { active: 'true', url: '' } }
it 'returns error messages in JSON response' do
put :test, params: { namespace_id: project.namespace, project_id: project, id: service.to_param, service: service_params }
put :test, params: project_params(service: service_params)
expect(json_response['message']).to eq "Validations failed."
expect(json_response['message']).to eq 'Validations failed.'
expect(json_response['service_response']).to include "Url can't be blank"
expect(response).to have_gitlab_http_status(200)
expect(response).to be_successful
end
end
@ -47,9 +47,9 @@ describe Projects::ServicesController do
it 'returns success' do
allow_any_instance_of(MicrosoftTeams::Notifier).to receive(:ping).and_return(true)
put :test, params: { namespace_id: project.namespace, project_id: project, id: service.to_param }
put :test, params: project_params
expect(response.status).to eq(200)
expect(response).to be_successful
end
end
@ -57,11 +57,11 @@ describe Projects::ServicesController do
stub_request(:get, 'http://example.com/rest/api/2/serverInfo')
.to_return(status: 200, body: '{}')
expect(Gitlab::HTTP).to receive(:get).with("/rest/api/2/serverInfo", any_args).and_call_original
expect(Gitlab::HTTP).to receive(:get).with('/rest/api/2/serverInfo', any_args).and_call_original
put :test, params: { namespace_id: project.namespace, project_id: project, id: service.to_param, service: service_params }
put :test, params: project_params(service: service_params)
expect(response.status).to eq(200)
expect(response).to be_successful
end
end
@ -69,14 +69,23 @@ describe Projects::ServicesController do
stub_request(:get, 'http://example.com/rest/api/2/serverInfo')
.to_return(status: 200, body: '{}')
expect(Gitlab::HTTP).to receive(:get).with("/rest/api/2/serverInfo", any_args).and_call_original
expect(Gitlab::HTTP).to receive(:get).with('/rest/api/2/serverInfo', any_args).and_call_original
put :test, params: { namespace_id: project.namespace, project_id: project, id: service.to_param, service: service_params }
put :test, params: project_params(service: service_params)
expect(response.status).to eq(200)
expect(response).to be_successful
end
context 'when service is configured for the first time' do
let(:service_params) do
{
'active' => '1',
'push_events' => '1',
'token' => 'token',
'project_url' => 'http://test.com'
}
end
before do
allow_any_instance_of(ServiceHook).to receive(:execute).and_return(true)
end
@ -84,7 +93,7 @@ describe Projects::ServicesController do
it 'persist the object' do
do_put
expect(response).to have_gitlab_http_status(200)
expect(response).to be_successful
expect(json_response).to be_empty
expect(BuildkiteService.first).to be_present
end
@ -92,18 +101,14 @@ describe Projects::ServicesController do
it 'creates the ServiceHook object' do
do_put
expect(response).to have_gitlab_http_status(200)
expect(response).to be_successful
expect(json_response).to be_empty
expect(BuildkiteService.first.service_hook).to be_present
end
def do_put
put :test, params: {
namespace_id: project.namespace,
project_id: project,
id: 'buildkite',
service: { 'active' => '1', 'push_events' => '1', token: 'token', 'project_url' => 'http://test.com' }
}
put :test, params: project_params(id: 'buildkite',
service: service_params)
end
end
end
@ -113,9 +118,9 @@ describe Projects::ServicesController do
stub_request(:get, 'http://example.com/rest/api/2/serverInfo')
.to_return(status: 404)
put :test, params: { namespace_id: project.namespace, project_id: project, id: service.to_param, service: service_params }
put :test, params: project_params(service: service_params)
expect(response).to have_gitlab_http_status(200)
expect(response).to be_successful
expect(json_response).to eq(
'error' => true,
'message' => 'Test failed.',
@ -127,39 +132,70 @@ describe Projects::ServicesController do
end
describe 'PUT #update' do
describe 'as HTML' do
let(:service_params) { { active: true } }
before do
put :update, params: project_params(service: service_params)
end
context 'when param `active` is set to true' do
it 'activates the service and redirects to integrations paths' do
put :update,
params: { namespace_id: project.namespace, project_id: project, id: service.to_param, service: { active: true } }
expect(response).to redirect_to(project_settings_integrations_path(project))
expect(flash[:notice]).to eq 'Jira activated.'
end
end
context 'when param `active` is set to false' do
it 'does not activate the service but saves the settings' do
put :update,
params: { namespace_id: project.namespace, project_id: project, id: service.to_param, service: { active: false } }
let(:service_params) { { active: false } }
it 'does not activate the service but saves the settings' do
expect(flash[:notice]).to eq 'Jira settings saved, but not activated.'
end
end
context 'when activating Jira service from a template' do
let(:template_service) { create(:jira_service, project: project, template: true) }
let(:service) do
create(:jira_service, project: project, template: true)
end
it 'activate Jira service from template' do
put :update, params: { namespace_id: project.namespace, project_id: project, id: service.to_param, service: { active: true } }
expect(flash[:notice]).to eq 'Jira activated.'
end
end
end
describe "GET #edit" do
describe 'as JSON' do
before do
get :edit, params: { namespace_id: project.namespace, project_id: project, id: 'jira' }
put :update, params: project_params(service: service_params, format: :json)
end
context 'when update succeeds' do
let(:service_params) { { url: 'http://example.com' } }
it 'returns JSON response with no errors' do
expect(response).to be_successful
expect(json_response).to include('active' => true, 'errors' => {})
end
end
context 'when update fails' do
let(:service_params) { { url: '' } }
it 'returns JSON response with errors' do
expect(response).to have_gitlab_http_status(:unprocessable_entity)
expect(json_response).to include(
'active' => true,
'errors' => { 'url' => ['must be a valid URL', %{can't be blank}] }
)
end
end
end
end
describe 'GET #edit' do
before do
get :edit, params: project_params(id: 'jira')
end
context 'with approved services' do
@ -168,4 +204,14 @@ describe Projects::ServicesController do
end
end
end
private
def project_params(opts = {})
opts.reverse_merge(
namespace_id: project.namespace,
project_id: project,
id: service.to_param
)
end
end