Specs on force deleting of a user
This commit is contained in:
parent
b221d11a25
commit
d249da1c16
2 changed files with 43 additions and 7 deletions
|
@ -12,7 +12,7 @@ class DeleteUserService
|
||||||
end
|
end
|
||||||
|
|
||||||
user.solo_owned_groups.each do |group|
|
user.solo_owned_groups.each do |group|
|
||||||
DeleteGroupService.new(group, current_user).execute
|
DestroyGroupService.new(group, current_user).execute
|
||||||
end
|
end
|
||||||
|
|
||||||
user.personal_projects.each do |project|
|
user.personal_projects.each do |project|
|
||||||
|
|
|
@ -7,16 +7,52 @@ describe DeleteUserWorker do
|
||||||
let!(:namespace) { create(:namespace, owner: user) }
|
let!(:namespace) { create(:namespace, owner: user) }
|
||||||
let!(:project) { create(:project, namespace: namespace) }
|
let!(:project) { create(:project, namespace: namespace) }
|
||||||
|
|
||||||
before do
|
context 'no force flag given' do
|
||||||
DeleteUserWorker.new.perform(current_user.id, user.id)
|
before do
|
||||||
|
DeleteUserWorker.new.perform(current_user.id, user.id)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'deletes all personal projects' do
|
||||||
|
expect { Project.find(project.id) }.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'deletes the user' do
|
||||||
|
expect { User.find(user.id) }.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'deletes all personal projects' do
|
context "solo owned groups present" do
|
||||||
expect { Project.find(project.id) }.to raise_error(ActiveRecord::RecordNotFound)
|
let(:solo_owned) { create(:group) }
|
||||||
|
let(:member) { create(:group_member) }
|
||||||
|
let(:user) { user = member.user }
|
||||||
|
|
||||||
|
before do
|
||||||
|
solo_owned.group_members = [member]
|
||||||
|
DeleteUserWorker.new.perform(current_user.id, user.id)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'does not delete the user' do
|
||||||
|
expect(User.find(user.id)).to eq user
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'deletes the user' do
|
context "deletions with force" do
|
||||||
expect { User.find(user.id) }.to raise_error(ActiveRecord::RecordNotFound)
|
let(:solo_owned) { create(:group) }
|
||||||
|
let(:member) { create(:group_member) }
|
||||||
|
let(:user) { user = member.user }
|
||||||
|
|
||||||
|
before do
|
||||||
|
solo_owned.group_members = [member]
|
||||||
|
DeleteUserWorker.new.perform(current_user.id, user.id, "force" => true)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'deletes solo owned groups' do
|
||||||
|
expect { Project.find(solo_owned.id) }.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'deletes the user' do
|
||||||
|
expect { User.find(user.id) }.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue