opentelemetry-instrumentation-action_pack 0.12.0 → 0.12.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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: eab625de85019f82c154ff99d01cccd4b83febb3ef39048155b2473d8a610ddf
4
- data.tar.gz: d63558c03d3347820619dd0d654869ac463351ea4ae348887b6fdf1b7159b1d8
3
+ metadata.gz: d469bead142d9682483795b636de7c9d46fc8d410651f3409ab8e106a9d28f48
4
+ data.tar.gz: 3e5fbfaa2a26ea52fa01f58077f8420e92b4a7a3561a4b6547ecbeecfcea07c7
5
5
  SHA512:
6
- metadata.gz: d20ada525ab57f5803fad793c0fc0b71b6c5a5109b4f62744d50205b9bb4ed5e73ccac41404334a68afe8dce946685c42bbbd501dd090871afe948aabba7e2df
7
- data.tar.gz: 10cc04a3536712d37d98b488bc3dec1e45bc37a3b4be025afe5c91a6b474000404f0c082661e30a02ccd8aa0dd366f7fd2f514566dd1308af2c171394641dc9d
6
+ metadata.gz: 98b81892126505b05311b3ca67feb6e530e7543742fa36895e301312e737ed8e5804f8c840aaf8e743ac29e00cec79d81be9908313888311f958225ba7a38d65
7
+ data.tar.gz: 1207dcac466eb75ba81f1b2ce75e8be3136f26d22e997fdb4acace9b84fbadba18aac959f181f29c8a2a0b091a9e9c7b5a3c2e37d86ec108080391c888bd8266
data/CHANGELOG.md CHANGED
@@ -1,5 +1,13 @@
1
1
  # Release History: opentelemetry-instrumentation-action_pack
2
2
 
3
+ ### v0.12.2 / 2025-06-04
4
+
5
+ * FIXED: Rack span class naming
6
+
7
+ ### v0.12.1 / 2025-05-07
8
+
9
+ * FIXED: Account for `nil` routes
10
+
3
11
  ### v0.12.0 / 2025-02-04
4
12
 
5
13
  * ADDED: Strip Rails `(.:format)` suffix from `http.route`
data/README.md CHANGED
@@ -69,7 +69,7 @@ The error object will be retained within `payload[:exception_object]`. Additiona
69
69
 
70
70
  ## Examples
71
71
 
72
- Example usage can be seen in the `./example/trace_demonstration.rb` file [here](https://github.com/open-telemetry/opentelemetry-ruby-contrib/blob/main/instrumentation/action_pack/example/trace_demonstration.ru)
72
+ Example usage can be seen in the [`./example/trace_demonstration.rb` file](https://github.com/open-telemetry/opentelemetry-ruby-contrib/blob/main/instrumentation/action_pack/example/trace_demonstration.ru)
73
73
 
74
74
  ## How can I get involved?
75
75
 
@@ -23,9 +23,34 @@ module OpenTelemetry
23
23
  # @param payload [Hash] the payload passed as a method argument
24
24
  # @return [Hash] the payload passed as a method argument
25
25
  def start(_name, _id, payload)
26
- span_name, attributes = to_span_name_and_attributes(payload)
26
+ request = payload[:request]
27
+ # It seems that there are cases in Rails functional tests where it bypasses the routing system and the `action_dispatch.route_uri_pattern` header not being set.
28
+ # Our Test suite executes the routing system so we are unable to recreate this error case.
29
+ # https://github.com/rails/rails/blob/747f85f200e7bb2c1a31b4e26e5a5655e2dc0cdc/actionpack/lib/action_dispatch/http/request.rb#L160
30
+ http_route = request.route_uri_pattern&.chomp('(.:format)') if request.respond_to?(:route_uri_pattern)
31
+
32
+ attributes = {
33
+ OpenTelemetry::SemanticConventions::Trace::CODE_NAMESPACE => String(payload[:controller]),
34
+ OpenTelemetry::SemanticConventions::Trace::CODE_FUNCTION => String(payload[:action])
35
+ }
36
+ attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_ROUTE] = http_route if http_route
37
+ attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET] = request.filtered_path if request.filtered_path != request.fullpath
27
38
 
28
39
  span = OpenTelemetry::Instrumentation::Rack.current_span
40
+ span_name = if @span_naming == :semconv
41
+ if http_route
42
+ "#{request.method} #{http_route}"
43
+ else
44
+ "#{request.method} /#{payload.dig(:params, :controller)}/#{payload.dig(:params, :action)}"
45
+ end
46
+ # If there is an exception we want to keep the original span name
47
+ # so it is easier to see where the request was routed to.
48
+ elsif request.env['action_dispatch.exception']
49
+ span.name
50
+ else
51
+ "#{payload[:controller]}##{payload[:action]}"
52
+ end
53
+
29
54
  span.name = span_name
30
55
  span.add_attributes(attributes)
31
56
  rescue StandardError => e
@@ -44,32 +69,6 @@ module OpenTelemetry
44
69
  rescue StandardError => e
45
70
  OpenTelemetry.handle_error(exception: e)
46
71
  end
47
-
48
- private
49
-
50
- # Extracts the span name and attributes from the payload
51
- #
52
- # @param payload [Hash] the payload passed from ActiveSupport::Notifications
53
- # @return [Array<String, Hash>] the span name and attributes
54
- def to_span_name_and_attributes(payload)
55
- request = payload[:request]
56
- http_route = request.route_uri_pattern.chomp('(.:format)') if request.respond_to?(:route_uri_pattern)
57
-
58
- attributes = {
59
- OpenTelemetry::SemanticConventions::Trace::CODE_NAMESPACE => String(payload[:controller]),
60
- OpenTelemetry::SemanticConventions::Trace::CODE_FUNCTION => String(payload[:action])
61
- }
62
- attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_ROUTE] = http_route if http_route
63
- attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET] = request.filtered_path if request.filtered_path != request.fullpath
64
-
65
- if @span_naming == :semconv
66
- return ["#{request.method} #{http_route}", attributes] if http_route
67
-
68
- return ["#{request.method} /#{payload.dig(:params, :controller)}/#{payload.dig(:params, :action)}", attributes]
69
- end
70
-
71
- ["#{payload[:controller]}##{payload[:action]}", attributes]
72
- end
73
72
  end
74
73
  end
75
74
  end
@@ -7,7 +7,7 @@
7
7
  module OpenTelemetry
8
8
  module Instrumentation
9
9
  module ActionPack
10
- VERSION = '0.12.0'
10
+ VERSION = '0.12.2'
11
11
  end
12
12
  end
13
13
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: opentelemetry-instrumentation-action_pack
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.12.0
4
+ version: 0.12.2
5
5
  platform: ruby
6
6
  authors:
7
7
  - OpenTelemetry Authors
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-02-04 00:00:00.000000000 Z
11
+ date: 2025-06-04 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: opentelemetry-api
@@ -52,160 +52,6 @@ dependencies:
52
52
  - - "~>"
53
53
  - !ruby/object:Gem::Version
54
54
  version: '0.21'
55
- - !ruby/object:Gem::Dependency
56
- name: appraisal
57
- requirement: !ruby/object:Gem::Requirement
58
- requirements:
59
- - - "~>"
60
- - !ruby/object:Gem::Version
61
- version: '2.5'
62
- type: :development
63
- prerelease: false
64
- version_requirements: !ruby/object:Gem::Requirement
65
- requirements:
66
- - - "~>"
67
- - !ruby/object:Gem::Version
68
- version: '2.5'
69
- - !ruby/object:Gem::Dependency
70
- name: bundler
71
- requirement: !ruby/object:Gem::Requirement
72
- requirements:
73
- - - "~>"
74
- - !ruby/object:Gem::Version
75
- version: '2.4'
76
- type: :development
77
- prerelease: false
78
- version_requirements: !ruby/object:Gem::Requirement
79
- requirements:
80
- - - "~>"
81
- - !ruby/object:Gem::Version
82
- version: '2.4'
83
- - !ruby/object:Gem::Dependency
84
- name: minitest
85
- requirement: !ruby/object:Gem::Requirement
86
- requirements:
87
- - - "~>"
88
- - !ruby/object:Gem::Version
89
- version: '5.0'
90
- type: :development
91
- prerelease: false
92
- version_requirements: !ruby/object:Gem::Requirement
93
- requirements:
94
- - - "~>"
95
- - !ruby/object:Gem::Version
96
- version: '5.0'
97
- - !ruby/object:Gem::Dependency
98
- name: opentelemetry-sdk
99
- requirement: !ruby/object:Gem::Requirement
100
- requirements:
101
- - - "~>"
102
- - !ruby/object:Gem::Version
103
- version: '1.1'
104
- type: :development
105
- prerelease: false
106
- version_requirements: !ruby/object:Gem::Requirement
107
- requirements:
108
- - - "~>"
109
- - !ruby/object:Gem::Version
110
- version: '1.1'
111
- - !ruby/object:Gem::Dependency
112
- name: opentelemetry-test-helpers
113
- requirement: !ruby/object:Gem::Requirement
114
- requirements:
115
- - - "~>"
116
- - !ruby/object:Gem::Version
117
- version: '0.3'
118
- type: :development
119
- prerelease: false
120
- version_requirements: !ruby/object:Gem::Requirement
121
- requirements:
122
- - - "~>"
123
- - !ruby/object:Gem::Version
124
- version: '0.3'
125
- - !ruby/object:Gem::Dependency
126
- name: rake
127
- requirement: !ruby/object:Gem::Requirement
128
- requirements:
129
- - - "~>"
130
- - !ruby/object:Gem::Version
131
- version: '13.0'
132
- type: :development
133
- prerelease: false
134
- version_requirements: !ruby/object:Gem::Requirement
135
- requirements:
136
- - - "~>"
137
- - !ruby/object:Gem::Version
138
- version: '13.0'
139
- - !ruby/object:Gem::Dependency
140
- name: rubocop
141
- requirement: !ruby/object:Gem::Requirement
142
- requirements:
143
- - - "~>"
144
- - !ruby/object:Gem::Version
145
- version: 1.71.0
146
- type: :development
147
- prerelease: false
148
- version_requirements: !ruby/object:Gem::Requirement
149
- requirements:
150
- - - "~>"
151
- - !ruby/object:Gem::Version
152
- version: 1.71.0
153
- - !ruby/object:Gem::Dependency
154
- name: rubocop-performance
155
- requirement: !ruby/object:Gem::Requirement
156
- requirements:
157
- - - "~>"
158
- - !ruby/object:Gem::Version
159
- version: 1.23.0
160
- type: :development
161
- prerelease: false
162
- version_requirements: !ruby/object:Gem::Requirement
163
- requirements:
164
- - - "~>"
165
- - !ruby/object:Gem::Version
166
- version: 1.23.0
167
- - !ruby/object:Gem::Dependency
168
- name: simplecov
169
- requirement: !ruby/object:Gem::Requirement
170
- requirements:
171
- - - "~>"
172
- - !ruby/object:Gem::Version
173
- version: 0.22.0
174
- type: :development
175
- prerelease: false
176
- version_requirements: !ruby/object:Gem::Requirement
177
- requirements:
178
- - - "~>"
179
- - !ruby/object:Gem::Version
180
- version: 0.22.0
181
- - !ruby/object:Gem::Dependency
182
- name: webmock
183
- requirement: !ruby/object:Gem::Requirement
184
- requirements:
185
- - - "~>"
186
- - !ruby/object:Gem::Version
187
- version: 3.24.0
188
- type: :development
189
- prerelease: false
190
- version_requirements: !ruby/object:Gem::Requirement
191
- requirements:
192
- - - "~>"
193
- - !ruby/object:Gem::Version
194
- version: 3.24.0
195
- - !ruby/object:Gem::Dependency
196
- name: yard
197
- requirement: !ruby/object:Gem::Requirement
198
- requirements:
199
- - - "~>"
200
- - !ruby/object:Gem::Version
201
- version: '0.9'
202
- type: :development
203
- prerelease: false
204
- version_requirements: !ruby/object:Gem::Requirement
205
- requirements:
206
- - - "~>"
207
- - !ruby/object:Gem::Version
208
- version: '0.9'
209
55
  description: ActionPack instrumentation for the OpenTelemetry framework
210
56
  email:
211
57
  - cncf-opentelemetry-contributors@lists.cncf.io
@@ -229,10 +75,10 @@ homepage: https://github.com/open-telemetry/opentelemetry-ruby-contrib
229
75
  licenses:
230
76
  - Apache-2.0
231
77
  metadata:
232
- changelog_uri: https://rubydoc.info/gems/opentelemetry-instrumentation-action_pack/0.12.0/file/CHANGELOG.md
78
+ changelog_uri: https://rubydoc.info/gems/opentelemetry-instrumentation-action_pack/0.12.2/file/CHANGELOG.md
233
79
  source_code_uri: https://github.com/open-telemetry/opentelemetry-ruby-contrib/tree/main/instrumentation/action_pack
234
80
  bug_tracker_uri: https://github.com/open-telemetry/opentelemetry-ruby-contrib/issues
235
- documentation_uri: https://rubydoc.info/gems/opentelemetry-instrumentation-action_pack/0.12.0
81
+ documentation_uri: https://rubydoc.info/gems/opentelemetry-instrumentation-action_pack/0.12.2
236
82
  post_install_message:
237
83
  rdoc_options: []
238
84
  require_paths: