Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/services/repositories/destroy_service_spec.rb')
-rw-r--r--spec/services/repositories/destroy_service_spec.rb80
1 files changed, 80 insertions, 0 deletions
diff --git a/spec/services/repositories/destroy_service_spec.rb b/spec/services/repositories/destroy_service_spec.rb
new file mode 100644
index 00000000000..9c2694483c1
--- /dev/null
+++ b/spec/services/repositories/destroy_service_spec.rb
@@ -0,0 +1,80 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+describe Repositories::DestroyService do
+ let_it_be(:user) { create(:user) }
+ let!(:project) { create(:project, :repository, namespace: user.namespace) }
+ let(:repository) { project.repository }
+ let(:path) { repository.disk_path }
+ let(:remove_path) { "#{path}+#{project.id}#{described_class::DELETED_FLAG}" }
+
+ subject { described_class.new(project.repository).execute }
+
+ it 'moves the repository to a +deleted folder' do
+ expect(project.gitlab_shell.repository_exists?(project.repository_storage, path + '.git')).to be_truthy
+ expect(project.gitlab_shell.repository_exists?(project.repository_storage, remove_path + '.git')).to be_falsey
+
+ subject
+
+ expect(project.gitlab_shell.repository_exists?(project.repository_storage, path + '.git')).to be_falsey
+ expect(project.gitlab_shell.repository_exists?(project.repository_storage, remove_path + '.git')).to be_truthy
+ end
+
+ it 'schedules the repository deletion' do
+ subject
+
+ expect(Repositories::ShellDestroyService).to receive(:new).with(repository).and_call_original
+
+ expect(GitlabShellWorker).to receive(:perform_in)
+ .with(Repositories::ShellDestroyService::REPO_REMOVAL_DELAY, :remove_repository, project.repository_storage, remove_path)
+
+ # Because GitlabShellWorker is inside a run_after_commit callback we need to
+ # trigger the callback
+ project.touch
+ end
+
+ it 'removes the repository', :sidekiq_inline do
+ subject
+
+ project.touch
+
+ expect(project.gitlab_shell.repository_exists?(project.repository_storage, path + '.git')).to be_falsey
+ expect(project.gitlab_shell.repository_exists?(project.repository_storage, remove_path + '.git')).to be_falsey
+ end
+
+ it 'flushes the repository cache' do
+ expect(repository).to receive(:before_delete)
+
+ subject
+ end
+
+ it 'does not perform any action if repository path does not exist and returns success' do
+ expect(repository).to receive(:disk_path).and_return('foo')
+ expect(repository).not_to receive(:before_delete)
+
+ result = subject
+
+ expect(result[:status]).to eq :success
+ end
+
+ context 'when move operation cannot be performed' do
+ let(:service) { described_class.new(repository) }
+
+ before do
+ allow(service).to receive(:mv_repository).and_return(false)
+ end
+
+ it 'returns error' do
+ result = service.execute
+
+ expect(result[:status]).to eq :error
+ end
+
+ it 'logs the error' do
+ expect(Gitlab::AppLogger).to receive(:error)
+
+ service.execute
+ end
+ end
+end