Skip to content

Commit

Permalink
add default_proc option to store block value as default value
Browse files Browse the repository at this point in the history
  • Loading branch information
GustavoCaso committed Jun 30, 2023
1 parent 35ddd1c commit f54d36f
Show file tree
Hide file tree
Showing 14 changed files with 74 additions and 12 deletions.
2 changes: 1 addition & 1 deletion lib/datadog/core/configuration/option.rb
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ def default_value
if definition.default.instance_of?(Proc)
context_eval(&definition.default)
else
definition.default
definition.default_proc || definition.default
end
end

Expand Down
24 changes: 24 additions & 0 deletions lib/datadog/core/configuration/option_definition.rb
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ class OptionDefinition

attr_reader \
:default,
:default_proc,
:delegate_to,
:depends_on,
:name,
Expand All @@ -21,6 +22,7 @@ class OptionDefinition

def initialize(name, meta = {}, &block)
@default = meta[:default]
@default_proc = meta[:default_proc]
@delegate_to = meta[:delegate_to]
@depends_on = meta[:depends_on] || []
@name = name.to_sym
Expand All @@ -38,11 +40,14 @@ def build(context)
# Acts as DSL for building OptionDefinitions
# @public_api
class Builder
class InvalidOptionError < StandardError; end

attr_reader \
:helpers

def initialize(name, options = {})
@default = nil
@default_proc = nil
@delegate_to = nil
@depends_on = []
@helpers = {}
Expand All @@ -57,6 +62,8 @@ def initialize(name, options = {})

# Apply block if given.
yield(self) if block_given?

validate_options!
end

def depends_on(*values)
Expand All @@ -67,6 +74,10 @@ def default(value = nil, &block)
@default = block || value
end

def default_proc(&block)
@default_proc = block
end

def delegate_to(&block)
@delegate_to = block
end
Expand Down Expand Up @@ -96,6 +107,7 @@ def apply_options!(options = {})
return if options.nil? || options.empty?

default(options[:default]) if options.key?(:default)
default_proc(&options[:default_proc]) if options.key?(:default_proc)
delegate_to(&options[:delegate_to]) if options.key?(:delegate_to)
depends_on(*options[:depends_on]) if options.key?(:depends_on)
on_set(&options[:on_set]) if options.key?(:on_set)
Expand All @@ -111,6 +123,7 @@ def to_definition
def meta
{
default: @default,
default_proc: @default_proc,
delegate_to: @delegate_to,
depends_on: @depends_on,
on_set: @on_set,
Expand All @@ -119,6 +132,17 @@ def meta
type: @type
}
end

private

def validate_options!
if !@default.nil? && @default_proc
raise InvalidOptionError,
'Using `default` and `default_proc` is not allowed. Please use one or the other.' \
'If you want to store a block as the default value use `default_proc`'\
' otherwise use `default`'
end
end
end
end
end
Expand Down
5 changes: 3 additions & 2 deletions lib/datadog/core/configuration/settings.rb
Original file line number Diff line number Diff line change
Expand Up @@ -472,8 +472,9 @@ def initialize(*_)
# @default `->{ Time.now }`
# @return [Proc<Time>]
option :time_now_provider do |o|
o.default { -> { ::Time.now } }

o.default_proc do
::Time.now
end
o.on_set do |time_provider|
Core::Utils::Time.now_provider = time_provider
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ class Settings < Contrib::Configuration::Settings
end

option :service_name
option :error_handler, default: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :error_handler, default_proc: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
end
end
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ class Settings < Contrib::Configuration::Settings

option :service_name
option :client_service_name
option :error_handler, default: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :error_handler, default_proc: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
end
end
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ class Settings < Contrib::Configuration::Settings
end

option :distributed_tracing, default: true
option :error_handler, default: DEFAULT_ERROR_HANDLER
option :error_handler, default_proc: DEFAULT_ERROR_HANDLER
option :split_by_domain, default: false

option :service_name do |o|
Expand Down
2 changes: 1 addition & 1 deletion lib/datadog/tracing/contrib/grpc/configuration/settings.rb
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ class Settings < Contrib::Configuration::Settings
end
end

option :error_handler, default: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :error_handler, default_proc: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
end
end
end
Expand Down
2 changes: 1 addition & 1 deletion lib/datadog/tracing/contrib/que/configuration/settings.rb
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ class Settings < Contrib::Configuration::Settings
option :tag_data do |o|
o.default { env_to_bool(Ext::ENV_TAG_DATA_ENABLED, false) }
end
option :error_handler, default: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :error_handler, default_proc: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
end
end
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ class Settings < Contrib::Configuration::Settings
end

option :service_name
option :error_handler, default: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :error_handler, default_proc: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
end
end
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ class Settings < Contrib::Configuration::Settings
end

option :service_name
option :error_handler, default: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :error_handler, default_proc: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :tag_body, default: false
end
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ class Settings < Contrib::Configuration::Settings

option :service_name
option :client_service_name
option :error_handler, default: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :error_handler, default_proc: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :quantize, default: {}
option :distributed_tracing, default: false
end
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ class Settings < Contrib::Configuration::Settings
end

option :service_name
option :error_handler, default: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :error_handler, default_proc: Tracing::SpanOperation::Events::DEFAULT_ON_ERROR
option :tag_body, default: false
end
end
Expand Down
29 changes: 29 additions & 0 deletions spec/datadog/core/configuration/option_definition_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -176,6 +176,7 @@
it 'generates an OptionDefinition with defaults' do
is_expected.to have_attributes(
default: nil,
default_proc: nil,
delegate_to: nil,
depends_on: [],
name: name,
Expand Down Expand Up @@ -209,6 +210,23 @@
end
end
end

context 'validate_options!' do
context 'when default and default_proc is provided' do
let(:initialize_block) do
proc do |o|
o.default false
o.default_proc { true }
end
end

it do
expect do
is_expected
end.to raise_error(described_class::InvalidOptionError)
end
end
end
end

describe '#depends_on' do
Expand Down Expand Up @@ -253,6 +271,16 @@
end
end

describe '#default_proc' do
subject(:default_proc) { builder.default_proc(&block) }

context 'given a block' do
let(:block) { proc { false } }

it { is_expected.to be block }
end
end

describe '#delegate_to' do
subject(:delegate_to) { builder.delegate_to(&block) }

Expand Down Expand Up @@ -424,6 +452,7 @@
it 'contains the arguments for OptionDefinition' do
expect(meta.keys).to include(
:default,
:default_proc,
:delegate_to,
:depends_on,
:on_set,
Expand Down
8 changes: 8 additions & 0 deletions spec/datadog/core/configuration/option_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,15 @@
instance_double(
Datadog::Core::Configuration::OptionDefinition,
default: default,
default_proc: default_proc,
delegate_to: delegate,
on_set: nil,
resetter: nil,
setter: setter
)
end
let(:default) { double('default') }
let(:default_proc) { nil }
let(:delegate) { nil }
let(:setter) { proc { setter_value } }
let(:setter_value) { double('setter_value') }
Expand Down Expand Up @@ -251,5 +253,11 @@
context 'when default is not a block' do
it { is_expected.to be default }
end

context 'when default_proc is defined' do
let(:default_proc) { proc { 'default_proc' } }

it { is_expected.to be default_proc }
end
end
end

0 comments on commit f54d36f

Please sign in to comment.