From b75ce7f77de71c7d15698597813d89792e5908c8 Mon Sep 17 00:00:00 2001 From: Andrei Subbota Date: Thu, 25 Apr 2024 07:39:46 +0200 Subject: [PATCH] Allow DELETE to have a params schema definition (#923) --- CHANGELOG.md | 1 + lib/grape-swagger/doc_methods/move_params.rb | 2 +- ...chema_definition_for_delete_action_spec.rb | 55 +++++++++++++++++++ spec/lib/move_params_spec.rb | 4 +- spec/support/mock_parser.rb | 2 + 5 files changed, 61 insertions(+), 3 deletions(-) create mode 100644 spec/issues/923_params_schema_definition_for_delete_action_spec.rb diff --git a/CHANGELOG.md b/CHANGELOG.md index fea7785c..56b29ae9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ * Your contribution here. * [#922](https://github.com/ruby-grape/grape-swagger/pull/922): Force request body to be an schema object - [@numbata](https://github.com/numbata) +* [#923](https://github.com/ruby-grape/grape-swagger/pull/923): Enabled schema definitions for body parameters in DELETE requests - [@numbata](https://github.com/numbata) ### 2.0.2 (Februar 2, 2024) diff --git a/lib/grape-swagger/doc_methods/move_params.rb b/lib/grape-swagger/doc_methods/move_params.rb index 26510869..7329b46c 100644 --- a/lib/grape-swagger/doc_methods/move_params.rb +++ b/lib/grape-swagger/doc_methods/move_params.rb @@ -186,7 +186,7 @@ def deletable?(param) end def move_methods - [:post, :put, :patch, 'POST', 'PUT', 'PATCH'] + [:delete, :post, :put, :patch, 'DELETE', 'POST', 'PUT', 'PATCH'] end def includes_body_param?(params) diff --git a/spec/issues/923_params_schema_definition_for_delete_action_spec.rb b/spec/issues/923_params_schema_definition_for_delete_action_spec.rb new file mode 100644 index 00000000..a2a228be --- /dev/null +++ b/spec/issues/923_params_schema_definition_for_delete_action_spec.rb @@ -0,0 +1,55 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe '#923 Body params for DELETE action' do + let(:app) do + Class.new(Grape::API) do + params do + requires :post_id, type: Integer + requires :query, type: String, documentation: { type: 'string', param_type: 'body' } + end + delete '/posts/:post_id/comments' do + { 'declared_params' => declared(params) } + end + add_swagger_documentation format: :json + end + end + + describe 'retrieves the documentation for delete parameters as a schema defintion' do + subject do + get '/swagger_doc' + JSON.parse(last_response.body) + end + + specify do + expect(subject['paths']['/posts/{post_id}/comments']['delete']['parameters']).to match( + [ + { + 'format' => 'int32', + 'in' => 'path', + 'name' => 'post_id', + 'type' => 'integer', + 'required' => true + }, + { + 'name' => 'deletePostsPostIdComments', + 'in' => 'body', + 'required' => true, + 'schema' => { '$ref' => '#/definitions/deletePostsPostIdComments' } + } + ] + ) + + expect(subject['definitions']['deletePostsPostIdComments']).to match( + 'type' => 'object', + 'properties' => { + 'query' => { + 'type' => 'string' + } + }, + 'required' => ['query'] + ) + end + end +end diff --git a/spec/lib/move_params_spec.rb b/spec/lib/move_params_spec.rb index c513e90e..bd294e45 100644 --- a/spec/lib/move_params_spec.rb +++ b/spec/lib/move_params_spec.rb @@ -30,11 +30,11 @@ end let(:allowed_verbs) do - [:post, :put, :patch, 'POST', 'PUT', 'PATCH'] + [:post, :put, :patch, :delete, 'POST', 'PUT', 'PATCH', 'DELETE'] end let(:not_allowed_verbs) do - [:get, :delete, 'GET', 'DELETE'] + [:get, 'GET'] end describe 'movable params' do diff --git a/spec/support/mock_parser.rb b/spec/support/mock_parser.rb index d9a78961..6877df0a 100644 --- a/spec/support/mock_parser.rb +++ b/spec/support/mock_parser.rb @@ -1,5 +1,7 @@ # frozen_string_literal: true +require 'ostruct' + module GrapeSwagger class MockParser attr_reader :model, :endpoint