diff options
Diffstat (limited to 'spec/workers/project_update_repository_storage_worker_spec.rb')
-rw-r--r-- | spec/workers/project_update_repository_storage_worker_spec.rb | 42 |
1 files changed, 5 insertions, 37 deletions
diff --git a/spec/workers/project_update_repository_storage_worker_spec.rb b/spec/workers/project_update_repository_storage_worker_spec.rb index f75bb3d1642..490f1f5a2ad 100644 --- a/spec/workers/project_update_repository_storage_worker_spec.rb +++ b/spec/workers/project_update_repository_storage_worker_spec.rb @@ -3,45 +3,13 @@ require 'spec_helper' RSpec.describe ProjectUpdateRepositoryStorageWorker do - let(:project) { create(:project, :repository) } - subject { described_class.new } - describe "#perform" do - let(:service) { double(:update_repository_storage_service) } - - before do - allow(Gitlab.config.repositories.storages).to receive(:keys).and_return(%w[default test_second_storage]) - end - - context 'without repository storage move' do - it "calls the update repository storage service" do - expect(Projects::UpdateRepositoryStorageService).to receive(:new).and_return(service) - expect(service).to receive(:execute) - - expect do - subject.perform(project.id, 'test_second_storage') - end.to change(ProjectRepositoryStorageMove, :count).by(1) - - storage_move = project.repository_storage_moves.last - expect(storage_move).to have_attributes( - source_storage_name: "default", - destination_storage_name: "test_second_storage" - ) - end - end - - context 'with repository storage move' do - let!(:repository_storage_move) { create(:project_repository_storage_move) } - - it "calls the update repository storage service" do - expect(Projects::UpdateRepositoryStorageService).to receive(:new).and_return(service) - expect(service).to receive(:execute) + it_behaves_like 'an update storage move worker' do + let_it_be_with_refind(:container) { create(:project, :repository) } + let_it_be(:repository_storage_move) { create(:project_repository_storage_move) } - expect do - subject.perform(nil, nil, repository_storage_move.id) - end.not_to change(ProjectRepositoryStorageMove, :count) - end - end + let(:service_klass) { Projects::UpdateRepositoryStorageService } + let(:repository_storage_move_klass) { ProjectRepositoryStorageMove } end end |