Skip to content

Commit

Permalink
move to Core::Utils::Rails
Browse files Browse the repository at this point in the history
  • Loading branch information
p committed Jan 7, 2025
1 parent d632d59 commit 7bf4169
Show file tree
Hide file tree
Showing 18 changed files with 58 additions and 63 deletions.
2 changes: 1 addition & 1 deletion Steepfile
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,6 @@ target :datadog do
ignore 'lib/datadog/core/configuration/option_definition_set.rb'
ignore 'lib/datadog/core/configuration/options.rb'
ignore 'lib/datadog/core/configuration/settings.rb'
ignore 'lib/datadog/core/contrib/rails/utils.rb'
ignore 'lib/datadog/core/diagnostics/health.rb'
ignore 'lib/datadog/core/encoding.rb'
ignore 'lib/datadog/core/environment/container.rb'
Expand Down Expand Up @@ -128,6 +127,7 @@ target :datadog do
ignore 'lib/datadog/core/utils/hash.rb' # Refinement module
ignore 'lib/datadog/core/utils/network.rb'
ignore 'lib/datadog/core/utils/only_once.rb'
ignore 'lib/datadog/core/utils/rails.rb'
ignore 'lib/datadog/core/utils/safe_dup.rb'
ignore 'lib/datadog/core/utils/sequence.rb'
ignore 'lib/datadog/core/utils/time.rb'
Expand Down
24 changes: 0 additions & 24 deletions lib/datadog/core/contrib/rails/utils.rb

This file was deleted.

22 changes: 22 additions & 0 deletions lib/datadog/core/utils/rails.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
# frozen_string_literal: true

module Datadog
module Core
module Utils
# common utilities for Rails
module Rails
def self.app_name
if ::Rails::VERSION::MAJOR >= 6
::Rails.application.class.module_parent_name.underscore
else
::Rails.application.class.parent_name.underscore
end
end

def self.railtie_supported?
!!defined?(::Rails::Railtie)
end
end
end
end
end
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/action_cable/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
require_relative '../integration'
require_relative 'configuration/settings'
require_relative 'patcher'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'

module Datadog
module Tracing
Expand Down Expand Up @@ -33,7 +33,7 @@ def self.compatible?
# enabled by rails integration so should only auto instrument
# if detected that it is being used without rails
def auto_instrument?
!Core::Contrib::Rails::Utils.railtie_supported?
!Core::Utils::Rails.railtie_supported?
end

def new_configuration
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/action_mailer/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
require_relative 'configuration/settings'
require_relative 'patcher'
require_relative '../integration'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'

module Datadog
module Tracing
Expand Down Expand Up @@ -33,7 +33,7 @@ def self.compatible?
# enabled by rails integration so should only auto instrument
# if detected that it is being used without rails
def auto_instrument?
!Core::Contrib::Rails::Utils.railtie_supported?
!Core::Utils::Rails.railtie_supported?
end

def new_configuration
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/action_pack/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
require_relative 'patcher'
require_relative '../integration'
require_relative '../rails/ext'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'

module Datadog
module Tracing
Expand Down Expand Up @@ -34,7 +34,7 @@ def self.compatible?
# enabled by rails integration so should only auto instrument
# if detected that it is being used without rails
def auto_instrument?
!Core::Contrib::Rails::Utils.railtie_supported?
!Core::Utils::Rails.railtie_supported?
end

def new_configuration
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/action_view/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
require_relative 'patcher'
require_relative '../integration'
require_relative '../rails/ext'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'

module Datadog
module Tracing
Expand Down Expand Up @@ -41,7 +41,7 @@ def self.compatible?
# enabled by rails integration so should only auto instrument
# if detected that it is being used without rails
def auto_instrument?
!Core::Contrib::Rails::Utils.railtie_supported?
!Core::Utils::Rails.railtie_supported?
end

def new_configuration
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/active_job/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
require_relative 'configuration/settings'
require_relative 'patcher'
require_relative '../integration'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'

module Datadog
module Tracing
Expand Down Expand Up @@ -33,7 +33,7 @@ def self.compatible?
# enabled by rails integration so should only auto instrument
# if detected that it is being used without rails
def auto_instrument?
!Core::Contrib::Rails::Utils.railtie_supported?
!Core::Utils::Rails.railtie_supported?
end

def new_configuration
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/active_record/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
require_relative '../component'
require_relative '../integration'
require_relative '../rails/ext'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'

module Datadog
module Tracing
Expand Down Expand Up @@ -37,7 +37,7 @@ def self.compatible?
# enabled by rails integration so should only auto instrument
# if detected that it is being used without rails
def auto_instrument?
!Core::Contrib::Rails::Utils.railtie_supported?
!Core::Utils::Rails.railtie_supported?
end

def new_configuration
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/active_support/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
require_relative 'patcher'
require_relative 'cache/redis'
require_relative '../rails/ext'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'

module Datadog
module Tracing
Expand Down Expand Up @@ -35,7 +35,7 @@ def self.compatible?
# enabled by rails integration so should only auto instrument
# if detected that it is being used without rails
def auto_instrument?
!Core::Contrib::Rails::Utils.railtie_supported?
!Core::Utils::Rails.railtie_supported?
end

def new_configuration
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/auto_instrument.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@ module Tracing
module Contrib
# Auto-activate instrumentation
def self.auto_instrument!
require_relative '../../core/contrib/rails/utils'
require_relative '../../core/utils/rails'

# Defer to Rails if this is a Rails application
if Datadog::Core::Contrib::Rails::Utils.railtie_supported?
if Datadog::Core::Utils::Rails.railtie_supported?
require_relative 'rails/auto_instrument_railtie'
else
AutoInstrument.patch_all!
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/rack/integration.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
require_relative '../integration'
require_relative 'configuration/settings'
require_relative 'patcher'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'

module Datadog
module Tracing
Expand Down Expand Up @@ -33,7 +33,7 @@ def self.compatible?
# enabled by rails integration so should only auto instrument
# if detected that it is being used without rails
def auto_instrument?
!Core::Contrib::Rails::Utils.railtie_supported?
!Core::Utils::Rails.railtie_supported?
end

def new_configuration
Expand Down
4 changes: 2 additions & 2 deletions lib/datadog/tracing/contrib/rails/framework.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
require_relative '../grape/endpoint'
require_relative '../lograge/integration'
require_relative 'ext'
require_relative '../../../core/contrib/rails/utils'
require_relative '../../../core/utils/rails'
require_relative '../semantic_logger/integration'

module Datadog
Expand Down Expand Up @@ -41,7 +41,7 @@ def self.setup
# being executed, but here we know better, get it from Rails config.
# Don't set this if service has been explicitly provided by the user.
if datadog_config.service_without_fallback.nil?
datadog_config.service = rails_config[:service_name] || Core::Contrib::Rails::Utils.app_name
datadog_config.service = rails_config[:service_name] || Core::Utils::Rails.app_name
end

activate_rack!(datadog_config, rails_config)
Expand Down
1 change: 0 additions & 1 deletion lib/datadog/tracing/contrib/rails/patcher.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@
require_relative 'log_injection'
require_relative 'middlewares'
require_relative 'runner'
require_relative '../../../core/contrib/rails/utils'
require_relative '../semantic_logger/patcher'

module Datadog
Expand Down
13 changes: 0 additions & 13 deletions sig/datadog/core/contrib/rails/utils.rbs

This file was deleted.

11 changes: 11 additions & 0 deletions sig/datadog/core/utils/rails.rbs
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
module Datadog
module Core
module Utils
module Rails
def self.app_name: () -> String

def self.railtie_supported?: () -> bool
end
end
end
end
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
require 'lib/datadog/core/contrib/rails/utils'
require 'lib/datadog/core/utils/rails'
require 'rails/version'

RSpec.describe Datadog::Core::Contrib::Rails::Utils do
RSpec.describe Datadog::Core::Utils::Rails do
describe 'railtie_supported?' do
subject(:railtie_supported?) { described_class.railtie_supported? }

Expand Down
4 changes: 2 additions & 2 deletions spec/datadog/tracing/contrib/auto_instrument_examples.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,15 @@

context 'outside of a rails application' do
before do
allow(Datadog::Core::Contrib::Rails::Utils).to receive(:railtie_supported?).and_return(false)
allow(Datadog::Core::Utils::Rails).to receive(:railtie_supported?).and_return(false)
end

it { is_expected.to be(true) }
end

context 'when within a rails application' do
before do
allow(Datadog::Core::Contrib::Rails::Utils).to receive(:railtie_supported?).and_return(true)
allow(Datadog::Core::Utils::Rails).to receive(:railtie_supported?).and_return(true)
end

it { is_expected.to be(false) }
Expand Down

0 comments on commit 7bf4169

Please sign in to comment.