2020-10-24 23:57:45 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# Extend the Feature class with the ability to stub feature flags.
|
|
|
|
module StubbedFeature
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
|
|
|
class_methods do
|
|
|
|
# Turn stubbed feature flags on or off.
|
|
|
|
def stub=(stub)
|
|
|
|
@stub = stub
|
|
|
|
end
|
|
|
|
|
|
|
|
def stub?
|
|
|
|
@stub.nil? ? true : @stub
|
|
|
|
end
|
|
|
|
|
|
|
|
# Wipe any previously set feature flags.
|
|
|
|
def reset_flipper
|
|
|
|
@flipper = nil
|
|
|
|
end
|
|
|
|
|
|
|
|
# Replace #flipper method with the optional stubbed/unstubbed version.
|
|
|
|
def flipper
|
|
|
|
if stub?
|
|
|
|
@flipper ||= Flipper.new(Flipper::Adapters::Memory.new)
|
|
|
|
else
|
|
|
|
super
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Replace #enabled? method with the optional stubbed/unstubbed version.
|
|
|
|
def enabled?(*args)
|
|
|
|
feature_flag = super(*args)
|
|
|
|
return feature_flag unless stub?
|
|
|
|
|
|
|
|
# If feature flag is not persisted we mark the feature flag as enabled
|
|
|
|
# We do `m.call` as we want to validate the execution of method arguments
|
|
|
|
# and a feature flag state if it is not persisted
|
|
|
|
unless Feature.persisted_name?(args.first)
|
2020-11-24 15:15:51 +05:30
|
|
|
feature_flag = true
|
2020-10-24 23:57:45 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
feature_flag
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|