From ceebbd34697fe3a6e74ed96cc5f6d528d84d6532 Mon Sep 17 00:00:00 2001 From: Suzuki Eiji Date: Fri, 26 Apr 2024 14:10:24 +0900 Subject: [PATCH] fix: Use mount_path to narrow down urls_for (#924) --- CHANGELOG.md | 1 + lib/grape-swagger/rake/oapi_tasks.rb | 2 +- spec/lib/oapi_tasks_spec.rb | 14 +++++++++++++- 3 files changed, 15 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 56b29ae9..f3bcaf43 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,6 +9,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) +* [#924](https://github.com/ruby-grape/grape-swagger/pull/924): fix: Use mount_path to narrow down urls_for - [@chibicco](https://github.com/chibicco) ### 2.0.2 (Februar 2, 2024) diff --git a/lib/grape-swagger/rake/oapi_tasks.rb b/lib/grape-swagger/rake/oapi_tasks.rb index 20a35c76..1fe06791 100644 --- a/lib/grape-swagger/rake/oapi_tasks.rb +++ b/lib/grape-swagger/rake/oapi_tasks.rb @@ -95,7 +95,7 @@ def make_request(url) def urls_for(api_class) api_class.routes .map(&:path) - .select { |e| e.include?('doc') } + .grep(/#{GrapeSwagger::DocMethods.class_variable_get(:@@mount_path)}/) .reject { |e| e.include?(':name') } .map { |e| format_path(e) } .map { |e| [e, ENV.fetch('resource', nil)].join('/').chomp('/') } diff --git a/spec/lib/oapi_tasks_spec.rb b/spec/lib/oapi_tasks_spec.rb index 38bdca70..9550be0f 100644 --- a/spec/lib/oapi_tasks_spec.rb +++ b/spec/lib/oapi_tasks_spec.rb @@ -14,6 +14,10 @@ class Item < Grape::API namespace :otherItem do get '/' end + + namespace :my_doc do + get '/' + end end class Base < Grape::API @@ -115,7 +119,7 @@ class Base < Grape::API end it 'returns complete doc' do - expect(response['paths'].length).to eql 2 + expect(response['paths'].length).to eql 3 end end end @@ -132,6 +136,14 @@ class Base < Grape::API end end + describe '#urls_for' do + describe 'match only the path to mount_path' do + it do + expect(subject.send(:urls_for, api_class)).to match_array ['/api/swagger_doc'] + end + end + end + describe '#file' do describe 'no store given' do it 'returns swagger_doc.json' do