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: []
|