Sha256: eadc11c9b126cc71f95dcc9b82ab2d243f88cfd8f29b947ff1d6d7214aeb61e7

Contents?: true

Size: 622 Bytes

Versions: 38

Compression:

Stored size: 622 Bytes

Contents

require 'bundler/setup'
require 'flipper'

logging = Flipper[:logging]

perform_test = lambda do |number|
  logging.enable_percentage_of_time number

  total = 100_000
  enabled = []
  disabled = []

  enabled = (1..total).map { |n|
    logging.enabled? ? true : nil
  }.compact

  actual = (enabled.size / total.to_f * 100).round(3)

  # puts "#{enabled.size} / #{total}"
  puts "percentage: #{actual.to_s.rjust(6, ' ')} vs #{number.to_s.rjust(3, ' ')}"
end

puts "percentage: Actual vs Hoped For"

[0.001, 0.01, 0.1, 1, 5, 10, 20, 30, 40, 50, 60, 70, 80, 90, 95, 99, 100].each do |number|
  perform_test.call number
end

Version data entries

38 entries across 38 versions & 1 rubygems

Version Path
flipper-1.3.2 examples/percentage_of_time.rb
flipper-1.3.1 examples/percentage_of_time.rb
flipper-1.3.0 examples/percentage_of_time.rb
flipper-1.3.0.pre examples/percentage_of_time.rb
flipper-1.2.2 examples/percentage_of_time.rb
flipper-1.2.1 examples/percentage_of_time.rb
flipper-1.2.0 examples/percentage_of_time.rb
flipper-1.1.2 examples/percentage_of_time.rb
flipper-1.1.1 examples/percentage_of_time.rb
flipper-1.1.0 examples/percentage_of_time.rb
flipper-1.0.0 examples/percentage_of_time.rb
flipper-1.0.0.pre examples/percentage_of_time.rb
flipper-0.28.3 examples/percentage_of_time.rb
flipper-0.28.2 examples/percentage_of_time.rb
flipper-0.28.1 examples/percentage_of_time.rb
flipper-0.28.0 examples/percentage_of_time.rb
flipper-0.27.1 examples/percentage_of_time.rb
flipper-0.27.0 examples/percentage_of_time.rb
flipper-0.26.2 examples/percentage_of_time.rb
flipper-0.26.1 examples/percentage_of_time.rb