2016-08-03 19:45:06 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe ProjectDestroyWorker do
|
2017-06-29 07:43:01 -04:00
|
|
|
let(:project) { create(:project, :repository, pending_delete: true) }
|
2016-08-03 19:45:06 -04:00
|
|
|
let(:path) { project.repository.path_to_repo }
|
|
|
|
|
2017-05-01 11:13:33 -04:00
|
|
|
subject { described_class.new }
|
2016-08-03 19:45:06 -04:00
|
|
|
|
2017-06-29 07:43:01 -04:00
|
|
|
describe '#perform' do
|
|
|
|
it 'deletes the project' do
|
2017-01-27 21:50:25 -05:00
|
|
|
subject.perform(project.id, project.owner.id, {})
|
2016-08-03 19:45:06 -04:00
|
|
|
|
|
|
|
expect(Project.all).not_to include(project)
|
|
|
|
expect(Dir.exist?(path)).to be_falsey
|
|
|
|
end
|
|
|
|
|
2017-06-29 07:43:01 -04:00
|
|
|
it 'deletes the project but skips repo deletion' do
|
2017-01-27 21:50:25 -05:00
|
|
|
subject.perform(project.id, project.owner.id, { "skip_repo" => true })
|
2016-08-03 19:45:06 -04:00
|
|
|
|
|
|
|
expect(Project.all).not_to include(project)
|
|
|
|
expect(Dir.exist?(path)).to be_truthy
|
|
|
|
end
|
2017-06-29 07:43:01 -04:00
|
|
|
|
|
|
|
describe 'when StandardError is raised' do
|
|
|
|
it 'reverts pending_delete attribute with a error message' do
|
|
|
|
allow_any_instance_of(::Projects::DestroyService).to receive(:execute).and_raise(StandardError, "some error message")
|
|
|
|
|
|
|
|
expect do
|
|
|
|
subject.perform(project.id, project.owner.id, {})
|
|
|
|
end.to change { project.reload.pending_delete }.from(true).to(false)
|
|
|
|
|
|
|
|
expect(Project.all).to include(project)
|
|
|
|
expect(project.delete_error).to eq("some error message")
|
|
|
|
end
|
|
|
|
end
|
2016-08-03 19:45:06 -04:00
|
|
|
end
|
|
|
|
end
|