2015-11-04 20:03:42 +08:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe 'Group Params as Array' do
|
2016-10-14 05:06:03 +08:00
|
|
|
include_context "#{MODEL_PARSER} swagger example"
|
|
|
|
|
2015-11-04 20:03:42 +08:00
|
|
|
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-07-07 23:44:07 +08:00
|
|
|
# as body parameters it would be interpreted a bit different,
|
|
|
|
# cause it could not be distinguished anymore, so this would be translated to one array,
|
|
|
|
# see also next example for the difference
|
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
|
|
|
|
|
2016-07-07 23:44:07 +08:00
|
|
|
params do
|
2016-07-11 02:52:00 +08:00
|
|
|
requires :array_of_string, type: Array[String], documentation: { param_type: 'body', desc: 'array of strings' }
|
|
|
|
requires :integer_value, type: Integer, documentation: { param_type: 'body', desc: 'integer value' }
|
2016-07-07 23:44:07 +08:00
|
|
|
end
|
|
|
|
|
2016-07-11 02:52:00 +08:00
|
|
|
post '/object_and_array' do
|
2016-07-07 23:44:07 +08:00
|
|
|
{ 'declared_params' => declared(params) }
|
|
|
|
end
|
|
|
|
|
2016-06-16 19:35:29 +08:00
|
|
|
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
|
|
|
|
|
2016-10-14 05:06:03 +08:00
|
|
|
params do
|
|
|
|
requires :array_of_entities, type: Array[Entities::ApiError]
|
|
|
|
end
|
|
|
|
|
|
|
|
post '/array_of_entities' 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-07-04 23:42:28 +08:00
|
|
|
{ 'in' => 'formData', 'name' => 'typed_group[id]', 'description' => 'integer given', 'type' => 'array', 'items' => { 'type' => 'integer', 'format' => 'int32' }, 'required' => true },
|
|
|
|
{ 'in' => 'formData', 'name' => 'typed_group[name]', 'description' => 'string given', 'type' => 'array', 'items' => { 'type' => 'string' }, 'required' => true },
|
|
|
|
{ 'in' => 'formData', 'name' => 'typed_group[email]', 'description' => 'email given', 'type' => 'array', 'items' => { 'type' => 'string' }, 'required' => false },
|
|
|
|
{ 'in' => 'formData', 'name' => 'typed_group[others]', 'type' => 'array', 'items' => { 'type' => 'integer', 'format' => 'int32' }, 'enum' => [1, 2, 3], 'required' => false }
|
2016-06-16 19:35:29 +08:00
|
|
|
]
|
|
|
|
)
|
|
|
|
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
|
2016-07-07 23:44:07 +08:00
|
|
|
expect(subject['definitions']['postArrayOfType']['type']).to eql 'array'
|
2016-07-11 02:52:00 +08:00
|
|
|
expect(subject['definitions']['postArrayOfType']['items']).to eql(
|
|
|
|
'type' => 'object',
|
|
|
|
'properties' => {
|
|
|
|
'array_of_string' => {
|
|
|
|
'type' => 'string', 'description' => 'nested array of strings'
|
|
|
|
},
|
|
|
|
'array_of_integer' => {
|
|
|
|
'type' => 'integer', 'format' => 'int32', 'description' => 'nested array of integers'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
'required' => %w(array_of_string array_of_integer)
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'documentation for simple and array parameters' do
|
|
|
|
subject do
|
|
|
|
get '/swagger_doc/object_and_array'
|
|
|
|
JSON.parse(last_response.body)
|
|
|
|
end
|
|
|
|
|
|
|
|
specify do
|
|
|
|
expect(subject['definitions']['postObjectAndArray']['type']).to eql 'object'
|
|
|
|
expect(subject['definitions']['postObjectAndArray']['properties']).to eql(
|
2016-06-16 19:35:29 +08:00
|
|
|
'array_of_string' => {
|
2016-07-21 19:15:36 +08:00
|
|
|
'type' => 'array',
|
|
|
|
'description' => 'array of strings',
|
|
|
|
'items' => {
|
|
|
|
'type' => 'string'
|
2016-07-11 02:52:00 +08:00
|
|
|
}
|
2016-06-16 19:35:29 +08:00
|
|
|
},
|
2016-07-11 02:52:00 +08:00
|
|
|
'integer_value' => {
|
|
|
|
'type' => 'integer', 'format' => 'int32', 'description' => 'integer value'
|
2016-06-16 19:35:29 +08:00
|
|
|
}
|
|
|
|
)
|
|
|
|
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 },
|
2016-07-04 23:42:28 +08:00
|
|
|
{ 'in' => 'formData', 'name' => 'array_of_integer', 'type' => 'array', 'items' => { 'type' => 'integer', 'format' => 'int32' }, 'required' => true }
|
2016-05-11 04:01:13 +08:00
|
|
|
]
|
|
|
|
)
|
2015-12-19 01:40:53 +08:00
|
|
|
end
|
|
|
|
end
|
2016-10-14 05:06:03 +08:00
|
|
|
|
|
|
|
describe 'documentation for entity array parameters' do
|
|
|
|
let(:parameters) do
|
|
|
|
[
|
|
|
|
{
|
|
|
|
'in' => 'formData',
|
|
|
|
'name' => 'array_of_entities',
|
|
|
|
'type' => 'array',
|
|
|
|
'items' => {
|
|
|
|
'$ref' => '#/definitions/ApiError'
|
|
|
|
},
|
|
|
|
'required' => true
|
|
|
|
}
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
subject do
|
|
|
|
get '/swagger_doc/array_of_entities'
|
|
|
|
JSON.parse(last_response.body)
|
|
|
|
end
|
|
|
|
|
|
|
|
specify do
|
|
|
|
expect(subject['definitions']['ApiError']).not_to be_blank
|
|
|
|
expect(subject['paths']['/array_of_entities']['post']['parameters']).to eql(parameters)
|
|
|
|
end
|
|
|
|
end
|
2015-11-04 20:03:42 +08:00
|
|
|
end
|