rspec-openapi 0.18.0 → 0.18.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.rubocop_todo.yml +5 -5
- data/lib/rspec/openapi/extractors/hanami.rb +7 -10
- data/lib/rspec/openapi/extractors/rails.rb +6 -21
- data/lib/rspec/openapi/extractors.rb +7 -0
- data/lib/rspec/openapi/version.rb +1 -1
- metadata +3 -3
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: e9d5e7e261220ae8c790eff0702c0d5e08dbf53667a410a1a540bdb4557d5f55
         | 
| 4 | 
            +
              data.tar.gz: ffd9b3d5cab09166652fb03d1a22cf774170c6e80690ed4215e3483b951d8f73
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 007a4e0466e55fa656667eb498a0f27cd3b049dc8fb2d3a2b46b1b511fbe0f28fab3a79282577b0c5db08a55301576e8104013854fdf400884ab58d3312fba04
         | 
| 7 | 
            +
              data.tar.gz: 39f0f78cfe88df09e7b16c540dc95890ac712feb7700df6f18101e5355540f21881f2905652c808422065f9330abfdd0c8f1037342192e5ee0b643fc71b65713
         | 
    
        data/.rubocop_todo.yml
    CHANGED
    
    | @@ -1,15 +1,15 @@ | |
| 1 1 | 
             
            # This configuration was generated by
         | 
| 2 2 | 
             
            # `rubocop --auto-gen-config`
         | 
| 3 | 
            -
            # on 2024-04- | 
| 3 | 
            +
            # on 2024-04-20 21:25:22 UTC using RuboCop version 1.62.1.
         | 
| 4 4 | 
             
            # The point is for the user to remove these configuration records
         | 
| 5 5 | 
             
            # one by one as the offenses are removed from the code base.
         | 
| 6 6 | 
             
            # Note that changes in the inspected code, or installation of new
         | 
| 7 7 | 
             
            # versions of RuboCop, may require this file to be generated again.
         | 
| 8 8 |  | 
| 9 | 
            -
            # Offense count:  | 
| 9 | 
            +
            # Offense count: 14
         | 
| 10 10 | 
             
            # Configuration parameters: AllowedMethods, AllowedPatterns, CountRepeatedAttributes.
         | 
| 11 11 | 
             
            Metrics/AbcSize:
         | 
| 12 | 
            -
              Max:  | 
| 12 | 
            +
              Max: 46
         | 
| 13 13 |  | 
| 14 14 | 
             
            # Offense count: 1
         | 
| 15 15 | 
             
            # Configuration parameters: CountComments, CountAsOne.
         | 
| @@ -19,7 +19,7 @@ Metrics/ClassLength: | |
| 19 19 | 
             
            # Offense count: 9
         | 
| 20 20 | 
             
            # Configuration parameters: AllowedMethods, AllowedPatterns.
         | 
| 21 21 | 
             
            Metrics/CyclomaticComplexity:
         | 
| 22 | 
            -
              Max:  | 
| 22 | 
            +
              Max: 13
         | 
| 23 23 |  | 
| 24 24 | 
             
            # Offense count: 22
         | 
| 25 25 | 
             
            # Configuration parameters: CountComments, CountAsOne, AllowedMethods, AllowedPatterns.
         | 
| @@ -29,7 +29,7 @@ Metrics/MethodLength: | |
| 29 29 | 
             
            # Offense count: 5
         | 
| 30 30 | 
             
            # Configuration parameters: AllowedMethods, AllowedPatterns.
         | 
| 31 31 | 
             
            Metrics/PerceivedComplexity:
         | 
| 32 | 
            -
              Max:  | 
| 32 | 
            +
              Max: 13
         | 
| 33 33 |  | 
| 34 34 | 
             
            # Offense count: 1
         | 
| 35 35 | 
             
            # Configuration parameters: EnforcedStyle, CheckMethodNames, CheckSymbols, AllowedIdentifiers, AllowedPatterns.
         | 
| @@ -19,7 +19,10 @@ class Inspector | |
| 19 19 | 
             
              def call(verb, path)
         | 
| 20 20 | 
             
                route = routes.find { |r| r.http_method == verb && r.path == path }
         | 
| 21 21 |  | 
| 22 | 
            -
                if route. | 
| 22 | 
            +
                if route.nil?
         | 
| 23 | 
            +
                  # FIXME: This is a hack to pass `/sites/***` in testing
         | 
| 24 | 
            +
                  {}
         | 
| 25 | 
            +
                elsif route.to.is_a?(Proc)
         | 
| 23 26 | 
             
                  {
         | 
| 24 27 | 
             
                    tags: [],
         | 
| 25 28 | 
             
                    summary: "#{verb} #{path}",
         | 
| @@ -66,7 +69,7 @@ class << RSpec::OpenAPI::Extractors::Hanami = Object.new | |
| 66 69 | 
             
                deprecated = metadata[:deprecated]
         | 
| 67 70 | 
             
                path = request.path
         | 
| 68 71 |  | 
| 69 | 
            -
                raw_path_params = route.params.filter { |_key, value| number_or_nil(value) }
         | 
| 72 | 
            +
                raw_path_params = route.params.filter { |_key, value| RSpec::OpenAPI::Extractors.number_or_nil(value) }
         | 
| 70 73 |  | 
| 71 74 | 
             
                result = InspectorAnalyzer.call(request.method, add_id(path, route))
         | 
| 72 75 |  | 
| @@ -92,7 +95,7 @@ class << RSpec::OpenAPI::Extractors::Hanami = Object.new | |
| 92 95 | 
             
                return path if route.params.empty?
         | 
| 93 96 |  | 
| 94 97 | 
             
                route.params.each_pair do |key, value|
         | 
| 95 | 
            -
                  next unless number_or_nil(value)
         | 
| 98 | 
            +
                  next unless RSpec::OpenAPI::Extractors.number_or_nil(value)
         | 
| 96 99 |  | 
| 97 100 | 
             
                  path = path.sub("/#{value}", "/:#{key}")
         | 
| 98 101 | 
             
                end
         | 
| @@ -104,17 +107,11 @@ class << RSpec::OpenAPI::Extractors::Hanami = Object.new | |
| 104 107 | 
             
                return path if route.params.empty?
         | 
| 105 108 |  | 
| 106 109 | 
             
                route.params.each_pair do |key, value|
         | 
| 107 | 
            -
                  next unless number_or_nil(value)
         | 
| 110 | 
            +
                  next unless RSpec::OpenAPI::Extractors.number_or_nil(value)
         | 
| 108 111 |  | 
| 109 112 | 
             
                  path = path.sub("/#{value}", "/{#{key}}")
         | 
| 110 113 | 
             
                end
         | 
| 111 114 |  | 
| 112 115 | 
             
                path
         | 
| 113 116 | 
             
              end
         | 
| 114 | 
            -
             | 
| 115 | 
            -
              def number_or_nil(string)
         | 
| 116 | 
            -
                Integer(string || '')
         | 
| 117 | 
            -
              rescue ArgumentError
         | 
| 118 | 
            -
                nil
         | 
| 119 | 
            -
              end
         | 
| 120 117 | 
             
            end
         | 
| @@ -44,38 +44,23 @@ class << RSpec::OpenAPI::Extractors::Rails = Object.new | |
| 44 44 |  | 
| 45 45 | 
             
              # @param [ActionDispatch::Request] request
         | 
| 46 46 | 
             
              def find_rails_route(request, app: Rails.application, path_prefix: '')
         | 
| 47 | 
            -
                app.routes.router.recognize(request) do |route,  | 
| 47 | 
            +
                app.routes.router.recognize(request) do |route, _parameters|
         | 
| 48 48 | 
             
                  path = route.path.spec.to_s.delete_suffix('(.:format)')
         | 
| 49 49 |  | 
| 50 50 | 
             
                  if route.app.matches?(request)
         | 
| 51 51 | 
             
                    if route.app.engine?
         | 
| 52 52 | 
             
                      route, path = find_rails_route(request, app: route.app.app, path_prefix: path)
         | 
| 53 53 | 
             
                      next if route.nil?
         | 
| 54 | 
            -
                    elsif path_prefix + path == add_id(request.path, parameters)
         | 
| 55 | 
            -
                      return [route, path_prefix + path]
         | 
| 56 | 
            -
                    else
         | 
| 57 | 
            -
                      return [route, nil]
         | 
| 58 54 | 
             
                    end
         | 
| 59 | 
            -
                    return [route, path_prefix + path]
         | 
| 60 | 
            -
                  end
         | 
| 61 | 
            -
                end
         | 
| 62 | 
            -
             | 
| 63 | 
            -
                nil
         | 
| 64 | 
            -
              end
         | 
| 65 55 |  | 
| 66 | 
            -
             | 
| 67 | 
            -
             | 
| 68 | 
            -
             | 
| 56 | 
            +
                    # Params are empty when it is Engine or Rack app.
         | 
| 57 | 
            +
                    # In that case, we can't handle parameters in path.
         | 
| 58 | 
            +
                    return [route, nil] if request.params.empty?
         | 
| 69 59 |  | 
| 70 | 
            -
             | 
| 60 | 
            +
                    return [route, path_prefix + path]
         | 
| 61 | 
            +
                  end
         | 
| 71 62 | 
             
                end
         | 
| 72 63 |  | 
| 73 | 
            -
                path
         | 
| 74 | 
            -
              end
         | 
| 75 | 
            -
             | 
| 76 | 
            -
              def number_or_nil(string)
         | 
| 77 | 
            -
                Integer(string || '')
         | 
| 78 | 
            -
              rescue ArgumentError
         | 
| 79 64 | 
             
                nil
         | 
| 80 65 | 
             
              end
         | 
| 81 66 | 
             
            end
         | 
    
        metadata
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: rspec-openapi
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0.18. | 
| 4 | 
            +
              version: 0.18.2
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Takashi Kokubun
         | 
| @@ -9,7 +9,7 @@ authors: | |
| 9 9 | 
             
            autorequire:
         | 
| 10 10 | 
             
            bindir: exe
         | 
| 11 11 | 
             
            cert_chain: []
         | 
| 12 | 
            -
            date: 2024-04- | 
| 12 | 
            +
            date: 2024-04-22 00:00:00.000000000 Z
         | 
| 13 13 | 
             
            dependencies:
         | 
| 14 14 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 15 15 | 
             
              name: actionpack
         | 
| @@ -109,7 +109,7 @@ licenses: | |
| 109 109 | 
             
            metadata:
         | 
| 110 110 | 
             
              homepage_uri: https://github.com/exoego/rspec-openapi
         | 
| 111 111 | 
             
              source_code_uri: https://github.com/exoego/rspec-openapi
         | 
| 112 | 
            -
              changelog_uri: https://github.com/exoego/rspec-openapi/releases/tag/v0.18. | 
| 112 | 
            +
              changelog_uri: https://github.com/exoego/rspec-openapi/releases/tag/v0.18.2
         | 
| 113 113 | 
             
              rubygems_mfa_required: 'true'
         | 
| 114 114 | 
             
            post_install_message:
         | 
| 115 115 | 
             
            rdoc_options: []
         |