Class: SplitIoClient::Cache::Repositories::Metrics::MemoryRepository

Inherits:
Object
  • Object
show all
Defined in:
lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb

Defined Under Namespace

Classes: SumAndCount, ValueAndCount

Constant Summary collapse

OPERATIONS =
%w(sdk.get_treatment sdk.get_treatments sdk.get_treatment_with_config sdk.get_treatments_with_config)

Instance Method Summary collapse

Constructor Details

#initialize(_ = nil, config) ⇒ MemoryRepository

Returns a new instance of MemoryRepository.



8
9
10
11
12
13
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 8

def initialize(_ = nil, config)
  @counts = []
  @latencies = []
  @gauges = []
  @config = config
end

Instance Method Details

#add_count(counter, delta) ⇒ Object



15
16
17
18
19
20
21
22
23
24
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 15

def add_count(counter, delta)
  counter_hash = @counts.find { |c| c[:name] == counter }
  if counter_hash.nil?
    counter_delta = SumAndCount.new
    counter_delta.add_delta(delta)
    @counts << { name: counter, delta: counter_delta }
  else
    counter_hash[:delta].add_delta(delta)
  end
end

#add_gauge(gauge, value) ⇒ Object



35
36
37
38
39
40
41
42
43
44
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 35

def add_gauge(gauge, value)
  gauge_hash = @gauges.find { |g| g[:name] == gauge }
  if gauge_hash.nil?
    gauge_value = ValueAndCount.new
    gauge_value.set_value(value)
    @gauges << { name: gauge, value: gauge_value }
  else
    gauge_hash[:value].set_value(value)
  end
end

#add_latency(operation, time_in_ms, binary_search) ⇒ Object



26
27
28
29
30
31
32
33
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 26

def add_latency(operation, time_in_ms, binary_search)
  if (OPERATIONS.include?(operation))
    index = binary_search.add_latency_millis(time_in_ms, true)
    increase_latency_bucket(operation, index)
  else
    concatenate_latency(operation, time_in_ms)
  end
end

#clearObject



78
79
80
81
82
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 78

def clear
  clear_counts
  clear_latencies
  clear_gauges
end

#clear_countsObject



66
67
68
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 66

def clear_counts
  @counts = []
end

#clear_gaugesObject



74
75
76
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 74

def clear_gauges
  @gauges = []
end

#clear_latenciesObject



70
71
72
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 70

def clear_latencies
  @latencies = []
end

#countsObject



46
47
48
49
50
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 46

def counts
  @counts.each_with_object({}) do |count, memo|
    memo[count[:name]] = count[:delta].sum
  end
end

#fix_latenciesObject



62
63
64
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 62

def fix_latencies
  # NOOP
end

#gaugesObject



58
59
60
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 58

def gauges
  # TODO
end

#latenciesObject



52
53
54
55
56
# File 'lib/splitclient-rb/cache/repositories/metrics/memory_repository.rb', line 52

def latencies
  @latencies.each_with_object({}) do |latency, memo|
    memo[latency[:operation]] = latency[:latencies]
  end
end