sentry-ruby 5.26.0 → 6.1.1

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.
Files changed (60) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +2 -4
  3. data/README.md +1 -1
  4. data/lib/sentry/background_worker.rb +1 -4
  5. data/lib/sentry/backtrace/line.rb +99 -0
  6. data/lib/sentry/backtrace.rb +44 -76
  7. data/lib/sentry/breadcrumb.rb +1 -1
  8. data/lib/sentry/breadcrumb_buffer.rb +2 -2
  9. data/lib/sentry/check_in_event.rb +2 -2
  10. data/lib/sentry/client.rb +39 -89
  11. data/lib/sentry/configuration.rb +125 -78
  12. data/lib/sentry/cron/monitor_check_ins.rb +3 -3
  13. data/lib/sentry/cron/monitor_config.rb +2 -2
  14. data/lib/sentry/cron/monitor_schedule.rb +2 -2
  15. data/lib/sentry/debug_structured_logger.rb +94 -0
  16. data/lib/sentry/dsn.rb +32 -0
  17. data/lib/sentry/envelope/item.rb +1 -2
  18. data/lib/sentry/error_event.rb +3 -3
  19. data/lib/sentry/event.rb +4 -10
  20. data/lib/sentry/graphql.rb +1 -1
  21. data/lib/sentry/hub.rb +6 -5
  22. data/lib/sentry/interface.rb +1 -1
  23. data/lib/sentry/interfaces/exception.rb +2 -2
  24. data/lib/sentry/interfaces/request.rb +2 -0
  25. data/lib/sentry/interfaces/single_exception.rb +3 -3
  26. data/lib/sentry/interfaces/stacktrace.rb +3 -3
  27. data/lib/sentry/interfaces/stacktrace_builder.rb +0 -8
  28. data/lib/sentry/interfaces/threads.rb +2 -2
  29. data/lib/sentry/log_event.rb +19 -6
  30. data/lib/sentry/profiler.rb +4 -5
  31. data/lib/sentry/propagation_context.rb +55 -18
  32. data/lib/sentry/rspec.rb +1 -1
  33. data/lib/sentry/span.rb +2 -17
  34. data/lib/sentry/std_lib_logger.rb +6 -1
  35. data/lib/sentry/test_helper.rb +23 -0
  36. data/lib/sentry/transaction.rb +72 -95
  37. data/lib/sentry/transaction_event.rb +4 -9
  38. data/lib/sentry/transport/debug_transport.rb +70 -0
  39. data/lib/sentry/transport/dummy_transport.rb +1 -0
  40. data/lib/sentry/transport/http_transport.rb +9 -5
  41. data/lib/sentry/transport.rb +3 -5
  42. data/lib/sentry/utils/encoding_helper.rb +7 -0
  43. data/lib/sentry/utils/logging_helper.rb +8 -6
  44. data/lib/sentry/utils/sample_rand.rb +97 -0
  45. data/lib/sentry/vernier/profiler.rb +4 -3
  46. data/lib/sentry/version.rb +1 -1
  47. data/lib/sentry-ruby.rb +6 -30
  48. data/sentry-ruby-core.gemspec +1 -1
  49. data/sentry-ruby.gemspec +1 -1
  50. metadata +12 -18
  51. data/lib/sentry/metrics/aggregator.rb +0 -248
  52. data/lib/sentry/metrics/configuration.rb +0 -47
  53. data/lib/sentry/metrics/counter_metric.rb +0 -25
  54. data/lib/sentry/metrics/distribution_metric.rb +0 -25
  55. data/lib/sentry/metrics/gauge_metric.rb +0 -35
  56. data/lib/sentry/metrics/local_aggregator.rb +0 -53
  57. data/lib/sentry/metrics/metric.rb +0 -19
  58. data/lib/sentry/metrics/set_metric.rb +0 -28
  59. data/lib/sentry/metrics/timing.rb +0 -51
  60. data/lib/sentry/metrics.rb +0 -56
@@ -1,51 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Sentry
4
- module Metrics
5
- module Timing
6
- class << self
7
- def nanosecond
8
- time = Sentry.utc_now
9
- time.to_i * (10 ** 9) + time.nsec
10
- end
11
-
12
- def microsecond
13
- time = Sentry.utc_now
14
- time.to_i * (10 ** 6) + time.usec
15
- end
16
-
17
- def millisecond
18
- Sentry.utc_now.to_i * (10 ** 3)
19
- end
20
-
21
- def second
22
- Sentry.utc_now.to_i
23
- end
24
-
25
- def minute
26
- Sentry.utc_now.to_i / 60.0
27
- end
28
-
29
- def hour
30
- Sentry.utc_now.to_i / 3600.0
31
- end
32
-
33
- def day
34
- Sentry.utc_now.to_i / (3600.0 * 24.0)
35
- end
36
-
37
- def week
38
- Sentry.utc_now.to_i / (3600.0 * 24.0 * 7.0)
39
- end
40
-
41
- def duration_start
42
- Process.clock_gettime(Process::CLOCK_MONOTONIC)
43
- end
44
-
45
- def duration_end(start)
46
- Process.clock_gettime(Process::CLOCK_MONOTONIC) - start
47
- end
48
- end
49
- end
50
- end
51
- end
@@ -1,56 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require "sentry/metrics/metric"
4
- require "sentry/metrics/counter_metric"
5
- require "sentry/metrics/distribution_metric"
6
- require "sentry/metrics/gauge_metric"
7
- require "sentry/metrics/set_metric"
8
- require "sentry/metrics/timing"
9
- require "sentry/metrics/aggregator"
10
-
11
- module Sentry
12
- module Metrics
13
- DURATION_UNITS = %w[nanosecond microsecond millisecond second minute hour day week]
14
- INFORMATION_UNITS = %w[bit byte kilobyte kibibyte megabyte mebibyte gigabyte gibibyte terabyte tebibyte petabyte pebibyte exabyte exbibyte]
15
- FRACTIONAL_UNITS = %w[ratio percent]
16
-
17
- OP_NAME = "metric.timing"
18
- SPAN_ORIGIN = "auto.metric.timing"
19
-
20
- class << self
21
- def increment(key, value = 1.0, unit: "none", tags: {}, timestamp: nil)
22
- Sentry.metrics_aggregator&.add(:c, key, value, unit: unit, tags: tags, timestamp: timestamp)
23
- end
24
-
25
- def distribution(key, value, unit: "none", tags: {}, timestamp: nil)
26
- Sentry.metrics_aggregator&.add(:d, key, value, unit: unit, tags: tags, timestamp: timestamp)
27
- end
28
-
29
- def set(key, value, unit: "none", tags: {}, timestamp: nil)
30
- Sentry.metrics_aggregator&.add(:s, key, value, unit: unit, tags: tags, timestamp: timestamp)
31
- end
32
-
33
- def gauge(key, value, unit: "none", tags: {}, timestamp: nil)
34
- Sentry.metrics_aggregator&.add(:g, key, value, unit: unit, tags: tags, timestamp: timestamp)
35
- end
36
-
37
- def timing(key, unit: "second", tags: {}, timestamp: nil, &block)
38
- return unless block_given?
39
- return yield unless DURATION_UNITS.include?(unit)
40
-
41
- result, value = Sentry.with_child_span(op: OP_NAME, description: key, origin: SPAN_ORIGIN) do |span|
42
- tags.each { |k, v| span.set_tag(k, v.is_a?(Array) ? v.join(", ") : v.to_s) } if span
43
-
44
- start = Timing.send(unit.to_sym)
45
- result = yield
46
- value = Timing.send(unit.to_sym) - start
47
-
48
- [result, value]
49
- end
50
-
51
- Sentry.metrics_aggregator&.add(:d, key, value, unit: unit, tags: tags, timestamp: timestamp)
52
- result
53
- end
54
- end
55
- end
56
- end