Commit 3e902a65 authored by ggelatti's avatar ggelatti

Support multiple HLL redis counter files

Move events file to specific folder
to support future additional files
parent b16a1537
...@@ -15,9 +15,9 @@ module Gitlab ...@@ -15,9 +15,9 @@ module Gitlab
CategoryMismatch = Class.new(EventError) CategoryMismatch = Class.new(EventError)
UnknownAggregationOperator = Class.new(EventError) UnknownAggregationOperator = Class.new(EventError)
KNOWN_EVENTS_PATH = 'lib/gitlab/usage_data_counters/known_events.yml' KNOWN_EVENTS_PATH = 'lib/gitlab/usage_data_counters/known_events/*.yml'
ALLOWED_AGGREGATIONS = %i(daily weekly).freeze ALLOWED_AGGREGATIONS = %i(daily weekly).freeze
AGGREGATED_METRICS_PATH = 'lib/gitlab/usage_data_counters/aggregated_metrics.yml' AGGREGATED_METRICS_PATH = 'lib/gitlab/usage_data_counters/aggregated_metrics/*.yml'
ALLOWED_METRICS_AGGREGATIONS = %w[ANY].freeze ALLOWED_METRICS_AGGREGATIONS = %w[ANY].freeze
# Track event on entity_id # Track event on entity_id
...@@ -102,6 +102,14 @@ module Gitlab ...@@ -102,6 +102,14 @@ module Gitlab
end end
end end
def known_events
@known_events ||= load_events(KNOWN_EVENTS_PATH)
end
def aggregated_metrics
@aggregated_metrics ||= load_events(AGGREGATED_METRICS_PATH)
end
private private
def calculate_count_for_aggregation(aggregation, start_date:, end_date:) def calculate_count_for_aggregation(aggregation, start_date:, end_date:)
...@@ -141,12 +149,10 @@ module Gitlab ...@@ -141,12 +149,10 @@ module Gitlab
end end
end end
def known_events def load_events(wildcard)
@known_events ||= load_yaml_from_path(KNOWN_EVENTS_PATH) Dir[wildcard].each_with_object([]) do |path, events|
end events.push(*load_yaml_from_path(path))
end
def aggregated_metrics
@aggregated_metrics ||= (load_yaml_from_path(AGGREGATED_METRICS_PATH) || [])
end end
def load_yaml_from_path(path) def load_yaml_from_path(path)
......
...@@ -14,12 +14,10 @@ RSpec.describe 'aggregated metrics' do ...@@ -14,12 +14,10 @@ RSpec.describe 'aggregated metrics' do
end end
let_it_be(:known_events) do let_it_be(:known_events) do
YAML.load_file( Gitlab::UsageDataCounters::HLLRedisCounter.known_events
Rails.root.join(Gitlab::UsageDataCounters::HLLRedisCounter::KNOWN_EVENTS_PATH)
).map(&:with_indifferent_access)
end end
YAML.load_file(Rails.root.join(Gitlab::UsageDataCounters::HLLRedisCounter::AGGREGATED_METRICS_PATH))&.map(&:with_indifferent_access).tap do |aggregated_metrics| Gitlab::UsageDataCounters::HLLRedisCounter.aggregated_metrics.tap do |aggregated_metrics|
it 'all events has unique name' do it 'all events has unique name' do
event_names = aggregated_metrics&.map { |event| event[:name] } event_names = aggregated_metrics&.map { |event| event[:name] }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment