2016-09-13 17:45:13 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe ProjectDestroyWorker do
|
2017-09-10 17:25:29 +05:30
|
|
|
let(:project) { create(:project, :repository, pending_delete: true) }
|
2018-11-08 19:23:39 +05:30
|
|
|
let(:path) do
|
|
|
|
Gitlab::GitalyClient::StorageSettings.allow_disk_access do
|
|
|
|
project.repository.path_to_repo
|
|
|
|
end
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
subject { described_class.new }
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe '#perform' do
|
|
|
|
it 'deletes the project' do
|
2017-08-17 22:00:37 +05:30
|
|
|
subject.perform(project.id, project.owner.id, {})
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
expect(Project.all).not_to include(project)
|
|
|
|
expect(Dir.exist?(path)).to be_falsey
|
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
it 'deletes the project but skips repo deletion' do
|
2017-08-17 22:00:37 +05:30
|
|
|
subject.perform(project.id, project.owner.id, { "skip_repo" => true })
|
2016-09-13 17:45:13 +05:30
|
|
|
|
|
|
|
expect(Project.all).not_to include(project)
|
|
|
|
expect(Dir.exist?(path)).to be_truthy
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
it 'does not raise error when project could not be found' do
|
|
|
|
expect do
|
|
|
|
subject.perform(-1, project.owner.id, {})
|
|
|
|
end.not_to raise_error
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not raise error when user could not be found' do
|
|
|
|
expect do
|
|
|
|
subject.perform(project.id, -1, {})
|
|
|
|
end.not_to raise_error
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
end
|
|
|
|
end
|