mirror of
https://gitlab.com/gitlab-org/gitlab-foss.git
synced 2025-07-29 12:00:32 +00:00
77 lines
2.1 KiB
Ruby
77 lines
2.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe ProjectDestroyWorker, feature_category: :source_code_management do
|
|
let!(:project) { create(:project, :repository, pending_delete: true) }
|
|
let!(:repository) { project.repository.raw }
|
|
|
|
let(:user) { project.first_owner }
|
|
let(:params) { {} }
|
|
|
|
subject(:worker) { described_class.new }
|
|
|
|
it_behaves_like 'an idempotent worker' do
|
|
let(:job_args) { [project.id, user.id, {}] }
|
|
|
|
it 'does not change projects when run twice' do
|
|
expect { worker.perform(project.id, user.id, {}) }.to change { Project.count }.by(-1)
|
|
expect { worker.perform(project.id, user.id, {}) }.not_to change { Project.count }
|
|
end
|
|
end
|
|
|
|
describe '#perform' do
|
|
shared_examples 'deletes the project' do
|
|
specify do
|
|
worker.perform(project.id, user.id, params)
|
|
|
|
expect(Project.all).not_to include(project)
|
|
expect(repository).not_to exist
|
|
end
|
|
end
|
|
|
|
it_behaves_like 'deletes the project'
|
|
|
|
context 'when an admin deletes the project' do
|
|
let_it_be(:user) { create(:admin) }
|
|
|
|
context 'with admin_mode setting enabled' do
|
|
context 'with admin mode session', :enable_admin_mode do
|
|
it_behaves_like 'deletes the project'
|
|
end
|
|
|
|
context 'without admin mode session' do
|
|
it 'does not delete the project' do
|
|
worker.perform(project.id, user.id, params)
|
|
|
|
expect(Project.all).to include(project)
|
|
expect(repository).to exist
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with admin_mode setting disabled' do
|
|
before do
|
|
stub_application_setting(admin_mode: false)
|
|
end
|
|
|
|
context 'without admin mode session' do
|
|
it_behaves_like 'deletes the project'
|
|
end
|
|
end
|
|
end
|
|
|
|
it 'does not raise error when project could not be found' do
|
|
expect do
|
|
worker.perform(-1, user.id, {})
|
|
end.not_to raise_error
|
|
end
|
|
|
|
it 'does not raise error when user could not be found' do
|
|
expect do
|
|
worker.perform(project.id, -1, {})
|
|
end.not_to raise_error
|
|
end
|
|
end
|
|
end
|