2015-11-04 20:03:42 +08:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe 'Group Params as Array' do
|
|
|
|
def app
|
|
|
|
Class.new(Grape::API) do
|
|
|
|
format :json
|
|
|
|
|
|
|
|
params do
|
|
|
|
requires :required_group, type: Array do
|
|
|
|
requires :required_param_1
|
|
|
|
requires :required_param_2
|
|
|
|
end
|
|
|
|
end
|
|
|
|
post '/groups' do
|
|
|
|
{ 'declared_params' => declared(params) }
|
|
|
|
end
|
|
|
|
|
|
|
|
params do
|
|
|
|
requires :typed_group, type: Array do
|
2016-05-07 03:00:36 +08:00
|
|
|
requires :id, type: Integer, desc: 'integer given'
|
|
|
|
requires :name, type: String, desc: 'string given'
|
|
|
|
optional :email, type: String, desc: 'email given'
|
2015-11-04 20:03:42 +08:00
|
|
|
optional :others, type: Integer, values: [1, 2, 3]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
post '/type_given' do
|
|
|
|
{ 'declared_params' => declared(params) }
|
|
|
|
end
|
|
|
|
|
2016-06-16 19:35:29 +08:00
|
|
|
params do
|
|
|
|
requires :array_of_string, type: Array[String], documentation: { param_type: 'body', desc: 'nested array of strings' }
|
|
|
|
requires :array_of_integer, type: Array[Integer], documentation: { param_type: 'body', desc: 'nested array of integers' }
|
|
|
|
end
|
|
|
|
|
|
|
|
post '/array_of_type' do
|
|
|
|
{ 'declared_params' => declared(params) }
|
|
|
|
end
|
|
|
|
|
|
|
|
params do
|
|
|
|
requires :array_of_string, type: Array[String]
|
|
|
|
requires :array_of_integer, type: Array[Integer]
|
|
|
|
end
|
|
|
|
|
|
|
|
post '/array_of_type_in_form' do
|
|
|
|
{ 'declared_params' => declared(params) }
|
|
|
|
end
|
|
|
|
|
2015-11-04 20:03:42 +08:00
|
|
|
add_swagger_documentation
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-05-07 03:00:36 +08:00
|
|
|
describe 'retrieves the documentation for grouped parameters' do
|
2015-12-19 01:40:53 +08:00
|
|
|
subject do
|
|
|
|
get '/swagger_doc/groups'
|
|
|
|
JSON.parse(last_response.body)
|
|
|
|
end
|
2015-11-04 20:03:42 +08:00
|
|
|
|
2015-12-19 01:40:53 +08:00
|
|
|
specify do
|
2016-05-07 03:00:36 +08:00
|
|
|
expect(subject['paths']['/groups']['post']['parameters']).to eql(
|
|
|
|
[
|
2016-06-16 19:35:29 +08:00
|
|
|
{ 'in' => 'formData', 'name' => 'required_group[required_param_1]', 'required' => true, 'type' => 'array', 'items' => { 'type' => 'string' } },
|
|
|
|
{ 'in' => 'formData', 'name' => 'required_group[required_param_2]', 'required' => true, 'type' => 'array', 'items' => { 'type' => 'string' } }
|
2016-05-11 04:01:13 +08:00
|
|
|
]
|
|
|
|
)
|
2015-12-19 01:40:53 +08:00
|
|
|
end
|
2015-11-04 20:03:42 +08:00
|
|
|
end
|
|
|
|
|
2016-05-07 03:00:36 +08:00
|
|
|
describe 'retrieves the documentation for typed group parameters' do
|
2015-12-19 01:40:53 +08:00
|
|
|
subject do
|
|
|
|
get '/swagger_doc/type_given'
|
|
|
|
JSON.parse(last_response.body)
|
|
|
|
end
|
|
|
|
|
|
|
|
specify do
|
2016-05-07 03:00:36 +08:00
|
|
|
expect(subject['paths']['/type_given']['post']['parameters']).to eql(
|
|
|
|
[
|
2016-06-16 19:35:29 +08:00
|
|
|
{ 'in' => 'formData', 'name' => 'typed_group[id]', 'description' => 'integer given', 'required' => true, 'type' => 'array', 'items' => { 'type' => 'integer' } },
|
|
|
|
{ 'in' => 'formData', 'name' => 'typed_group[name]', 'description' => 'string given', 'required' => true, 'type' => 'array', 'items' => { 'type' => 'string' } },
|
|
|
|
{ 'in' => 'formData', 'name' => 'typed_group[email]', 'description' => 'email given', 'required' => false, 'type' => 'array', 'items' => { 'type' => 'string' } },
|
|
|
|
{ 'in' => 'formData', 'name' => 'typed_group[others]', 'required' => false, 'type' => 'array', 'items' => { 'type' => 'integer' }, 'enum' => [1, 2, 3] }
|
|
|
|
]
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'retrieves the documentation for parameters that are arrays of primitive types' do
|
|
|
|
subject do
|
|
|
|
get '/swagger_doc/array_of_type'
|
|
|
|
JSON.parse(last_response.body)
|
|
|
|
end
|
|
|
|
|
|
|
|
specify do
|
|
|
|
expect(subject['definitions']['postArrayOfType']['properties']).to eql(
|
|
|
|
'array_of_string' => {
|
|
|
|
'type' => 'array', 'items' => { 'type' => 'string' }, 'description' => 'nested array of strings'
|
|
|
|
},
|
|
|
|
'array_of_integer' => {
|
|
|
|
'type' => 'array', 'items' => { 'type' => 'integer' }, 'description' => 'nested array of integers'
|
|
|
|
}
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'retrieves the documentation for typed group parameters' do
|
|
|
|
subject do
|
|
|
|
get '/swagger_doc/array_of_type_in_form'
|
|
|
|
JSON.parse(last_response.body)
|
|
|
|
end
|
|
|
|
|
|
|
|
specify do
|
|
|
|
expect(subject['paths']['/array_of_type_in_form']['post']['parameters']).to eql(
|
|
|
|
[
|
|
|
|
{ 'in' => 'formData', 'name' => 'array_of_string', 'type' => 'array', 'items' => { 'type' => 'string' }, 'required' => true },
|
|
|
|
{ 'in' => 'formData', 'name' => 'array_of_integer', 'type' => 'array', 'items' => { 'type' => 'integer' }, 'required' => true }
|
2016-05-11 04:01:13 +08:00
|
|
|
]
|
|
|
|
)
|
2015-12-19 01:40:53 +08:00
|
|
|
end
|
|
|
|
end
|
2015-11-04 20:03:42 +08:00
|
|
|
end
|