Commit 722ac5cb authored by Rémy Coutable's avatar Rémy Coutable

Merge branch 'grapify-labels-api' into 'master'

Grapify the labels API

Add the Grape-DSL to the labels API. Since the input validation messages are checked, two tests are modified slightly.

## What are the relevant issue numbers?

Related to #22928

See merge request !7070
parents 64556712 21666dbe
...@@ -3,37 +3,32 @@ module API ...@@ -3,37 +3,32 @@ module API
class Labels < Grape::API class Labels < Grape::API
before { authenticate! } before { authenticate! }
params do
requires :id, type: String, desc: 'The ID of a project'
end
resource :projects do resource :projects do
# Get all labels of the project desc 'Get all labels of the project' do
# success Entities::Label
# Parameters: end
# id (required) - The ID of a project
# Example Request:
# GET /projects/:id/labels
get ':id/labels' do get ':id/labels' do
present available_labels, with: Entities::Label, current_user: current_user present available_labels, with: Entities::Label, current_user: current_user
end end
# Creates a new label desc 'Create a new label' do
# success Entities::Label
# Parameters: end
# id (required) - The ID of a project params do
# name (required) - The name of the label to be created requires :name, type: String, desc: 'The name of the label to be created'
# color (required) - Color of the label given in 6-digit hex requires :color, type: String, desc: "The color of the label given in 6-digit hex notation with leading '#' sign (e.g. #FFAABB)"
# notation with leading '#' sign (e.g. #FFAABB) optional :description, type: String, desc: 'The description of label to be created'
# description (optional) - The description of label to be created end
# Example Request:
# POST /projects/:id/labels
post ':id/labels' do post ':id/labels' do
authorize! :admin_label, user_project authorize! :admin_label, user_project
required_attributes! [:name, :color]
attrs = attributes_for_keys [:name, :color, :description]
label = user_project.find_label(attrs[:name])
label = user_project.find_label(params[:name])
conflict!('Label already exists') if label conflict!('Label already exists') if label
label = user_project.labels.create(attrs) label = user_project.labels.create(declared(params, include_parent_namespaces: false).to_h)
if label.valid? if label.valid?
present label, with: Entities::Label, current_user: current_user present label, with: Entities::Label, current_user: current_user
...@@ -42,54 +37,44 @@ module API ...@@ -42,54 +37,44 @@ module API
end end
end end
# Deletes an existing label desc 'Delete an existing label' do
# success Entities::Label
# Parameters: end
# id (required) - The ID of a project params do
# name (required) - The name of the label to be deleted requires :name, type: String, desc: 'The name of the label to be deleted'
# end
# Example Request:
# DELETE /projects/:id/labels
delete ':id/labels' do delete ':id/labels' do
authorize! :admin_label, user_project authorize! :admin_label, user_project
required_attributes! [:name]
label = user_project.find_label(params[:name]) label = user_project.find_label(params[:name])
not_found!('Label') unless label not_found!('Label') unless label
label.destroy present label.destroy, with: Entities::Label, current_user: current_user
end end
# Updates an existing label. At least one optional parameter is required. desc 'Update an existing label. At least one optional parameter is required.' do
# success Entities::Label
# Parameters: end
# id (required) - The ID of a project params do
# name (required) - The name of the label to be deleted requires :name, type: String, desc: 'The name of the label to be updated'
# new_name (optional) - The new name of the label optional :new_name, type: String, desc: 'The new name of the label'
# color (optional) - Color of the label given in 6-digit hex optional :color, type: String, desc: "The new color of the label given in 6-digit hex notation with leading '#' sign (e.g. #FFAABB)"
# notation with leading '#' sign (e.g. #FFAABB) optional :description, type: String, desc: 'The new description of label'
# description (optional) - The description of label to be created at_least_one_of :new_name, :color, :description
# Example Request: end
# PUT /projects/:id/labels
put ':id/labels' do put ':id/labels' do
authorize! :admin_label, user_project authorize! :admin_label, user_project
required_attributes! [:name]
label = user_project.find_label(params[:name]) label = user_project.find_label(params[:name])
not_found!('Label not found') unless label not_found!('Label not found') unless label
attrs = attributes_for_keys [:new_name, :color, :description] update_params = declared(params,
include_parent_namespaces: false,
if attrs.empty? include_missing: false).to_h
render_api_error!('Required parameters "new_name" or "color" ' \
'missing',
400)
end
# Rename new name to the actual label attribute name # Rename new name to the actual label attribute name
attrs[:name] = attrs.delete(:new_name) if attrs.key?(:new_name) update_params['name'] = update_params.delete('new_name') if update_params.key?('new_name')
if label.update(attrs) if label.update(update_params)
present label, with: Entities::Label, current_user: current_user present label, with: Entities::Label, current_user: current_user
else else
render_validation_error!(label) render_validation_error!(label)
......
...@@ -159,14 +159,14 @@ describe API::API, api: true do ...@@ -159,14 +159,14 @@ describe API::API, api: true do
it 'returns 400 if no label name given' do it 'returns 400 if no label name given' do
put api("/projects/#{project.id}/labels", user), new_name: 'label2' put api("/projects/#{project.id}/labels", user), new_name: 'label2'
expect(response).to have_http_status(400) expect(response).to have_http_status(400)
expect(json_response['message']).to eq('400 (Bad request) "name" not given') expect(json_response['error']).to eq('name is missing')
end end
it 'returns 400 if no new parameters given' do it 'returns 400 if no new parameters given' do
put api("/projects/#{project.id}/labels", user), name: 'label1' put api("/projects/#{project.id}/labels", user), name: 'label1'
expect(response).to have_http_status(400) expect(response).to have_http_status(400)
expect(json_response['message']).to eq('Required parameters '\ expect(json_response['error']).to eq('new_name, color, description are missing, '\
'"new_name" or "color" missing') 'at least one parameter must be provided')
end end
it 'returns 400 for invalid name' do it 'returns 400 for invalid name' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment