2019-09-04 21:01:54 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
2021-09-04 01:27:46 +05:30
|
|
|
require_migration!
|
2019-09-04 21:01:54 +05:30
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe EnqueueResetMergeStatus do
|
2019-09-04 21:01:54 +05:30
|
|
|
let(:namespaces) { table(:namespaces) }
|
|
|
|
let(:projects) { table(:projects) }
|
2021-02-22 17:27:13 +05:30
|
|
|
let(:namespace) { namespaces.create!(name: 'gitlab', path: 'gitlab-org') }
|
|
|
|
let(:project) { projects.create!(namespace_id: namespace.id, name: 'foo') }
|
2019-09-04 21:01:54 +05:30
|
|
|
let(:merge_requests) { table(:merge_requests) }
|
|
|
|
|
|
|
|
def create_merge_request(id, extra_params = {})
|
|
|
|
params = {
|
|
|
|
id: id,
|
|
|
|
target_project_id: project.id,
|
|
|
|
target_branch: 'master',
|
|
|
|
source_project_id: project.id,
|
|
|
|
source_branch: 'mr name',
|
|
|
|
title: "mr name#{id}"
|
|
|
|
}.merge(extra_params)
|
|
|
|
|
|
|
|
merge_requests.create!(params)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'correctly schedules background migrations' do
|
|
|
|
create_merge_request(1, state: 'opened', merge_status: 'can_be_merged')
|
|
|
|
create_merge_request(2, state: 'opened', merge_status: 'can_be_merged')
|
|
|
|
create_merge_request(3, state: 'opened', merge_status: 'can_be_merged')
|
|
|
|
create_merge_request(4, state: 'merged', merge_status: 'can_be_merged')
|
|
|
|
create_merge_request(5, state: 'opened', merge_status: 'unchecked')
|
|
|
|
|
|
|
|
stub_const("#{described_class.name}::BATCH_SIZE", 2)
|
|
|
|
|
|
|
|
Sidekiq::Testing.fake! do
|
2020-11-24 15:15:51 +05:30
|
|
|
freeze_time do
|
2019-09-04 21:01:54 +05:30
|
|
|
migrate!
|
|
|
|
|
|
|
|
expect(described_class::MIGRATION)
|
|
|
|
.to be_scheduled_delayed_migration(5.minutes, 1, 2)
|
|
|
|
|
|
|
|
expect(described_class::MIGRATION)
|
|
|
|
.to be_scheduled_delayed_migration(10.minutes, 3, 4)
|
|
|
|
|
|
|
|
expect(described_class::MIGRATION)
|
|
|
|
.to be_scheduled_delayed_migration(15.minutes, 5, 5)
|
|
|
|
|
|
|
|
expect(BackgroundMigrationWorker.jobs.size).to eq(3)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|