Update batch size when calculating secure build metrics

parent 8814eae6
...@@ -7,6 +7,11 @@ module Gitlab ...@@ -7,6 +7,11 @@ module Gitlab
class CountCiBuildsMetric < DatabaseMetric class CountCiBuildsMetric < DatabaseMetric
relation { ::Ci::Build } relation { ::Ci::Build }
operation :count operation :count
metric_options do
{
batch_size: 1_000_000
}
end
def initialize(time_frame:, options: {}) def initialize(time_frame:, options: {})
super super
......
...@@ -33,6 +33,12 @@ module Gitlab ...@@ -33,6 +33,12 @@ module Gitlab
@metric_relation = block @metric_relation = block
end end
def metric_options(&block)
return @metric_options&.call.to_h unless block_given?
@metric_options = block
end
def operation(symbol, column: nil, &block) def operation(symbol, column: nil, &block)
@metric_operation = symbol @metric_operation = symbol
@column = column @column = column
...@@ -54,6 +60,7 @@ module Gitlab ...@@ -54,6 +60,7 @@ module Gitlab
self.class.column, self.class.column,
start: start, start: start,
finish: finish, finish: finish,
**self.class.metric_options,
&self.class.metric_operation_block) &self.class.metric_operation_block)
end end
......
...@@ -36,6 +36,28 @@ RSpec.describe Gitlab::Usage::Metrics::Instrumentations::DatabaseMetric do ...@@ -36,6 +36,28 @@ RSpec.describe Gitlab::Usage::Metrics::Instrumentations::DatabaseMetric do
expect(Rails.cache.read('metric_instrumentation/special_issue_count_maximum_id')).to eq(nil) expect(Rails.cache.read('metric_instrumentation/special_issue_count_maximum_id')).to eq(nil)
end end
context 'with metric options specified with custom batch_size' do
subject do
described_class.tap do |metric_class|
metric_class.relation { Issue }
metric_class.operation :count
metric_class.start { metric_class.relation.minimum(:id) }
metric_class.finish { metric_class.relation.maximum(:id) }
metric_class.metric_options { { batch_size: 12345 } }
end.new(time_frame: 'all')
end
it 'calls metric with customized batch_size' do
expect(subject).to receive(:count).with(any_args, hash_including(batch_size: 12345, start: issues.min_by(&:id).id, finish: issues.max_by(&:id).id)).and_call_original
subject.value
end
it 'calculates a correct result' do
expect(subject.value).to eq(3)
end
end
context 'with start and finish not called' do context 'with start and finish not called' do
subject do subject do
described_class.tap do |metric_class| described_class.tap do |metric_class|
......
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