debian-mirror-gitlab/spec/workers/hashed_storage/project_rollback_worker_spec.rb

51 lines
1.5 KiB
Ruby
Raw Normal View History

2019-07-07 11:18:12 +05:30
# frozen_string_literal: true
2018-03-17 18:26:18 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe HashedStorage::ProjectRollbackWorker, :clean_gitlab_redis_shared_state do
2018-11-08 19:23:39 +05:30
include ExclusiveLeaseHelpers
2018-03-17 18:26:18 +05:30
describe '#perform' do
2019-07-07 11:18:12 +05:30
let(:project) { create(:project, :empty_repo) }
2018-11-08 19:23:39 +05:30
let(:lease_key) { "project_migrate_hashed_storage_worker:#{project.id}" }
2019-03-02 22:35:43 +05:30
let(:lease_timeout) { described_class::LEASE_TIMEOUT }
2019-07-07 11:18:12 +05:30
let(:rollback_service) { ::Projects::HashedStorage::RollbackService }
2018-11-08 19:23:39 +05:30
it 'skips when project no longer exists' do
2019-07-07 11:18:12 +05:30
expect(rollback_service).not_to receive(:new)
2018-11-08 19:23:39 +05:30
subject.perform(-1)
end
2018-03-17 18:26:18 +05:30
2018-11-08 19:23:39 +05:30
it 'skips when project is pending delete' do
pending_delete_project = create(:project, :empty_repo, pending_delete: true)
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
expect(rollback_service).not_to receive(:new)
2018-03-17 18:26:18 +05:30
2018-11-08 19:23:39 +05:30
subject.perform(pending_delete_project.id)
end
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
it 'delegates rollback to service class when have exclusive lease' do
2018-11-08 19:23:39 +05:30
stub_exclusive_lease(lease_key, 'uuid', timeout: lease_timeout)
2018-03-17 18:26:18 +05:30
2019-03-02 22:35:43 +05:30
service_spy = spy
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
allow(rollback_service)
.to receive(:new).with(project, project.disk_path, logger: subject.logger)
2019-03-02 22:35:43 +05:30
.and_return(service_spy)
2018-03-17 18:26:18 +05:30
2018-11-08 19:23:39 +05:30
subject.perform(project.id)
2018-03-17 18:26:18 +05:30
2019-03-02 22:35:43 +05:30
expect(service_spy).to have_received(:execute)
2018-03-17 18:26:18 +05:30
end
2019-03-02 22:35:43 +05:30
it 'skips when it cant acquire the exclusive lease' do
2018-11-08 19:23:39 +05:30
stub_exclusive_lease_taken(lease_key, timeout: lease_timeout)
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
expect(rollback_service).not_to receive(:new)
2018-03-17 18:26:18 +05:30
2018-11-08 19:23:39 +05:30
subject.perform(project.id)
2018-03-17 18:26:18 +05:30
end
end
end