Skip to content

Commit

Permalink
issue #584: do not mutate route.path (#585)
Browse files Browse the repository at this point in the history
- adds changelog entry
  • Loading branch information
peter scholz authored Feb 27, 2017
1 parent 6fc47e0 commit 26e6d93
Show file tree
Hide file tree
Showing 9 changed files with 37 additions and 33 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
#### Fixes

* [#580](https://github.com/ruby-grape/grape-swagger/pull/580): Issue #578: fixes duplicated path params - [@LeFnord](https://github.com/LeFnord).
* [#585](https://github.com/ruby-grape/grape-swagger/pull/585): Issue #584: do not mutate route.path - [@LeFnord](https://github.com/LeFnord).

* Your contribution here.

Expand Down
8 changes: 4 additions & 4 deletions lib/grape-swagger/doc_methods/move_params.rb
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,15 @@ def can_be_moved?(params, http_verb)
move_methods.include?(http_verb) && includes_body_param?(params)
end

def to_definition(params, route, definitions)
def to_definition(path, params, route, definitions)
@definitions = definitions
unify!(params)

params_to_move = movable_params(params)

return (params + correct_array_param(params_to_move)) if should_correct_array?(params_to_move)

params << parent_definition_of_params(params_to_move, route)
params << parent_definition_of_params(params_to_move, path, route)

params
end
Expand All @@ -33,8 +33,8 @@ def correct_array_param(param)
param
end

def parent_definition_of_params(params, route)
definition_name = OperationId.manipulate(parse_model(route.path))
def parent_definition_of_params(params, path, route)
definition_name = OperationId.manipulate(parse_model(path))
referenced_definition = build_definition(definition_name, params, route.request_method.downcase)
definition = @definitions[referenced_definition]

Expand Down
8 changes: 2 additions & 6 deletions lib/grape-swagger/doc_methods/operation_id.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,12 @@ class OperationId
class << self
def build(route, path = nil)
if route.options[:nickname]
operation_id = route.options[:nickname]
route.options[:nickname]
else
verb = route.request_method.to_s.downcase

operation = manipulate(path) unless path.nil?

operation_id = "#{verb}#{operation}"
"#{verb}#{operation}"
end

operation_id
end

def manipulate(path)
Expand Down
4 changes: 1 addition & 3 deletions lib/grape-swagger/doc_methods/parse_params.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,8 @@ module GrapeSwagger
module DocMethods
class ParseParams
class << self
def call(param, settings, route, definitions)
path = route.path
def call(param, settings, path, route, definitions)
method = route.request_method

additional_documentation = settings.fetch(:documentation, {})
settings.merge!(additional_documentation)
data_type = DataType.call(settings)
Expand Down
2 changes: 1 addition & 1 deletion lib/grape-swagger/doc_methods/path_string.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ module DocMethods
class PathString
class << self
def build(route, options = {})
path = route.path
path = route.path.dup
# always removing format
path.sub!(/\(\.\w+?\)$/, '')
path.sub!('(.:format)', '')
Expand Down
14 changes: 7 additions & 7 deletions lib/grape-swagger/endpoint.rb
Original file line number Diff line number Diff line change
Expand Up @@ -108,10 +108,10 @@ def method_object(route, options, path)
method[:description] = description_object(route)
method[:produces] = produces_object(route, options[:produces] || options[:format])
method[:consumes] = consumes_object(route, options[:format])
method[:parameters] = params_object(route)
method[:parameters] = params_object(route, path)
method[:security] = security_object(route)
method[:responses] = response_object(route)
method[:tags] = route.options.fetch(:tags, tag_object(route))
method[:tags] = route.options.fetch(:tags, tag_object(route, path))
method[:operationId] = GrapeSwagger::DocMethods::OperationId.build(route, path)
method.delete_if { |_, value| value.blank? }

Expand Down Expand Up @@ -161,7 +161,7 @@ def consumes_object(route, format)
mime_types
end

def params_object(route)
def params_object(route, path)
parameters = partition_params(route).map do |param, value|
value = { required: false }.merge(value) if value.is_a?(Hash)
_, value = default_type([[param, value]]).first if value == ''
Expand All @@ -170,11 +170,11 @@ def params_object(route)
elsif value[:documentation]
expose_params(value[:documentation][:type])
end
GrapeSwagger::DocMethods::ParseParams.call(param, value, route, @definitions)
GrapeSwagger::DocMethods::ParseParams.call(param, value, path, route, @definitions)
end

if GrapeSwagger::DocMethods::MoveParams.can_be_moved?(parameters, route.request_method)
parameters = GrapeSwagger::DocMethods::MoveParams.to_definition(parameters, route, @definitions)
parameters = GrapeSwagger::DocMethods::MoveParams.to_definition(path, parameters, route, @definitions)
end

parameters
Expand Down Expand Up @@ -227,11 +227,11 @@ def apply_success_codes(route)
[default_code]
end

def tag_object(route)
def tag_object(route, path)
version = GrapeSwagger::DocMethods::Version.get(route)
version = [version] unless version.is_a?(Array)
Array(
route.path.split('{')[0].split('/').reject(&:empty?).delete_if do |i|
path.split('{')[0].split('/').reject(&:empty?).delete_if do |i|
i == route.prefix.to_s || version.map(&:to_s).include?(i)
end.first
)
Expand Down
11 changes: 6 additions & 5 deletions spec/lib/move_params_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -91,18 +91,19 @@
end

describe 'parent_definition_of_params' do
let(:path) { '/in_body' }
describe 'POST' do
let(:params) { paths['/in_body'][:post][:parameters] }
let(:params) { paths[path][:post][:parameters] }
let(:options) do
{
method: 'POST'
}
end
let(:env) { Rack::MockRequest.env_for('/in_body', options) }
let(:env) { Rack::MockRequest.env_for(path, options) }
let(:request) { Grape::Request.new(env) }

specify do
subject.to_definition(params, request, definitions)
subject.to_definition(path, params, request, definitions)
expect(params).to eql(
[
{ name: 'InBody', in: 'body', required: true, schema: { '$ref' => '#/definitions/postInBody' } }
Expand All @@ -120,11 +121,11 @@
method: 'PUT'
}
end
let(:env) { Rack::MockRequest.env_for('/in_body', options) }
let(:env) { Rack::MockRequest.env_for(path, options) }
let(:request) { Grape::Request.new(env) }

specify do
subject.to_definition(params, request, definitions)
subject.to_definition(path, params, request, definitions)
expect(params).to eql(
[
{ in: 'path', name: 'key', description: nil, type: 'integer', format: 'int32', required: true },
Expand Down
9 changes: 8 additions & 1 deletion spec/lib/path_string_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,14 @@
specify { expect(subject).to eql GrapeSwagger::DocMethods::PathString }
specify { expect(subject).to respond_to :build }

describe 'operation_id_object' do
describe 'path_string_object' do
specify 'The original route path is not mutated' do
route = Struct.new(:version, :path).new
route.path = '/foo/:dynamic/bar'
subject.build(route, add_version: true)
expect(route.path).to eq '/foo/:dynamic/bar'
end

describe 'version' do
describe 'defaults: given, true' do
let(:options) { { add_version: true } }
Expand Down
13 changes: 7 additions & 6 deletions spec/lib/tag_name_description_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,12 @@
end

describe '#build' do
subject { described_class.build(paths) }
let(:object) { described_class.build(paths) }

describe 'empty paths' do
let(:paths) { {} }
specify do
expect(subject).to eql([])
expect(object).to eql([])
end
end

Expand All @@ -30,7 +31,7 @@
end

specify do
expect(subject).to eql [{ name: 'tags_given', description: 'Operations about tags_givens' }]
expect(object).to eql [{ name: 'tags_given', description: 'Operations about tags_givens' }]
end
end

Expand All @@ -40,7 +41,7 @@
end

specify do
expect(subject).to eql [{ name: 'tags_given', description: 'Operations about tags_givens' }]
expect(object).to eql [{ name: 'tags_given', description: 'Operations about tags_givens' }]
end
end

Expand All @@ -53,7 +54,7 @@
end

specify do
expect(subject).to eql [
expect(object).to eql [
{ name: 'tags_given', description: 'Operations about tags_givens' },
{ name: 'another_tag_given', description: 'Operations about another_tag_givens' }
]
Expand All @@ -68,7 +69,7 @@
end

specify do
expect(subject).to eql [{ name: 'tags_given', description: 'Operations about tags_givens' }]
expect(object).to eql [{ name: 'tags_given', description: 'Operations about tags_givens' }]
end
end
end
Expand Down

0 comments on commit 26e6d93

Please sign in to comment.