opentelemetry-exporter-jaeger 0.7.0 → 0.12.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 6bc6a2d520fef3b1bd667a4987730e5d5c82711381a3b8a83e6317830c467d0b
4
- data.tar.gz: ddaafa96a03026729fdb0112ca6183d9a13de8752d70aad9fae992b6db15809f
3
+ metadata.gz: 1c9e5303c5d213eb07a04eb5d9102eb959f76d8ddb519e7626eb62e876fe5e26
4
+ data.tar.gz: eaef6cc4bae366ece52d06bdd4c3b9bd0795c0e1e8bbdd944dc5caa8d3158b27
5
5
  SHA512:
6
- metadata.gz: 995b968d85b99897ccca539a4cbb5657b93dbd962946d4771d9363788507da3de057c87aba39223a246eb9312b8258f1984e98428e80c5459dcf48e07ad2cfd7
7
- data.tar.gz: 7515e9ff79a96b44873408eeed222f54a91aa2ff280c1af4ddeb7fe3e6304e6c0463e19e5e855e7fd503f5a8cfea5c6e94ebbaca801c375ff18086fcac61dac4
6
+ metadata.gz: 0be71380edef077d86867b3e51785e4d0e1efd85965a1553db6e720afada01e1993651df6ced3045cbef55892e4a17fb391f733efd5b66fe73e59ba4ef17047f
7
+ data.tar.gz: 34fb683b8f3bcd597221ae580ab4ef5b326bca64eb55d9cac55ca8d8a15992d6e4fe7983d8ec749f815180b4a5e60c8e89e6d0ff5fa3468139aa93d48944e044
@@ -1,5 +1,33 @@
1
1
  # Release History: opentelemetry-exporter-jaeger
2
2
 
3
+ ### v0.12.0 / 2020-12-24
4
+
5
+ * ADDED: Structured error handling
6
+
7
+ ### v0.11.0 / 2020-12-11
8
+
9
+ * FIXED: Copyright comments to not reference year
10
+
11
+ ### v0.10.0 / 2020-12-03
12
+
13
+ * (No significant changes)
14
+
15
+ ### v0.9.0 / 2020-11-27
16
+
17
+ * BREAKING CHANGE: Add timeout for force_flush and shutdown
18
+
19
+ * ADDED: Add timeout for force_flush and shutdown
20
+
21
+ ### v0.8.0 / 2020-10-27
22
+
23
+ * BREAKING CHANGE: Move context/span methods to Trace module
24
+ * BREAKING CHANGE: Remove 'canonical' from status codes
25
+ * BREAKING CHANGE: Assorted SpanContext fixes
26
+
27
+ * FIXED: Move context/span methods to Trace module
28
+ * FIXED: Remove 'canonical' from status codes
29
+ * FIXED: Assorted SpanContext fixes
30
+
3
31
  ### v0.7.0 / 2020-10-07
4
32
 
5
33
  * ADDED: Add service_version setter to configurator
data/LICENSE CHANGED
@@ -186,7 +186,7 @@
186
186
  same "printed page" as the copyright notice for easier
187
187
  identification within third-party archives.
188
188
 
189
- Copyright 2020 OpenTelemetry Authors
189
+ Copyright The OpenTelemetry Authors
190
190
 
191
191
  Licensed under the Apache License, Version 2.0 (the "License");
192
192
  you may not use this file except in compliance with the License.
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- # Copyright 2019 OpenTelemetry Authors
3
+ # Copyright The OpenTelemetry Authors
4
4
  #
5
5
  # SPDX-License-Identifier: Apache-2.0
6
6
 
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- # Copyright 2019 OpenTelemetry Authors
3
+ # Copyright The OpenTelemetry Authors
4
4
  #
5
5
  # SPDX-License-Identifier: Apache-2.0
6
6
 
@@ -23,6 +23,7 @@ $LOAD_PATH.push(File.dirname(__FILE__) + '/../../../thrift/gen-rb')
23
23
  require 'agent'
24
24
  require 'collector'
25
25
  require 'opentelemetry/sdk'
26
+ require 'opentelemetry/common'
26
27
  require 'socket'
27
28
  require 'opentelemetry/exporter/jaeger/encoder'
28
29
  require 'opentelemetry/exporter/jaeger/transport'
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- # Copyright 2019 OpenTelemetry Authors
3
+ # Copyright The OpenTelemetry Authors
4
4
  #
5
5
  # SPDX-License-Identifier: Apache-2.0
6
6
 
@@ -30,12 +30,14 @@ module OpenTelemetry
30
30
  # @param [Enumerable<OpenTelemetry::SDK::Trace::SpanData>] span_data the
31
31
  # list of recorded {OpenTelemetry::SDK::Trace::SpanData} structs to be
32
32
  # exported.
33
+ # @param [optional Numeric] timeout An optional timeout in seconds.
33
34
  # @return [Integer] the result of the export.
34
- def export(span_data)
35
+ def export(span_data, timeout: nil)
35
36
  return FAILURE if @shutdown
36
37
 
38
+ start_time = Time.now
37
39
  encoded_batches(span_data) do |batch|
38
- return FAILURE if @shutdown
40
+ return FAILURE if @shutdown || OpenTelemetry::Common::Utilities.maybe_timeout(timeout, start_time)&.zero?
39
41
 
40
42
  @client.emitBatch(batch)
41
43
  end
@@ -44,7 +46,9 @@ module OpenTelemetry
44
46
  # Called when {OpenTelemetry::SDK::Trace::Tracer#shutdown} is called, if
45
47
  # this exporter is registered to a {OpenTelemetry::SDK::Trace::Tracer}
46
48
  # object.
47
- def shutdown
49
+ #
50
+ # @param [optional Numeric] timeout An optional timeout in seconds.
51
+ def shutdown(timeout: nil)
48
52
  @shutdown = true
49
53
  end
50
54
 
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- # Copyright 2019 OpenTelemetry Authors
3
+ # Copyright The OpenTelemetry Authors
4
4
  #
5
5
  # SPDX-License-Identifier: Apache-2.0
6
6
 
@@ -29,7 +29,6 @@ module OpenTelemetry
29
29
  end
30
30
  @serializer = ::Thrift::Serializer.new
31
31
  @shutdown = false
32
- @tracer = OpenTelemetry.tracer_provider.tracer
33
32
  end
34
33
 
35
34
  # Called to export sampled {OpenTelemetry::SDK::Trace::SpanData} structs.
@@ -37,8 +36,9 @@ module OpenTelemetry
37
36
  # @param [Enumerable<OpenTelemetry::SDK::Trace::SpanData>] span_data the
38
37
  # list of recorded {OpenTelemetry::SDK::Trace::SpanData} structs to be
39
38
  # exported.
39
+ # @param [optional Numeric] timeout An optional timeout in seconds.
40
40
  # @return [Integer] the result of the export.
41
- def export(span_data)
41
+ def export(span_data, timeout: nil)
42
42
  return FAILURE if @shutdown
43
43
 
44
44
  encoded_batches(span_data).each do |batch|
@@ -50,14 +50,16 @@ module OpenTelemetry
50
50
  end
51
51
  SUCCESS
52
52
  rescue StandardError => e
53
- OpenTelemetry.logger.error("unexpected error in Jaeger::CollectorExporter#export - #{e}")
53
+ OpenTelemetry.handle_error(exception: e, message: 'unexpected error in Jaeger::CollectorExporter#export')
54
54
  FAILURE
55
55
  end
56
56
 
57
57
  # Called when {OpenTelemetry::SDK::Trace::Tracer#shutdown} is called, if
58
58
  # this exporter is registered to a {OpenTelemetry::SDK::Trace::Tracer}
59
59
  # object.
60
- def shutdown
60
+ #
61
+ # @param [optional Numeric] timeout An optional timeout in seconds.
62
+ def shutdown(timeout: nil)
61
63
  @shutdown = true
62
64
  end
63
65
 
@@ -73,7 +75,7 @@ module OpenTelemetry
73
75
  end
74
76
 
75
77
  def untraced
76
- @tracer.with_span(OpenTelemetry::Trace::Span.new) { yield }
78
+ OpenTelemetry::Trace.with_span(OpenTelemetry::Trace::Span.new) { yield }
77
79
  end
78
80
 
79
81
  def encoded_batches(span_data)
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- # Copyright 2020 OpenTelemetry Authors
3
+ # Copyright The OpenTelemetry Authors
4
4
  #
5
5
  # SPDX-License-Identifier: Apache-2.0
6
6
 
@@ -111,15 +111,15 @@ module OpenTelemetry
111
111
  links&.map do |link|
112
112
  Thrift::SpanRef.new(
113
113
  'refType' => Thrift::SpanRefType::CHILD_OF,
114
- 'traceIdLow' => int64(link.context.trace_id[16, 16]),
115
- 'traceIdHigh' => int64(link.context.trace_id[0, 16]),
116
- 'spanId' => int64(link.context.span_id)
114
+ 'traceIdLow' => int64(link.span_context.trace_id[16, 16]),
115
+ 'traceIdHigh' => int64(link.span_context.trace_id[0, 16]),
116
+ 'spanId' => int64(link.span_context.span_id)
117
117
  )
118
118
  end
119
119
  end
120
120
 
121
121
  def encoded_status(status)
122
- return EMPTY_ARRAY unless status&.canonical_code == OpenTelemetry::Trace::Status::ERROR
122
+ return EMPTY_ARRAY unless status&.code == OpenTelemetry::Trace::Status::ERROR
123
123
 
124
124
  Array(
125
125
  Thrift::Tag.new(
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- # Copyright 2019 OpenTelemetry Authors
3
+ # Copyright The OpenTelemetry Authors
4
4
  #
5
5
  # SPDX-License-Identifier: Apache-2.0
6
6
 
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- # Copyright 2019 OpenTelemetry Authors
3
+ # Copyright The OpenTelemetry Authors
4
4
  #
5
5
  # SPDX-License-Identifier: Apache-2.0
6
6
 
@@ -8,7 +8,7 @@ module OpenTelemetry
8
8
  module Exporter
9
9
  module Jaeger
10
10
  ## Current OpenTelemetry Jaeger exporter version
11
- VERSION = '0.7.0'
11
+ VERSION = '0.12.0'
12
12
  end
13
13
  end
14
14
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: opentelemetry-exporter-jaeger
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.7.0
4
+ version: 0.12.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - OpenTelemetry Authors
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-10-08 00:00:00.000000000 Z
11
+ date: 2020-12-24 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: opentelemetry-api
@@ -16,14 +16,28 @@ dependencies:
16
16
  requirements:
17
17
  - - "~>"
18
18
  - !ruby/object:Gem::Version
19
- version: 0.7.0
19
+ version: 0.12.0
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - "~>"
25
25
  - !ruby/object:Gem::Version
26
- version: 0.7.0
26
+ version: 0.12.0
27
+ - !ruby/object:Gem::Dependency
28
+ name: opentelemetry-common
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: 0.12.0
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: 0.12.0
27
41
  - !ruby/object:Gem::Dependency
28
42
  name: thrift
29
43
  requirement: !ruby/object:Gem::Requirement
@@ -194,7 +208,11 @@ files:
194
208
  homepage: https://github.com/open-telemetry/opentelemetry-ruby
195
209
  licenses:
196
210
  - Apache-2.0
197
- metadata: {}
211
+ metadata:
212
+ changelog_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-exporter-jaeger/v0.12.0/file.CHANGELOG.html
213
+ source_code_uri: https://github.com/open-telemetry/opentelemetry-ruby/tree/master/exporter/jaeger
214
+ bug_tracker_uri: https://github.com/open-telemetry/opentelemetry-ruby/issues
215
+ documentation_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-exporter-jaeger/v0.12.0
198
216
  post_install_message:
199
217
  rdoc_options: []
200
218
  require_paths: