File: prune_aggregation_schedules_worker_spec.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (34 lines) | stat: -rw-r--r-- 1,057 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Namespaces::PruneAggregationSchedulesWorker, '#perform', :clean_gitlab_redis_shared_state, feature_category: :source_code_management do
  include ExclusiveLeaseHelpers

  let(:namespaces) { create_list(:namespace, 5, :with_aggregation_schedule) }

  subject(:worker) { described_class.new }

  before do
    allow(Namespaces::RootStatisticsWorker)
      .to receive(:perform_async).and_return(nil)

    allow(Namespaces::RootStatisticsWorker)
      .to receive(:perform_in).and_return(nil)

    namespaces.each do |namespace|
      lease_key = "namespace:namespaces_root_statistics:#{namespace.id}"
      stub_exclusive_lease(lease_key, timeout: namespace.aggregation_schedule.default_lease_timeout)
    end
  end

  it 'schedules a worker per pending aggregation' do
    expect(Namespaces::RootStatisticsWorker)
      .to receive(:perform_async).exactly(5).times

    expect(Namespaces::RootStatisticsWorker)
      .to receive(:perform_in).exactly(5).times

    worker.perform
  end
end