debian-mirror-gitlab/spec/services/projects/unlink_fork_service_spec.rb

90 lines
2.7 KiB
Ruby
Raw Normal View History

2019-12-16 22:33:55 +05:30
# frozen_string_literal: true
2016-06-02 11:05:42 +05:30
require 'spec_helper'
2017-09-10 17:25:29 +05:30
describe Projects::UnlinkForkService do
2018-03-17 18:26:18 +05:30
include ProjectForksHelper
2016-06-02 11:05:42 +05:30
2018-03-17 18:26:18 +05:30
subject { described_class.new(forked_project, user) }
let(:project) { create(:project, :public) }
let(:forked_project) { fork_project(project, user) }
2016-06-02 11:05:42 +05:30
let(:user) { create(:user) }
context 'with opened merge request on the source project' do
2018-12-13 13:39:08 +05:30
let(:merge_request) { create(:merge_request, source_project: forked_project, target_project: forked_project.forked_from_project) }
2018-03-17 18:26:18 +05:30
let(:merge_request2) { create(:merge_request, source_project: forked_project, target_project: fork_project(project)) }
let(:merge_request_in_fork) { create(:merge_request, source_project: forked_project, target_project: forked_project) }
let(:mr_close_service) { MergeRequests::CloseService.new(forked_project, user) }
2016-06-02 11:05:42 +05:30
before do
2017-09-10 17:25:29 +05:30
allow(MergeRequests::CloseService).to receive(:new)
2018-03-17 18:26:18 +05:30
.with(forked_project, user)
2017-09-10 17:25:29 +05:30
.and_return(mr_close_service)
2016-06-02 11:05:42 +05:30
end
it 'close all pending merge requests' do
expect(mr_close_service).to receive(:execute).with(merge_request)
2018-03-17 18:26:18 +05:30
expect(mr_close_service).to receive(:execute).with(merge_request2)
2016-06-02 11:05:42 +05:30
subject.execute
end
2018-03-17 18:26:18 +05:30
it 'does not close merge requests for the project being unlinked' do
expect(mr_close_service).not_to receive(:execute).with(merge_request_in_fork)
end
2016-06-02 11:05:42 +05:30
end
2018-03-17 18:26:18 +05:30
it 'removes the link to the fork network' do
expect(forked_project.fork_network_member).to be_present
expect(forked_project.fork_network).to be_present
subject.execute
forked_project.reload
expect(forked_project.fork_network_member).to be_nil
expect(forked_project.reload.fork_network).to be_nil
end
2017-09-10 17:25:29 +05:30
it 'refreshes the forks count cache of the source project' do
2018-03-17 18:26:18 +05:30
source = forked_project.forked_from_project
2017-09-10 17:25:29 +05:30
expect(source.forks_count).to eq(1)
subject.execute
expect(source.forks_count).to be_zero
end
2018-03-17 18:26:18 +05:30
context 'when the source has LFS objects' do
let(:lfs_object) { create(:lfs_object) }
before do
lfs_object.projects << project
end
it 'links the fork to the lfs object before unlinking' do
subject.execute
expect(lfs_object.projects).to include(forked_project)
end
it 'does not fail if the lfs objects were already linked' do
lfs_object.projects << forked_project
expect { subject.execute }.not_to raise_error
end
end
context 'when the original project was deleted' do
it 'does not fail when the original project is deleted' do
source = forked_project.forked_from_project
source.destroy
forked_project.reload
expect { subject.execute }.not_to raise_error
end
end
2016-06-02 11:05:42 +05:30
end