summaryrefslogtreecommitdiff
path: root/lib/gitlab/usage/metrics/aggregates/aggregate.rb
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2023-01-18 19:00:14 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2023-01-18 19:00:14 +0000
commit05f0ebba3a2c8ddf39e436f412dc2ab5bf1353b2 (patch)
tree11d0f2a6ec31c7793c184106cedc2ded3d9a2cc5 /lib/gitlab/usage/metrics/aggregates/aggregate.rb
parentec73467c23693d0db63a797d10194da9e72a74af (diff)
downloadgitlab-ce-05f0ebba3a2c8ddf39e436f412dc2ab5bf1353b2.tar.gz
Add latest changes from gitlab-org/gitlab@15-8-stable-eev15.8.0-rc42
Diffstat (limited to 'lib/gitlab/usage/metrics/aggregates/aggregate.rb')
-rw-r--r--lib/gitlab/usage/metrics/aggregates/aggregate.rb20
1 files changed, 18 insertions, 2 deletions
diff --git a/lib/gitlab/usage/metrics/aggregates/aggregate.rb b/lib/gitlab/usage/metrics/aggregates/aggregate.rb
index 8d816c8d902..b68e1ace658 100644
--- a/lib/gitlab/usage/metrics/aggregates/aggregate.rb
+++ b/lib/gitlab/usage/metrics/aggregates/aggregate.rb
@@ -7,6 +7,11 @@ module Gitlab
class Aggregate
include Gitlab::Usage::TimeFrame
+ # TODO: define this missing event https://gitlab.com/gitlab-org/gitlab/-/issues/385080
+ EVENTS_NOT_DEFINED_YET = %w[
+ i_code_review_merge_request_widget_license_compliance_warning
+ ].freeze
+
def initialize(recorded_at)
@recorded_at = recorded_at
end
@@ -14,11 +19,12 @@ module Gitlab
def calculate_count_for_aggregation(aggregation:, time_frame:)
with_validate_configuration(aggregation, time_frame) do
source = SOURCES[aggregation[:source]]
+ events = select_defined_events(aggregation[:events], aggregation[:source])
if aggregation[:operator] == UNION_OF_AGGREGATED_METRICS
- source.calculate_metrics_union(**time_constraints(time_frame).merge(metric_names: aggregation[:events], recorded_at: recorded_at))
+ source.calculate_metrics_union(**time_constraints(time_frame).merge(metric_names: events, recorded_at: recorded_at))
else
- source.calculate_metrics_intersections(**time_constraints(time_frame).merge(metric_names: aggregation[:events], recorded_at: recorded_at))
+ source.calculate_metrics_intersections(**time_constraints(time_frame).merge(metric_names: events, recorded_at: recorded_at))
end
end
rescue Gitlab::UsageDataCounters::HLLRedisCounter::EventError, AggregatedMetricError => error
@@ -71,6 +77,16 @@ module Gitlab
{ start_date: nil, end_date: nil }
end
end
+
+ def select_defined_events(events, source)
+ # Database source metrics get validated inside the PostgresHll class:
+ # https://gitlab.com/gitlab-org/gitlab/-/blob/master/lib/gitlab/usage/metrics/aggregates/sources/postgres_hll.rb#L16
+ return events if source != ::Gitlab::Usage::Metrics::Aggregates::REDIS_SOURCE
+
+ events.select do |event|
+ ::Gitlab::UsageDataCounters::HLLRedisCounter.known_event?(event) || EVENTS_NOT_DEFINED_YET.include?(event)
+ end
+ end
end
end
end