Skip to content

Commit

Permalink
Add support for Kicks gem
Browse files Browse the repository at this point in the history
  • Loading branch information
marcotc committed Jan 2, 2025
1 parent cf5120d commit 1e42f87
Show file tree
Hide file tree
Showing 18 changed files with 125 additions and 19 deletions.
3 changes: 2 additions & 1 deletion Matrixfile
Original file line number Diff line number Diff line change
Expand Up @@ -168,7 +168,8 @@
'contrib' => '✅ 2.5 / ✅ 2.6 / ✅ 2.7 / ✅ 3.0 / ✅ 3.1 / ✅ 3.2 / ✅ 3.3 / ✅ 3.4 / ✅ jruby'
},
'sneakers' => {
'contrib' => '✅ 2.5 / ✅ 2.6 / ✅ 2.7 / ✅ 3.0 / ✅ 3.1 / ✅ 3.2 / ✅ 3.3 / ✅ 3.4 / ✅ jruby'
'kicks-3' => '✅ 2.5 / ✅ 2.6 / ✅ 2.7 / ✅ 3.0 / ✅ 3.1 / ✅ 3.2 / ✅ 3.3 / ✅ 3.4 / ✅ jruby',
'sneakers-2' => '✅ 2.5 / ✅ 2.6 / ✅ 2.7 / ✅ 3.0 / ✅ 3.1 / ✅ 3.2 / ✅ 3.3 / ✅ 3.4 / ✅ jruby',
},
'stripe' => {
'stripe-latest' => '✅ 2.5 / ✅ 2.6 / ✅ 2.7 / ✅ 3.0 / ✅ 3.1 / ✅ 3.2 / ✅ 3.3 / ✅ 3.4 / ✅ jruby',
Expand Down
14 changes: 8 additions & 6 deletions appraisal/generate.rb
Original file line number Diff line number Diff line change
Expand Up @@ -49,12 +49,14 @@

# Builds a matrix of versions to test for a given integration

# `range`: the range of versions to test
# `gem` : optional, gem name to test (gem name can be different from the integration name)
# `min` : optional, minimum version to test
# `meta` : optional, additional metadata (development dependencies, etc.) for the group
def build_coverage_matrix(integration, range, gem: nil, min: nil, meta: {})
gem ||= integration
# @param [String] integration the name of the integration to test
# @param [Range, Integer] range the range of major versions to test, or a single major version to test
# @param [String] gem optional, gem name to test (gem name can be different from the integration name)
# @param [String] min optional, minimum version to test
# @param [Hash] meta optional, additional metadata (development dependencies, etc.) for the group
def build_coverage_matrix(integration, range, gem: integration, min: nil, meta: {})
# Allow single version to be passed easily
range = range..range if range.is_a?(Integer)

if min
appraise "#{integration}-min" do
Expand Down
2 changes: 2 additions & 0 deletions appraisal/jruby-9.2.rb
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 5'
Expand Down
2 changes: 2 additions & 0 deletions appraisal/jruby-9.3.rb
Original file line number Diff line number Diff line change
Expand Up @@ -175,6 +175,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 6.0.0'
Expand Down
2 changes: 2 additions & 0 deletions appraisal/jruby-9.4.rb
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 6.1.0'
Expand Down
2 changes: 2 additions & 0 deletions appraisal/ruby-2.5.rb
Original file line number Diff line number Diff line change
Expand Up @@ -221,6 +221,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 5'
Expand Down
2 changes: 2 additions & 0 deletions appraisal/ruby-2.6.rb
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 6.0.0'
Expand Down
2 changes: 2 additions & 0 deletions appraisal/ruby-2.7.rb
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 6.1.0'
Expand Down
2 changes: 2 additions & 0 deletions appraisal/ruby-3.0.rb
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 7'
Expand Down
2 changes: 2 additions & 0 deletions appraisal/ruby-3.1.rb
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 7'
Expand Down
2 changes: 2 additions & 0 deletions appraisal/ruby-3.2.rb
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 7'
Expand Down
3 changes: 2 additions & 1 deletion appraisal/ruby-3.3.rb
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
gem 'activerecord', '~> 7'
Expand Down Expand Up @@ -131,7 +133,6 @@
gem 'roda', '>= 2.0.0'
gem 'semantic_logger', '~> 4.0'
gem 'sidekiq', '~> 7'
gem 'sneakers', '>= 2.12.0'
gem 'sucker_punch'
gem 'que', '>= 1.0.0'
end
Expand Down
2 changes: 2 additions & 0 deletions appraisal/ruby-3.4.rb
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,8 @@
build_coverage_matrix('stripe', 7..12, min: '5.15.0')
build_coverage_matrix('opensearch', 2..3, gem: 'opensearch-ruby')
build_coverage_matrix('elasticsearch', 7..8)
build_coverage_matrix('kicks', 3)
build_coverage_matrix('sneakers', 2)

appraise 'relational_db' do
# ActiveRecord locked because tests are failing with 7.1, which was attempted as a part of Ruby 3.4 testing in CI.
Expand Down
11 changes: 11 additions & 0 deletions lib/datadog/tracing/contrib/registerable.rb
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,17 @@ module ClassMethods
def register_as(name, registry: Contrib::REGISTRY, auto_patch: false, **options)
registry.add(name, new(name, **options), auto_patch)
end

# Registers this `alias_name` in the global tracer registry as an alias of `original_name`.
# Using `alias_name` or `original_name` become interchangeable.
# The configuration object is shared between the two names.
# The patcher will only run once if both are activated.
def register_as_alias(original_name, alias_name, registry: Contrib::REGISTRY)
original = registry[original_name]
raise ArgumentError, "integration '#{original_name}' not registered" unless original

registry.add(alias_name, original, false)
end
end

# Instance methods for registerable behavior
Expand Down
20 changes: 16 additions & 4 deletions lib/datadog/tracing/contrib/sneakers/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -13,21 +13,33 @@ module Sneakers
class Integration
include Contrib::Integration

MINIMUM_VERSION = Gem::Version.new('2.12.0')
MINIMUM_SNEAKERS_VERSION = Gem::Version.new('2.12.0')
# All versions are supported. Kicks first version is 3.0.0.
MINIMUM_KICKS_VERSION = Gem::Version.new('3.0.0')

# @public_api Changing the integration name or integration options can cause breaking changes
register_as :sneakers, auto_patch: true

register_as_alias :sneakers, :kicks

# Sneakers development continues in the Kicks gem.
# The **only** thing that has changed is the gem name,
# even the file naming and module namespacing are the same (require 'sneakers', `::Sneakers`).
#
# The last version of Sneakers is 2.12.0.
# The first version of Kicks is 3.0.0. We currently support all versions of Kicks.
#
# @see https://github.com/jondot/sneakers/commit/9780692624c666b6db8266d2d5710f709cb0f2e2
def self.version
Gem.loaded_specs['sneakers'] && Gem.loaded_specs['sneakers'].version
Gem.loaded_specs['sneakers'] && Gem.loaded_specs['sneakers'].version || \
Gem.loaded_specs['kicks'] && Gem.loaded_specs['kicks'].version
end

def self.loaded?
!defined?(::Sneakers).nil?
end

def self.compatible?
super && version >= MINIMUM_VERSION
super && version >= MINIMUM_SNEAKERS_VERSION
end

def new_configuration
Expand Down
2 changes: 2 additions & 0 deletions sig/datadog/tracing/contrib/registerable.rbs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ module Datadog
def self.included: (untyped base) -> untyped
module ClassMethods
def register_as: (untyped name, ?registry: untyped, ?auto_patch: bool, **untyped options) -> untyped

def register_as_alias: (Symbol original_name, Symbol alias_name, registry: Registry) -> void
end
module InstanceMethods
attr_reader name: untyped
Expand Down
38 changes: 38 additions & 0 deletions spec/datadog/tracing/contrib/registerable_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,44 @@
end
end
end

describe '#register_as_alias' do
subject(:register_as_alias) { registerable_class.register_as_alias(:original, :alias, **options) }

context 'when a registry' do
context 'is provided' do
let(:options) { { registry: registry } }
let(:registry) { Datadog::Tracing::Contrib::Registry.new }

context 'with the original integration not registered' do
it { expect { register_as_alias }.to raise_error(ArgumentError) }
end

context 'with the original integration registered' do
before { registerable_class.register_as(:original, registry: registry) }

it 'creates an alias to the original integration object' do
register_as_alias
expect(registry[:alias]).to be(registry[:original])
end
end
end

context 'is not provided' do
let(:options) { {} }
let(:registry) { Datadog::Tracing::Contrib::Registry.new }

before { registerable_class.register_as(:original, registry: registry) }

it 'invokes the global Datadog.registry' do
stub_const('Datadog::Tracing::Contrib::REGISTRY', registry)

register_as_alias
expect(registry[:alias]).to be(registry[:original])
end
end
end
end
end

describe 'instance behavior' do
Expand Down
33 changes: 26 additions & 7 deletions spec/datadog/tracing/contrib/sneakers/integration_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,17 @@
subject(:version) { described_class.version }

context 'when the "sneakers" gem is loaded' do
include_context 'loaded gems', sneakers: described_class::MINIMUM_VERSION
include_context 'loaded gems', sneakers: described_class::MINIMUM_SNEAKERS_VERSION
it { is_expected.to be_a_kind_of(Gem::Version) }
end

context 'when "sneakers" gem is not loaded' do
include_context 'loaded gems', sneakers: nil
context 'when the "kicks" gem is loaded' do
include_context 'loaded gems', kicks: described_class::MINIMUM_KICKS_VERSION
it { is_expected.to be_a_kind_of(Gem::Version) }
end

context 'when neither gem is not loaded' do
include_context 'loaded gems', sneakers: nil, kicks: nil
it { is_expected.to be nil }
end
end
Expand All @@ -40,18 +45,32 @@

context 'when "sneakers" gem is loaded with a version' do
context 'that is less than the minimum' do
include_context 'loaded gems', sneakers: decrement_gem_version(described_class::MINIMUM_VERSION)
include_context 'loaded gems',
sneakers: decrement_gem_version(described_class::MINIMUM_SNEAKERS_VERSION),
kicks: nil
it { is_expected.to be false }
end

context 'that meets the minimum version' do
include_context 'loaded gems', sneakers: described_class::MINIMUM_SNEAKERS_VERSION, kicks: nil
it { is_expected.to be true }
end
end

context 'when "kicks" gem is loaded with a version' do
context 'that is less than the minimum' do
include_context 'loaded gems', sneakers: nil, kicks: decrement_gem_version(described_class::MINIMUM_KICKS_VERSION)
it { is_expected.to be false }
end

context 'that meets the minimum version' do
include_context 'loaded gems', sneakers: described_class::MINIMUM_VERSION
include_context 'loaded gems', sneakers: nil, kicks: described_class::MINIMUM_KICKS_VERSION
it { is_expected.to be true }
end
end

context 'when gem is not loaded' do
include_context 'loaded gems', sneakers: nil
context 'when neither gem is not loaded' do
include_context 'loaded gems', sneakers: nil, kicks: nil
it { is_expected.to be false }
end
end
Expand Down

0 comments on commit 1e42f87

Please sign in to comment.